1/* 2 * Copyright (c) 2021-2022 Huawei Device Co., Ltd. 3 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * you may not use this file except in compliance with the License. 5 * You may obtain a copy of the License at 6 * 7 * http://www.apache.org/licenses/LICENSE-2.0 8 * 9 * Unless required by applicable law or agreed to in writing, software 10 * distributed under the License is distributed on an "AS IS" BASIS, 11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 * See the License for the specific language governing permissions and 13 * limitations under the License. 14 */ 15 16#ifndef ACCESSTOKEN_LOG_H 17#define ACCESSTOKEN_LOG_H 18 19#ifdef HILOG_ENABLE 20 21#include "hilog/log.h" 22 23/* define LOG_TAG as "security_*" at your submodule, * means your submodule name such as "security_dac" */ 24#undef LOG_TAG 25#undef LOG_DOMAIN 26 27static constexpr unsigned int SECURITY_DOMAIN_ACCESSTOKEN = 0xD005A01; 28static constexpr unsigned int SECURITY_DOMAIN_PRIVACY = 0xD005A02; 29 30#define ACCESSTOKEN_LOG_FATAL(label, fmt, ...) \ 31 ((void)HILOG_IMPL(label.type, LOG_FATAL, label.domain, label.tag, \ 32 "[%{public}s:%{public}d]" fmt, __FUNCTION__, __LINE__, ##__VA_ARGS__)) 33#define ACCESSTOKEN_LOG_ERROR(label, fmt, ...) \ 34 ((void)HILOG_IMPL(label.type, LOG_ERROR, label.domain, label.tag, \ 35 "[%{public}s:%{public}d]" fmt, __FUNCTION__, __LINE__, ##__VA_ARGS__)) 36#define ACCESSTOKEN_LOG_WARN(label, fmt, ...) \ 37 ((void)HILOG_IMPL(label.type, LOG_WARN, label.domain, label.tag, \ 38 "[%{public}s:%{public}d]" fmt, __FUNCTION__, __LINE__, ##__VA_ARGS__)) 39#define ACCESSTOKEN_LOG_INFO(label, fmt, ...) \ 40 ((void)HILOG_IMPL(label.type, LOG_INFO, label.domain, label.tag, \ 41 "[%{public}s:%{public}d]" fmt, __FUNCTION__, __LINE__, ##__VA_ARGS__)) 42#define ACCESSTOKEN_LOG_DEBUG(label, fmt, ...) \ 43 ((void)HILOG_IMPL(label.type, LOG_DEBUG, label.domain, label.tag, \ 44 "[%{public}s:%{public}d]" fmt, __FUNCTION__, __LINE__, ##__VA_ARGS__)) 45 46#define IF_FALSE_PRINT_LOG(label, cond, fmt, ...) \ 47 do { \ 48 if (!(cond)) { \ 49 ACCESSTOKEN_LOG_ERROR(label, fmt, ##__VA_ARGS__); \ 50 } \ 51 } while (0) 52 53#define IF_FALSE_RETURN_LOG(label, cond, fmt, ...) \ 54 do { \ 55 if (!(cond)) { \ 56 ACCESSTOKEN_LOG_ERROR(label, fmt, ##__VA_ARGS__); \ 57 return; \ 58 } \ 59 } while (0) 60#else 61 62#include <stdarg.h> 63#include <stdio.h> 64 65/* define LOG_TAG as "security_*" at your submodule, * means your submodule name such as "security_dac" */ 66#undef LOG_TAG 67 68#define ACCESSTOKEN_LOG_DEBUG(fmt, ...) printf("[%s] debug: %s: " fmt "\n", LOG_TAG, __func__, ##__VA_ARGS__) 69#define ACCESSTOKEN_LOG_INFO(fmt, ...) printf("[%s] info: %s: " fmt "\n", LOG_TAG, __func__, ##__VA_ARGS__) 70#define ACCESSTOKEN_LOG_WARN(fmt, ...) printf("[%s] warn: %s: " fmt "\n", LOG_TAG, __func__, ##__VA_ARGS__) 71#define ACCESSTOKEN_LOG_ERROR(fmt, ...) printf("[%s] error: %s: " fmt "\n", LOG_TAG, __func__, ##__VA_ARGS__) 72#define ACCESSTOKEN_LOG_FATAL(fmt, ...) printf("[%s] fatal: %s: " fmt "\n", LOG_TAG, __func__, ##__VA_ARGS__) 73 74#define IF_FALSE_PRINT_LOG(cond, fmt, ...) \ 75 do { \ 76 if (!(cond)) { \ 77 ACCESSTOKEN_LOG_ERROR(fmt, ##__VA_ARGS__); \ 78 } \ 79 } while (0) 80 81#define IF_FALSE_RETURN_LOG(cond, fmt, ...) \ 82 do { \ 83 if (!(cond)) { \ 84 ACCESSTOKEN_LOG_ERROR(fmt, ##__VA_ARGS__); \ 85 return; \ 86 } \ 87 } while (0) 88#endif // HILOG_ENABLE 89 90#endif // ACCESSTOKEN_LOG_H 91