1 /* 2 * Copyright (c) 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 HUKS_CIPHER_AES_TEST_COMMON_H 17 #define HUKS_CIPHER_AES_TEST_COMMON_H 18 19 #include <string> 20 21 #include "huks_three_stage_test_common.h" 22 23 namespace Unittest::AesCipher 24 { 25 static const uint32_t AES_COMMON_SIZE = 1024; 26 static const uint32_t IV_SIZE = 16; 27 static const uint32_t AAD_SIZE = 16; 28 static const uint32_t NONCE_SIZE = 12; 29 static const uint32_t AEAD_SIZE = 16; 30 31 static uint8_t IV[IV_SIZE] = {0}; 32 static uint8_t AAD[AAD_SIZE] = {0}; 33 static uint8_t NONCE[NONCE_SIZE] = {0}; 34 static uint8_t AEAD[AEAD_SIZE] = {0}; 35 36 static const std::string g_inData = 37 "Hks_AES_Cipher_Test_000000000000000000000000000000000000000000000000000000000000" 38 "00000000000000000000000000000000000000000000000000000000000000000000000000000000" 39 "0000000000000000000000000000000000000000000000000000000000000000000000000_string"; 40 41 OH_Huks_Result HksAesCipherTestEncrypt(const struct OH_Huks_Blob *keyAlias, 42 const struct OH_Huks_ParamSet *encryptParamSet, 43 const struct OH_Huks_Blob *inData, struct OH_Huks_Blob *cipherText); 44 45 OH_Huks_Result HksAesCipherTestDecrypt(const struct OH_Huks_Blob *keyAlias, 46 const struct OH_Huks_ParamSet *decryptParamSet, 47 const struct OH_Huks_Blob *cipherText, struct OH_Huks_Blob *plainText, 48 const struct OH_Huks_Blob *inData); 49 50 OH_Huks_Result HksAesCipherTestCaseOther(const struct OH_Huks_Blob *keyAlias, struct OH_Huks_ParamSet *genParamSet, 51 struct OH_Huks_ParamSet *encryptParamSet, 52 struct OH_Huks_ParamSet *decryptParamSet); 53 54 OH_Huks_Result HksAesCipherTestCaseGcm2(const struct OH_Huks_Blob *keyAlias, struct OH_Huks_ParamSet *genParamSet, 55 struct OH_Huks_ParamSet *encryptParamSet, 56 struct OH_Huks_ParamSet *decryptParamSet, 57 struct OH_Huks_ParamSet *decrypt1ParamSet); 58 } // namespace Unittest::AesCipher 59 #endif // HUKS_CIPHER_AES_TEST_COMMON_H 60