]> git.saurik.com Git - apple/security.git/blame - OSX/sec/SOSCircle/CKBridge/SOSCloudKeychainConstants.c
Security-57337.60.2.tar.gz
[apple/security.git] / OSX / sec / SOSCircle / CKBridge / SOSCloudKeychainConstants.c
CommitLineData
427c49bc 1/*
d8f41ccd 2 * Copyright (c) 2012-2014 Apple Inc. All Rights Reserved.
427c49bc
A
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
24/*
25 This XPC service is essentially just a proxy to iCloud KVS, which exists since
26 the main security code cannot link against Foundation.
27
28 See sendTSARequestWithXPC in tsaSupport.c for how to call the service
29
30 The client of an XPC service does not get connection events, nor does it
31 need to deal with transactions.
32*/
33
34//------------------------------------------------------------------------------------------------
35
36
37#include <CoreFoundation/CoreFoundation.h>
38#include "SOSCloudKeychainConstants.h"
39
40const uint64_t kCKDXPCVersion = 1;
41
42// seems like launchd looks for the BundleIdentifier, not the name
43const char *xpcServiceName = "com.apple.security.cloudkeychainproxy3"; //"CloudKeychainProxy";
5c19dc3a 44const char *xpcIDSServiceName = "com.apple.security.idskeychainsyncingproxy";
427c49bc
A
45
46const char *kMessageKeyOperation = "operation";
47const char *kMessageKeyKey = "key";
48const char *kMessageKeyValue = "value";
49const char *kMessageKeyError = "error";
50const char *kMessageKeyVersion = "version";
51const char *kMessageKeyGetNewKeysOnly = "GetNewKeysOnly";
52const char *kMessageKeyKeysToGet = "KeysToGet";
53const char *kMessageKeyKeysRequireFirstUnlock = "KeysRequireFirstUnlock";
54const char *kMessageKeyKeysRequiresUnlocked = "KeysRequiresUnlocked";
427c49bc
A
55const char *kMessageKeyNotificationFlags = "NotificationFlags";
56
d8f41ccd
A
57/* parameters within the dictionary */
58const char *kMessageAlwaysKeys = "AlwaysKeys";
59const char *kMessageFirstUnlocked = "FirstUnlockKeys";
60const char *kMessageUnlocked = "UnlockedKeys";
61
62const char *kMessageContext = "Context";
63const char *kMessageAllKeys = "AllKeys";
64const char *kMessageKeyParameter = "KeyParameter";
65const char *kMessageCircle = "Circle";
66const char *kMessageMessage = "Message";
5c19dc3a
A
67const char *kMessageKeyDeviceName = "deviceName";
68const char *kMessageKeyIDSDataMessage = "idsDataMessage";
69const char *kMessageKeyDeviceID = "deviceID";
70const char *kMessageKeyPeerID = "peerID";
d8f41ccd 71
427c49bc
A
72const char *kMessageOperationItemChanged = "ItemChanged";
73
74const char *kOperationClearStore = "ClearStore";
75const char *kOperationSynchronize = "Synchronize";
76const char *kOperationSynchronizeAndWait = "SynchronizeAndWait";
77
d8f41ccd
A
78const char *kOperationFlush = "Flush";
79
427c49bc
A
80const char *kOperationPUTDictionary = "PUTDictionary";
81const char *kOperationGETv2 = "GETv2";
82const char *kOperationRemoveObjectForKey = "RemoveObjectForKey";
83
d8f41ccd 84const char *kOperationRegisterKeys = "RegisterKeys";
5c19dc3a
A
85const char *kOperationGetDeviceID = "DeviceID";
86
87const char *kOperationSendIDSMessage = "IDSMessage";
427c49bc
A
88
89const char *kOperationUILocalNotification = "UILocalNotification";
90
427c49bc 91const char *kOperationRequestSyncWithAllPeers = "requestSyncWithAllPeers";
d8f41ccd 92const char *kOperationRequestEnsurePeerRegistration = "requestEnsurePeerRegistration";
427c49bc 93
427c49bc
A
94
95/*
96 The values for the KVS notification and KVS Store ID must be identical to the values
97 in syncdefaultsd (SYDApplication.m). The notification string is used in two places:
98 it is in our launchd plist (com.apple.security.cloudkeychainproxy.plist) as the
99 LaunchEvents/com.apple.notifyd.matching key and is examined in code in the stream event handler.
100
101 The KVS Store ID (_SYDRemotePreferencesStoreIdentifierKey in SYDApplication.m) must
102 be in the entitlements. The bundle identifier is (com.apple.security.cloudkeychainproxy3)
103 is used by installInfoForBundleIdentifiers in SYDApplication.m and is used to look up our
104 daemon to figure out what store to use, etc.
105*/
106
107const char * const kCloudKeychainStorechangeChangeNotification = "com.apple.security.cloudkeychainproxy.kvstorechange3"; // was "com.apple.security.cloudkeychain.kvstorechange" for seeds
108
109const char *kNotifyTokenForceUpdate = "com.apple.security.cloudkeychain.forceupdate";