xref: /aosp_15_r20/system/security/keystore2/aaid/aaid.cpp (revision e1997b9af69e3155ead6e072d106a0077849ffba)
1*e1997b9aSAndroid Build Coastguard Worker /*
2*e1997b9aSAndroid Build Coastguard Worker  * Copyright (C) 2020 The Android Open Source Project
3*e1997b9aSAndroid Build Coastguard Worker  *
4*e1997b9aSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*e1997b9aSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*e1997b9aSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*e1997b9aSAndroid Build Coastguard Worker  *
8*e1997b9aSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*e1997b9aSAndroid Build Coastguard Worker  *
10*e1997b9aSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*e1997b9aSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*e1997b9aSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*e1997b9aSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*e1997b9aSAndroid Build Coastguard Worker  * limitations under the License.
15*e1997b9aSAndroid Build Coastguard Worker  */
16*e1997b9aSAndroid Build Coastguard Worker 
17*e1997b9aSAndroid Build Coastguard Worker #include "aaid.hpp"
18*e1997b9aSAndroid Build Coastguard Worker 
19*e1997b9aSAndroid Build Coastguard Worker #include <keystore/keystore_attestation_id.h>
20*e1997b9aSAndroid Build Coastguard Worker 
21*e1997b9aSAndroid Build Coastguard Worker using android::security::gather_attestation_application_id;
22*e1997b9aSAndroid Build Coastguard Worker 
aaid_keystore_attestation_id(uint32_t uid,uint8_t * aaid,size_t * aaid_size)23*e1997b9aSAndroid Build Coastguard Worker uint32_t aaid_keystore_attestation_id(uint32_t uid, uint8_t* aaid, size_t* aaid_size) {
24*e1997b9aSAndroid Build Coastguard Worker     static_assert(sizeof(uint32_t) == sizeof(uid_t), "uid_t has unexpected size");
25*e1997b9aSAndroid Build Coastguard Worker     static_assert(sizeof(uint32_t) == sizeof(android::status_t), "status_t has unexpected size");
26*e1997b9aSAndroid Build Coastguard Worker     static_assert(KEY_ATTESTATION_APPLICATION_ID_MAX_SIZE ==
27*e1997b9aSAndroid Build Coastguard Worker                       android::security::KEY_ATTESTATION_APPLICATION_ID_MAX_SIZE,
28*e1997b9aSAndroid Build Coastguard Worker                   "KEY_ATTESTATION_APPLICATION_ID_MAX_SIZE sizes don't match.");
29*e1997b9aSAndroid Build Coastguard Worker     auto result = gather_attestation_application_id(uid);
30*e1997b9aSAndroid Build Coastguard Worker     if (!result.isOk()) {
31*e1997b9aSAndroid Build Coastguard Worker         return result.status();
32*e1997b9aSAndroid Build Coastguard Worker     }
33*e1997b9aSAndroid Build Coastguard Worker     if (result.value().size() > KEY_ATTESTATION_APPLICATION_ID_MAX_SIZE) {
34*e1997b9aSAndroid Build Coastguard Worker         return ::android::NO_MEMORY;
35*e1997b9aSAndroid Build Coastguard Worker     }
36*e1997b9aSAndroid Build Coastguard Worker     if (*aaid_size != KEY_ATTESTATION_APPLICATION_ID_MAX_SIZE) {
37*e1997b9aSAndroid Build Coastguard Worker         return ::android::BAD_VALUE;
38*e1997b9aSAndroid Build Coastguard Worker     }
39*e1997b9aSAndroid Build Coastguard Worker     std::copy(result.value().begin(), result.value().end(), aaid);
40*e1997b9aSAndroid Build Coastguard Worker     *aaid_size = result.value().size();
41*e1997b9aSAndroid Build Coastguard Worker     return ::android::OK;
42*e1997b9aSAndroid Build Coastguard Worker }
43