1/* 2 * Copyright (c) 2014 Apple Inc. All Rights Reserved. 3 * 4 * @APPLE_LICENSE_HEADER_START@ 5 * 6 * This file contains Original Code and/or Modifications of Original Code 7 * as defined in and that are subject to the Apple Public Source License 8 * Version 2.0 (the 'License'). You may not use this file except in 9 * compliance with the License. Please obtain a copy of the License at 10 * http://www.opensource.apple.com/apsl/ and read it before using this 11 * file. 12 * 13 * The Original Code and all software distributed under the License are 14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, 16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, 17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 18 * Please see the License for the specific language governing rights and 19 * limitations under the License. 20 * 21 * @APPLE_LICENSE_HEADER_END@ 22 */ 23#ifndef _SWCAGENT_CLIENT_H_ 24#define _SWCAGENT_CLIENT_H_ 25 26#include <stdint.h> 27 28#include <CoreFoundation/CFArray.h> 29#include <CoreFoundation/CFDictionary.h> 30#include <CoreFoundation/CFError.h> 31 32#include <xpc/xpc.h> 33#include <CoreFoundation/CFXPCBridge.h> 34 35// TODO: This should be in client of XPC code locations... 36#define kSWCAXPCServiceName "com.apple.security.swcagent" 37 38// 39// MARK: XPC Information. 40// 41 42extern CFStringRef sSWCAXPCErrorDomain; 43 44// 45// MARK: XPC Interfaces 46// 47 48extern const char *kSecXPCKeyOperation; 49extern const char *kSecXPCKeyResult; 50extern const char *kSecXPCKeyError; 51extern const char *kSecXPCKeyClientToken; 52extern const char *kSecXPCKeyPeerInfos; 53extern const char *kSecXPCKeyUserLabel; 54extern const char *kSecXPCKeyUserPassword; 55extern const char *kSecXPCLimitInMinutes; 56extern const char *kSecXPCKeyQuery; 57extern const char *kSecXPCKeyAttributesToUpdate; 58extern const char *kSecXPCKeyDomain; 59extern const char *kSecXPCKeyDigest; 60extern const char *kSecXPCKeyCertificate; 61extern const char *kSecXPCKeySettings; 62extern const char *kSecXPCKeyDeviceID; 63 64// 65// MARK: Mach port request IDs 66// 67enum SWCAXPCOperation { 68 swca_add_request_id, 69 swca_update_request_id, 70 swca_delete_request_id, 71 swca_copy_request_id, 72 swca_select_request_id, 73 swca_copy_pairs_request_id, 74 swca_set_selection_request_id, 75 swca_enabled_request_id, 76}; 77 78xpc_object_t swca_message_with_reply_sync(xpc_object_t message, CFErrorRef *error); 79xpc_object_t swca_create_message(enum SWCAXPCOperation op, CFErrorRef *error); 80bool swca_message_no_error(xpc_object_t message, CFErrorRef *error); 81long swca_message_response(xpc_object_t replyMessage, CFErrorRef *error); 82 83bool swca_autofill_enabled(const audit_token_t *auditToken); 84 85bool swca_confirm_operation(enum SWCAXPCOperation op, 86 const audit_token_t *auditToken, 87 CFTypeRef query, 88 CFErrorRef *error, 89 void (^add_negative_entry)(CFStringRef fqdn)); 90 91CFTypeRef swca_message_copy_response(xpc_object_t replyMessage, CFErrorRef *error); 92 93CFDictionaryRef swca_copy_selected_dictionary(enum SWCAXPCOperation op, 94 const audit_token_t *auditToken, 95 CFTypeRef items, 96 CFErrorRef *error); 97 98CFArrayRef swca_copy_pairs(enum SWCAXPCOperation op, 99 const audit_token_t *auditToken, 100 CFErrorRef *error); 101 102bool swca_set_selection(enum SWCAXPCOperation op, 103 const audit_token_t *auditToken, 104 CFTypeRef dictionary, 105 CFErrorRef *error); 106 107bool swca_send_sync_and_do(enum SWCAXPCOperation op, CFErrorRef *error, 108 bool (^add_to_message)(xpc_object_t message, CFErrorRef* error), 109 bool (^handle_response)(xpc_object_t response, CFErrorRef* error)); 110 111 112#endif /* _SWCAGENT_CLIENT_H_ */ 113