blob: 6ff31aec36ab22887b1b28e4b7bf35df7f1ab6e0 [file] [log] [blame]
David Zeuthenab3e5652019-10-28 13:32:48 -04001/*
2 * Copyright (c) 2019, The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef SYSTEM_SECURITY_WRITABLE_CREDENTIAL_H_
18#define SYSTEM_SECURITY_WRITABLE_CREDENTIAL_H_
19
20#include <string>
21#include <vector>
22
23#include <android/security/identity/BnWritableCredential.h>
24
David Zeuthena6f9fba2020-02-11 22:08:27 -050025#include <android/hardware/identity/IIdentityCredentialStore.h>
David Zeuthenab3e5652019-10-28 13:32:48 -040026
27namespace android {
28namespace security {
29namespace identity {
30
31using ::android::binder::Status;
David Zeuthen472e6c82020-10-16 11:50:13 -040032using ::android::hardware::identity::HardwareInformation;
David Zeuthena6f9fba2020-02-11 22:08:27 -050033using ::android::hardware::identity::IWritableIdentityCredential;
David Zeuthenab3e5652019-10-28 13:32:48 -040034using ::std::string;
35using ::std::vector;
36
37class WritableCredential : public BnWritableCredential {
38 public:
39 WritableCredential(const string& dataPath, const string& credentialName, const string& docType,
David Zeuthen472e6c82020-10-16 11:50:13 -040040 bool isUpdate, HardwareInformation hwInfo,
41 sp<IWritableIdentityCredential> halBinder, int halApiVersion);
David Zeuthenab3e5652019-10-28 13:32:48 -040042 ~WritableCredential();
43
David Zeuthen472e6c82020-10-16 11:50:13 -040044 // Used when updating a credential
45 void setAttestationCertificate(const vector<uint8_t>& attestationCertificate);
46 void setAvailableAuthenticationKeys(int keyCount, int maxUsesPerKey);
47 void setCredentialUpdatedCallback(std::function<void()>&& onCredentialUpdatedCallback);
48
David Zeuthenab3e5652019-10-28 13:32:48 -040049 // IWritableCredential overrides
50 Status getCredentialKeyCertificateChain(const vector<uint8_t>& challenge,
51 vector<uint8_t>* _aidl_return) override;
52
53 Status personalize(const vector<AccessControlProfileParcel>& accessControlProfiles,
54 const vector<EntryNamespaceParcel>& entryNamespaces, int64_t secureUserId,
55 vector<uint8_t>* _aidl_return) override;
56
57 private:
58 string dataPath_;
59 string credentialName_;
David Zeuthene2a78a42020-04-27 13:34:38 -040060 string docType_;
David Zeuthen472e6c82020-10-16 11:50:13 -040061 bool isUpdate_;
62 HardwareInformation hwInfo_;
David Zeuthenab3e5652019-10-28 13:32:48 -040063 sp<IWritableIdentityCredential> halBinder_;
David Zeuthen472e6c82020-10-16 11:50:13 -040064 int halApiVersion_;
65
David Zeuthenab3e5652019-10-28 13:32:48 -040066 vector<uint8_t> attestationCertificate_;
David Zeuthen472e6c82020-10-16 11:50:13 -040067 int keyCount_ = 0;
68 int maxUsesPerKey_ = 1;
69
70 std::function<void()> onCredentialUpdatedCallback_ = []() {};
David Zeuthenab3e5652019-10-28 13:32:48 -040071
David Zeuthene2a78a42020-04-27 13:34:38 -040072 ssize_t calcExpectedProofOfProvisioningSize(
73 const vector<AccessControlProfileParcel>& accessControlProfiles,
74 const vector<EntryNamespaceParcel>& entryNamespaces);
75
David Zeuthenab3e5652019-10-28 13:32:48 -040076 Status ensureAttestationCertificateExists(const vector<uint8_t>& challenge);
77};
78
79} // namespace identity
80} // namespace security
81} // namespace android
82
83#endif // SYSTEM_SECURITY_WRITABLE_CREDENTIAL_H_