2 * Copyright (c) 2014 Apple Inc. All Rights Reserved.
4 * @APPLE_LICENSE_HEADER_START@
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
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.
21 * @APPLE_LICENSE_HEADER_END@
23 #ifndef _SWCAGENT_CLIENT_H_
24 #define _SWCAGENT_CLIENT_H_
28 #include <CoreFoundation/CFArray.h>
29 #include <CoreFoundation/CFDictionary.h>
30 #include <CoreFoundation/CFError.h>
33 #include <CoreFoundation/CFXPCBridge.h>
35 // TODO: This should be in client of XPC code locations...
36 #define kSWCAXPCServiceName "com.apple.security.swcagent"
39 // MARK: XPC Information.
42 extern CFStringRef sSWCAXPCErrorDomain
;
45 // MARK: XPC Interfaces
48 extern const char *kSecXPCKeyOperation
;
49 extern const char *kSecXPCKeyResult
;
50 extern const char *kSecXPCKeyError
;
51 extern const char *kSecXPCKeyClientToken
;
52 extern const char *kSecXPCKeyPeerInfos
;
53 extern const char *kSecXPCKeyUserLabel
;
54 extern const char *kSecXPCKeyUserPassword
;
55 extern const char *kSecXPCLimitInMinutes
;
56 extern const char *kSecXPCKeyQuery
;
57 extern const char *kSecXPCKeyAttributesToUpdate
;
58 extern const char *kSecXPCKeyDomain
;
59 extern const char *kSecXPCKeyDigest
;
60 extern const char *kSecXPCKeyCertificate
;
61 extern const char *kSecXPCKeySettings
;
62 extern const char *kSecXPCKeyDeviceID
;
65 // MARK: Mach port request IDs
67 enum SWCAXPCOperation
{
69 swca_update_request_id
,
70 swca_delete_request_id
,
72 swca_select_request_id
,
73 swca_copy_pairs_request_id
,
74 swca_set_selection_request_id
,
75 swca_enabled_request_id
,
78 xpc_object_t
swca_message_with_reply_sync(xpc_object_t message
, CFErrorRef
*error
);
79 xpc_object_t
swca_create_message(enum SWCAXPCOperation op
, CFErrorRef
*error
);
80 bool swca_message_no_error(xpc_object_t message
, CFErrorRef
*error
);
81 long swca_message_response(xpc_object_t replyMessage
, CFErrorRef
*error
);
83 bool swca_autofill_enabled(const audit_token_t
*auditToken
);
85 bool swca_confirm_operation(enum SWCAXPCOperation op
,
86 const audit_token_t
*auditToken
,
89 void (^add_negative_entry
)(CFStringRef fqdn
));
91 CFTypeRef
swca_message_copy_response(xpc_object_t replyMessage
, CFErrorRef
*error
);
93 CFDictionaryRef
swca_copy_selected_dictionary(enum SWCAXPCOperation op
,
94 const audit_token_t
*auditToken
,
98 CFArrayRef
swca_copy_pairs(enum SWCAXPCOperation op
,
99 const audit_token_t
*auditToken
,
102 bool swca_set_selection(enum SWCAXPCOperation op
,
103 const audit_token_t
*auditToken
,
104 CFTypeRef dictionary
,
107 bool 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
));
112 #endif /* _SWCAGENT_CLIENT_H_ */