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