1 /* 2 * Copyright (c) 2023-2024 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 X509_TRUST_ANCHOR_H 17 #define X509_TRUST_ANCHOR_H 18 19 #include <stddef.h> 20 #include <stdint.h> 21 22 #include "cf_blob.h" 23 #include "x509_certificate.h" 24 25 typedef struct HcfX509TrustAnchor HcfX509TrustAnchor; 26 struct HcfX509TrustAnchor { 27 CfBlob *CAPubKey; // CAPubKey : Uint8Array DER format 28 HcfX509Certificate *CACert; // CACert : X509Cert 29 CfBlob *CASubject; // CASubject : Uint8Array DER format 30 CfBlob *nameConstraints; 31 }; 32 33 typedef struct { 34 HcfX509TrustAnchor **data; 35 uint32_t count; 36 } HcfX509TrustAnchorArray; 37 38 typedef struct { 39 bool isPem; // format of prikey : PEM format is true, DER is false 40 CfBlob *pwd; // pwd : string 41 bool isGetPriKey; // isGetPriKey : true is get prikey, false is not get prikey 42 bool isGetCert; // isGetCert : true is get Cert, false is not get Cert 43 bool isGetOtherCerts; // isGetOtherCerts : true is get otherCerts, false is not get otherCerts 44 } HcfParsePKCS12Conf; 45 46 typedef struct { 47 bool isPem; // format of prikey : PEM format is true, DER is false 48 CfBlob *prikey; // prikey : Uint8Array 49 HcfX509Certificate *cert; // cert : X509Cert 50 HcfX509Certificate **otherCerts; // otherCerts : X509Cert[] 51 uint32_t otherCertsCount; // otherCertsCount : count of otherCerts 52 } HcfX509P12Collection; 53 54 #endif // X509_TRUST_ANCHOR_H 55