lin
2025-03-11 6f4f7a76e03a46fefb056a4b18197f1d9e8aa939
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/*
**
** Copyright 2017, The Android Open Source Project
**
** Licensed under the Apache License, Version 2.0 (the "License");
** you may not use this file except in compliance with the License.
** You may obtain a copy of the License at
**
**     http://www.apache.org/licenses/LICENSE-2.0
**
** Unless required by applicable law or agreed to in writing, software
** distributed under the License is distributed on an "AS IS" BASIS,
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
** See the License for the specific language governing permissions and
** limitations under the License.
*/
 
#include <keymaster/legacy_support/keymaster_passthrough_key.h>
 
namespace keymaster {
 
keymaster_error_t
KeymasterPassthroughKeyFactory::LoadKey(KeymasterKeyBlob&& key_material,
                          const AuthorizationSet& additional_params,
                          AuthorizationSet&& hw_enforced,
                          AuthorizationSet&& sw_enforced,
                          UniquePtr<Key>* key) const {
    keymaster_error_t error = KM_ERROR_OK;
    if (!key)
        return KM_ERROR_OUTPUT_PARAMETER_NULL;
 
    key->reset(new (std::nothrow) KeymasterPassthroughKey(move(key_material), move(hw_enforced),
                                                          move(sw_enforced), this, &error,
                                                          additional_params, engine_));
    if (!key->get())
        error = KM_ERROR_MEMORY_ALLOCATION_FAILED;
 
    return error;
}
 
const keymaster_key_format_t*
KeymasterPassthroughKeyFactory::SupportedImportFormats(size_t* format_count) const {
    if (format_count) *format_count = 0;
    return nullptr;
}
const keymaster_key_format_t*
KeymasterPassthroughKeyFactory::SupportedExportFormats(size_t* format_count) const {
    if (format_count) *format_count = 0;
    return nullptr;
}
 
 
keymaster_error_t
KeymasterPassthroughKey::formatted_key_material(keymaster_key_format_t format,
                                                UniquePtr<uint8_t[]>* material,
                                                size_t* size) const {
    if (!material || !size) {
        return KM_ERROR_OUTPUT_PARAMETER_NULL;
    }
    keymaster_blob_t km_app_data = {};
    KeymasterBlob app_data;
    if (additional_parameters_.GetTagValue(TAG_APPLICATION_DATA, &km_app_data)) {
        app_data = KeymasterBlob(km_app_data);
    }
 
    keymaster_blob_t km_client_id = {};
    KeymasterBlob client_id;
    if (additional_parameters_.GetTagValue(TAG_APPLICATION_ID, &km_client_id)) {
        client_id = KeymasterBlob(km_client_id);
    }
 
    KeymasterBlob export_data;
 
    keymaster_error_t error = engine_->ExportKey(format, key_material(), client_id, app_data,
                                                 &export_data);
    if (error == KM_ERROR_OK) {
        keymaster_blob_t export_blob = export_data.release();
        material->reset(const_cast<uint8_t*>(export_blob.data));
        *size = export_blob.data_length;
    }
    return error;
}
 
}  // namespace keymaster