1 /*
2  * Copyright (C) 2020 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 #pragma once
18 #include <vector>
19 
20 //#include <aidl/android/hardware/security/keymint/HardwareAuthToken.h>
21 
22 // namespace aidl::android::hardware::security::keymint {
23 namespace keymint::javacard {
24 
25 using std::vector;
26 
blob2vector(const uint8_t * data,const size_t length)27 inline static std::vector<uint8_t> blob2vector(const uint8_t* data, const size_t length) {
28     std::vector<uint8_t> result(data, data + length);
29     return result;
30 }
31 
blob2vector(const std::string & value)32 inline static std::vector<uint8_t> blob2vector(const std::string& value) {
33     vector<uint8_t> result(reinterpret_cast<const uint8_t*>(value.data()),
34                            reinterpret_cast<const uint8_t*>(value.data()) + value.size());
35     return result;
36 }
37 
38 // HardwareAuthToken vector2AuthToken(const vector<uint8_t>& buffer);
39 // vector<uint8_t> authToken2vector(const HardwareAuthToken& token);
40 
41 uint32_t getOsVersion();
42 uint32_t getOsPatchlevel();
43 uint32_t getVendorPatchlevel();
44 
45 }  // namespace keymint::javacard
46