1060ff233Sopenharmony_ci/*
2060ff233Sopenharmony_ci * Copyright (c) 2023 Huawei Device Co., Ltd.
3060ff233Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4060ff233Sopenharmony_ci * you may not use this file except in compliance with the License.
5060ff233Sopenharmony_ci * You may obtain a copy of the License at
6060ff233Sopenharmony_ci *
7060ff233Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8060ff233Sopenharmony_ci *
9060ff233Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10060ff233Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11060ff233Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12060ff233Sopenharmony_ci * See the License for the specific language governing permissions and
13060ff233Sopenharmony_ci * limitations under the License.
14060ff233Sopenharmony_ci */
15060ff233Sopenharmony_ci
16060ff233Sopenharmony_ci#ifndef SOFTBUS_AES_ENCRYPT_H
17060ff233Sopenharmony_ci#define SOFTBUS_AES_ENCRYPT_H
18060ff233Sopenharmony_ci
19060ff233Sopenharmony_ci#include <stdint.h>
20060ff233Sopenharmony_ci
21060ff233Sopenharmony_ci#ifdef __cplusplus
22060ff233Sopenharmony_ciextern "C" {
23060ff233Sopenharmony_ci#endif
24060ff233Sopenharmony_ci
25060ff233Sopenharmony_ci#define ENCRYPT_MODE           1
26060ff233Sopenharmony_ci#define DECRYPT_MODE           0
27060ff233Sopenharmony_ci#define SHA256_MAC_LEN         32
28060ff233Sopenharmony_ci#define AES_SESSION_KEY_LENGTH 16
29060ff233Sopenharmony_ci#define AES_IV_LENGTH          16
30060ff233Sopenharmony_ci#define AES_GCM_TAG_LEN        16
31060ff233Sopenharmony_ci#define RANDOM_LENGTH          8
32060ff233Sopenharmony_ci
33060ff233Sopenharmony_citypedef struct {
34060ff233Sopenharmony_ci    uint8_t *key;
35060ff233Sopenharmony_ci    uint32_t keyLen;
36060ff233Sopenharmony_ci    uint8_t *iv;
37060ff233Sopenharmony_ci    uint32_t ivLen;
38060ff233Sopenharmony_ci} AesCipherKey;
39060ff233Sopenharmony_ci
40060ff233Sopenharmony_citypedef struct {
41060ff233Sopenharmony_ci    const uint8_t *key;
42060ff233Sopenharmony_ci    uint32_t len;
43060ff233Sopenharmony_ci} EncryptKey;
44060ff233Sopenharmony_ci
45060ff233Sopenharmony_citypedef struct {
46060ff233Sopenharmony_ci    const uint8_t *data;
47060ff233Sopenharmony_ci    uint32_t len;
48060ff233Sopenharmony_ci} AesInputData;
49060ff233Sopenharmony_ci
50060ff233Sopenharmony_citypedef struct {
51060ff233Sopenharmony_ci    uint8_t *data;
52060ff233Sopenharmony_ci    uint32_t len;
53060ff233Sopenharmony_ci} AesOutputData;
54060ff233Sopenharmony_ci
55060ff233Sopenharmony_ciint32_t SoftBusGenerateHmacHash(
56060ff233Sopenharmony_ci    const EncryptKey *randomKey, const uint8_t *rootKey, uint32_t rootKeyLen, uint8_t *hash, uint32_t hashLen);
57060ff233Sopenharmony_ci
58060ff233Sopenharmony_ci// Aes-cfb encrypt and decrypt by randomKey and rootKey
59060ff233Sopenharmony_ciint32_t SoftBusAesCfbRootEncrypt(const AesInputData *inData, const EncryptKey *randomKey, EncryptKey *rootKey,
60060ff233Sopenharmony_ci    int32_t encMode, AesOutputData *outData);
61060ff233Sopenharmony_ci
62060ff233Sopenharmony_ciint32_t SoftBusAesCfbEncrypt(
63060ff233Sopenharmony_ci    const AesInputData *inData, AesCipherKey *cipherKey, int32_t encMode, AesOutputData *outData);
64060ff233Sopenharmony_ci
65060ff233Sopenharmony_ciint32_t SoftBusAesGcmEncrypt(
66060ff233Sopenharmony_ci    const AesInputData *inData, AesCipherKey *cipherKey, int32_t encMode, AesOutputData *outData);
67060ff233Sopenharmony_ci
68060ff233Sopenharmony_ci#ifdef __cplusplus
69060ff233Sopenharmony_ci}
70060ff233Sopenharmony_ci#endif
71060ff233Sopenharmony_ci#endif /* SOFTBUS_AES_ENCRYPT_H */
72