blob: c3f6f3c8719f08b81499faab1f277e1a7da6e002 [file] [log] [blame]
// Copyright 2020, 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.
package {
// See: http://go/android-license-faq
// A large-scale-change added 'default_applicable_licenses' to import
// all of the 'license_kinds' from "system_security_license"
// to get the below license kinds:
// SPDX-license-identifier-Apache-2.0
default_applicable_licenses: ["system_security_license"],
}
rust_library {
name: "libkeystore2_crypto_rust",
crate_name: "keystore2_crypto",
srcs: ["lib.rs"],
rustlibs: [
"libkeystore2_crypto_bindgen",
"liblog_rust",
"libnix",
"libthiserror",
],
shared_libs: [
"libkeystore2_crypto",
"libcrypto",
],
vendor_available: true,
}
cc_library {
name: "libkeystore2_crypto",
srcs: [
"crypto.cpp",
"certificate_utils.cpp",
],
export_include_dirs: ["include"],
shared_libs: [
"libcrypto",
"liblog",
],
vendor_available: true,
}
rust_bindgen {
name: "libkeystore2_crypto_bindgen",
wrapper_src: "crypto.hpp",
crate_name: "keystore2_crypto_bindgen",
source_stem: "bindings",
host_supported: true,
vendor_available: true,
shared_libs: ["libcrypto"],
bindgen_flags: [
"--size_t-is-usize",
"--allowlist-function", "hmacSha256",
"--allowlist-function", "randomBytes",
"--allowlist-function", "AES_gcm_encrypt",
"--allowlist-function", "AES_gcm_decrypt",
"--allowlist-function", "CreateKeyId",
"--allowlist-function", "generateKeyFromPassword",
"--allowlist-function", "HKDFExtract",
"--allowlist-function", "HKDFExpand",
"--allowlist-function", "ECDHComputeKey",
"--allowlist-function", "ECKEYGenerateKey",
"--allowlist-function", "ECKEYMarshalPrivateKey",
"--allowlist-function", "ECKEYParsePrivateKey",
"--allowlist-function", "EC_KEY_get0_public_key",
"--allowlist-function", "ECPOINTPoint2Oct",
"--allowlist-function", "ECPOINTOct2Point",
"--allowlist-function", "EC_KEY_free",
"--allowlist-function", "EC_POINT_free",
"--allowlist-function", "extractSubjectFromCertificate",
"--allowlist-type", "EC_KEY",
"--allowlist-type", "EC_POINT",
"--allowlist-var", "EC_MAX_BYTES",
"--allowlist-var", "EVP_MAX_MD_SIZE",
],
cflags: ["-DBORINGSSL_NO_CXX"],
}
rust_test {
name: "keystore2_crypto_test_rust",
crate_name: "keystore2_crypto_test_rust",
srcs: ["lib.rs"],
test_suites: ["general-tests"],
auto_gen_config: true,
rustlibs: [
"libkeystore2_crypto_bindgen",
"liblog_rust",
"libnix",
"libthiserror",
],
static_libs: [
"libkeystore2_crypto",
],
shared_libs: [
"libc++",
"libcrypto",
"liblog",
],
}
cc_test {
name: "keystore2_crypto_test",
cflags: [
"-Wall",
"-Werror",
"-Wextra",
],
srcs: [
"tests/certificate_utils_test.cpp",
"tests/gtest_main.cpp",
],
test_suites: ["general-tests"],
static_libs: [
"libkeystore2_crypto",
],
shared_libs: [
"libcrypto",
],
}
rust_test {
name: "libkeystore2_crypto_bindgen_test",
srcs: [":libkeystore2_crypto_bindgen"],
crate_name: "keystore2_crypto_bindgen_test",
test_suites: ["general-tests"],
auto_gen_config: true,
clippy_lints: "none",
lints: "none",
}