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