1 // Copyright 2015 The Chromium OS Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 #ifndef SYSTEM_API_DBUS_CRYPTOHOME_DBUS_CONSTANTS_H_
6 #define SYSTEM_API_DBUS_CRYPTOHOME_DBUS_CONSTANTS_H_
7 
8 namespace cryptohome {
9 const char kCryptohomeInterface[] = "org.chromium.CryptohomeInterface";
10 const char kCryptohomeServicePath[] = "/org/chromium/Cryptohome";
11 const char kCryptohomeServiceName[] = "org.chromium.Cryptohome";
12 // Methods
13 const char kCryptohomeAsyncAddKey[] = "AsyncAddKey";
14 const char kCryptohomeCheckKey[] = "CheckKey";
15 const char kCryptohomeMigrateKey[] = "MigrateKey";
16 const char kCryptohomeRemove[] = "Remove";
17 const char kCryptohomeGetSystemSalt[] = "GetSystemSalt";
18 const char kCryptohomeGetSanitizedUsername[] = "GetSanitizedUsername";
19 const char kCryptohomeIsMounted[] = "IsMounted";
20 const char kCryptohomeMount[] = "Mount";
21 const char kCryptohomeMountGuest[] = "MountGuest";
22 const char kCryptohomeMountPublic[] = "MountPublic";
23 const char kCryptohomeUnmount[] = "Unmount";
24 const char kCryptohomeTpmIsReady[] = "TpmIsReady";
25 const char kCryptohomeTpmIsEnabled[] = "TpmIsEnabled";
26 const char kCryptohomeTpmIsOwned[] = "TpmIsOwned";
27 const char kCryptohomeTpmIsBeingOwned[] = "TpmIsBeingOwned";
28 const char kCryptohomeTpmGetPassword[] = "TpmGetPassword";
29 const char kCryptohomeTpmCanAttemptOwnership[] = "TpmCanAttemptOwnership";
30 const char kCryptohomeTpmClearStoredPassword[] = "TpmClearStoredPassword";
31 const char kCryptohomePkcs11GetTpmTokenInfo[] = "Pkcs11GetTpmTokenInfo";
32 const char kCryptohomePkcs11GetTpmTokenInfoForUser[] =
33     "Pkcs11GetTpmTokenInfoForUser";
34 const char kCryptohomePkcs11IsTpmTokenReady[] = "Pkcs11IsTpmTokenReady";
35 const char kCryptohomePkcs11IsTpmTokenReadyForUser[] =
36     "Pkcs11IsTpmTokenReadyForUser";
37 const char kCryptohomeAsyncCheckKey[] = "AsyncCheckKey";
38 const char kCryptohomeAsyncMigrateKey[] = "AsyncMigrateKey";
39 const char kCryptohomeAsyncMount[] = "AsyncMount";
40 const char kCryptohomeAsyncMountGuest[] = "AsyncMountGuest";
41 const char kCryptohomeAsyncMountPublic[] = "AsyncMountPublic";
42 const char kCryptohomeAsyncRemove[] = "AsyncRemove";
43 const char kCryptohomeGetStatusString[] = "GetStatusString";
44 const char kCryptohomeRemoveTrackedSubdirectories[] =
45     "RemoveTrackedSubdirectories";
46 const char kCryptohomeAsyncRemoveTrackedSubdirectories[] =
47     "AsyncRemoveTrackedSubdirectories";
48 const char kCryptohomeDoAutomaticFreeDiskSpaceControl[] =
49     "DoAutomaticFreeDiskSpaceControl";
50 const char kCryptohomeAsyncDoAutomaticFreeDiskSpaceControl[] =
51     "AsyncDoAutomaticFreeDiskSpaceControl";
52 const char kCryptohomeAsyncDoesUsersExist[] = "AsyncDoesUsersExist";
53 const char kCryptohomeInstallAttributesGet[] = "InstallAttributesGet";
54 const char kCryptohomeInstallAttributesSet[] = "InstallAttributesSet";
55 const char kCryptohomeInstallAttributesCount[] = "InstallAttributesCount";
56 const char kCryptohomeInstallAttributesFinalize[] =
57     "InstallAttributesFinalize";
58 const char kCryptohomeInstallAttributesIsReady[] = "InstallAttributesIsReady";
59 const char kCryptohomeInstallAttributesIsSecure[] =
60     "InstallAttributesIsSecure";
61 const char kCryptohomeInstallAttributesIsInvalid[] =
62     "InstallAttributesIsInvalid";
63 const char kCryptohomeInstallAttributesIsFirstInstall[] =
64     "InstallAttributesIsFirstInstall";
65 const char kCryptohomeStoreEnrollmentState[] =
66     "StoreEnrollmentState";
67 const char kCryptohomeLoadEnrollmentState[] =
68     "LoadEnrollmentState";
69 const char kCryptohomeTpmIsAttestationPrepared[] = "TpmIsAttestationPrepared";
70 const char kCryptohomeTpmIsAttestationEnrolled[] = "TpmIsAttestationEnrolled";
71 const char kCryptohomeAsyncTpmAttestationCreateEnrollRequest[] =
72     "AsyncTpmAttestationCreateEnrollRequest";
73 const char kCryptohomeAsyncTpmAttestationCreateEnrollRequestNew[] =
74     "AsyncTpmAttestationCreateEnrollRequestNew";
75 const char kCryptohomeAsyncTpmAttestationEnroll[] = "AsyncTpmAttestationEnroll";
76 const char kCryptohomeAsyncTpmAttestationEnrollNew[] =
77     "AsyncTpmAttestationEnrollNew";
78 const char kCryptohomeAsyncTpmAttestationCreateCertRequest[] =
79     "AsyncTpmAttestationCreateCertRequest";
80 const char kCryptohomeAsyncTpmAttestationCreateCertRequestByProfile[] =
81     "AsyncTpmAttestationCreateCertRequestByProfile";
82 const char kCryptohomeAsyncTpmAttestationFinishCertRequest[] =
83     "AsyncTpmAttestationFinishCertRequest";
84 const char kCryptohomeTpmAttestationDoesKeyExist[] =
85     "TpmAttestationDoesKeyExist";
86 const char kCryptohomeTpmAttestationGetCertificate[] =
87     "TpmAttestationGetCertificate";
88 const char kCryptohomeTpmAttestationGetPublicKey[] =
89     "TpmAttestationGetPublicKey";
90 const char kCryptohomeTpmAttestationRegisterKey[] = "TpmAttestationRegisterKey";
91 const char kCryptohomeTpmAttestationSignEnterpriseChallenge[] =
92     "TpmAttestationSignEnterpriseChallenge";
93 const char kCryptohomeTpmAttestationSignSimpleChallenge[] =
94     "TpmAttestationSignSimpleChallenge";
95 const char kCryptohomeTpmAttestationGetKeyPayload[] =
96     "TpmAttestationGetKeyPayload";
97 const char kCryptohomeTpmAttestationSetKeyPayload[] =
98     "TpmAttestationSetKeyPayload";
99 const char kCryptohomeTpmAttestationDeleteKeys[] =
100     "TpmAttestationDeleteKeys";
101 const char kCryptohomeGetKeyDataEx[] = "GetKeyDataEx";
102 const char kCryptohomeCheckKeyEx[] = "CheckKeyEx";
103 const char kCryptohomeMountEx[] = "MountEx";
104 const char kCryptohomeAddKeyEx[] = "AddKeyEx";
105 const char kCryptohomeUpdateKeyEx[] = "UpdateKeyEx";
106 const char kCryptohomeRemoveKeyEx[] = "RemoveKeyEx";
107 const char kCryptohomeSignBootLockbox[] = "SignBootLockbox";
108 const char kCryptohomeVerifyBootLockbox[] = "VerifyBootLockbox";
109 const char kCryptohomeFinalizeBootLockbox[] = "FinalizeBootLockbox";
110 const char kCryptohomeGetBootAttribute[] = "GetBootAttribute";
111 const char kCryptohomeSetBootAttribute[] = "SetBootAttribute";
112 const char kCryptohomeFlushAndSignBootAttributes[] =
113     "FlushAndSignBootAttributes";
114 const char kCryptohomeGetLoginStatus[] = "GetLoginStatus";
115 const char kCryptohomeGetTpmStatus[] = "GetTpmStatus";
116 const char kCryptohomeGetEndorsementInfo[] = "GetEndorsementInfo";
117 const char kCryptohomeRenameCryptohome[] = "RenameCryptohome";
118 const char kCryptohomeGetAccountDiskUsage[] = "GetAccountDiskUsage";
119 const char kCryptohomeGetFirmwareManagementParameters[] =
120     "GetFirmwareManagementParameters";
121 const char kCryptohomeSetFirmwareManagementParameters[] =
122     "SetFirmwareManagementParameters";
123 const char kCryptohomeRemoveFirmwareManagementParameters[] =
124     "RemoveFirmwareManagementParameters";
125 const char kCryptohomeMigrateToDircrypto[] = "MigrateToDircrypto";
126 
127 // Signals
128 const char kSignalAsyncCallStatus[] = "AsyncCallStatus";
129 const char kSignalAsyncCallStatusWithData[] = "AsyncCallStatusWithData";
130 const char kSignalTpmInitStatus[] = "TpmInitStatus";
131 const char kSignalCleanupUsersRemoved[] = "CleanupUsersRemoved";
132 const char kSignalLowDiskSpace[] = "LowDiskSpace";
133 const char kSignalDircryptoMigrationProgress[] = "DircryptoMigrationProgress";
134 // Error code
135 enum MountError {
136   MOUNT_ERROR_NONE = 0,
137   MOUNT_ERROR_FATAL = 1 << 0,
138   MOUNT_ERROR_KEY_FAILURE = 1 << 1,
139   MOUNT_ERROR_MOUNT_POINT_BUSY = 1 << 2,
140   MOUNT_ERROR_TPM_COMM_ERROR = 1 << 3,
141   MOUNT_ERROR_TPM_DEFEND_LOCK = 1 << 4,
142   MOUNT_ERROR_USER_DOES_NOT_EXIST = 1 << 5,
143   MOUNT_ERROR_TPM_NEEDS_REBOOT = 1 << 6,
144   // Encrypted in old method, need migration before mounting.
145   MOUNT_ERROR_OLD_ENCRYPTION = 1 << 7,
146   // Previous migration attempt was aborted in the middle. Must resume it first.
147   MOUNT_ERROR_PREVIOUS_MIGRATION_INCOMPLETE = 1 << 8,
148   MOUNT_ERROR_RECREATED = 1 << 31,
149 };
150 // Status code signaled from MigrateToDircrypto().
151 enum DircryptoMigrationStatus {
152   // 0 means a successful completeion.
153   DYRCRYPTO_MIGRATION_SUCCESS = 0,
154   // Negative values mean failing completion.
155   // TODO(kinaba,dspaid): Add error codes as needed here.
156   // Positive values mean intermediate state report for the running migration.
157   // TODO(kinaba,dspaid): Add state codes as needed.
158 };
159 }  // namespace cryptohome
160 
161 #endif  // SYSTEM_API_DBUS_CRYPTOHOME_DBUS_CONSTANTS_H_
162