# Copyright (c) 2021-2025 Huawei Device Co., Ltd. # 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. import("//build/ohos.gni") import("../../access_token.gni") config("accesstoken_common_cxx_public_config") { visibility = [ ":*" ] include_dirs = [ "include" ] } action("permission_definition_check") { script = "permission_check.py" args = [ "--source-root-dir", rebase_path("//", root_build_dir), "--input-full-permissions", rebase_path("${access_token_path}") + "/services/accesstokenmanager/permission_definitions.json", ] inputs = [ rebase_path("${access_token_path}") + "/services/accesstokenmanager/permission_definitions.json" ] outputs = [ "$target_out_dir/permission_definition_check.stamp" ] } action("permission_definition_parse") { script = "permission_definition_parser.py" inputs = [ rebase_path("${access_token_path}") + "/services/accesstokenmanager/permission_definitions.json" ] args = [ "--input-json", rebase_path("${access_token_path}") + "/services/accesstokenmanager/permission_definitions.json", "--output-path", rebase_path(target_out_dir) + "/permission_map_constant.h", "--target-platform", target_platform, ] outputs = [ "$target_out_dir" + "/permission_map_constant.h" ] if (!ohos_indep_compiler_enable) { deps = [ ":permission_definition_check" ] } } ohos_static_library("accesstoken_hisysevent") { subsystem_name = "security" part_name = "access_token" sanitize = { cfi = true cfi_cross_dso = true debug = false } branch_protector_ret = "pac_ret" public_configs = [ ":accesstoken_common_cxx_public_config" ] include_dirs = [ "${access_token_path}/interfaces/innerkits/accesstoken/include" ] sources = [ "src/hisysevent_adapter.cpp" ] external_deps = [ "hilog:libhilog", "hisysevent:libhisysevent", ] configs = [ "${access_token_path}/config:access_token_compile_flags", "${access_token_path}/config:coverage_flags", ] cflags_cc = [ "-DHILOG_ENABLE" ] } ohos_static_library("accesstoken_static_log") { subsystem_name = "security" part_name = "access_token" sanitize = { cfi = true cfi_cross_dso = true debug = false } branch_protector_ret = "pac_ret" public_configs = [ ":accesstoken_common_cxx_public_config" ] include_dirs = [ "include" ] sources = [ "src/accesstoken_common_log.cpp" ] external_deps = [ "c_utils:utils", "hilog:libhilog", ] configs = [ "${access_token_path}/config:access_token_compile_flags", "${access_token_path}/config:coverage_flags", ] cflags_cc = [ "-DHILOG_ENABLE" ] } ohos_static_library("accesstoken_static_log_for_nativetoken") { subsystem_name = "security" part_name = "access_token" sanitize = { cfi = true cfi_cross_dso = true debug = false } branch_protector_ret = "pac_ret" public_configs = [ ":accesstoken_common_cxx_public_config" ] include_dirs = [ "include", "${access_token_path}/interfaces/innerkits/nativetoken/include", ] cflags_cc = [ "-DUSE_NATIVE_TOKEN_KLOG" ] sources = [ "src/accesstoken_common_log.cpp", "src/accesstoken_klog.cpp", ] external_deps = [ "c_utils:utils" ] configs = [ "${access_token_path}/config:access_token_compile_flags", "${access_token_path}/config:coverage_flags", ] } ohos_shared_library("accesstoken_common_cxx") { subsystem_name = "security" innerapi_tags = [ "platformsdk_indirect", "chipsetsdk_indirect", ] part_name = "access_token" sanitize = { cfi = true cfi_cross_dso = true debug = false } branch_protector_ret = "pac_ret" public_configs = [ ":accesstoken_common_cxx_public_config" ] include_dirs = [ "${access_token_path}/interfaces/innerkits/accesstoken/include", "${access_token_path}/interfaces/innerkits/privacy/include", "include", rebase_path(target_out_dir), ] sources = [ "src/constant_common.cpp", "src/data_validator.cpp", "src/permission_map.cpp", "src/permission_validator.cpp", "src/time_util.cpp", "src/tokenid_attributes.cpp", ] deps = [ ":accesstoken_static_log", ":permission_definition_parse", ] external_deps = [ "c_utils:utils", "hilog:libhilog", "init:libbegetutil", ] configs = [ "${access_token_path}/config:access_token_compile_flags", "${access_token_path}/config:coverage_flags", ] cflags_cc = [ "-DHILOG_ENABLE" ] }