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