• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 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 CJX509CERTIFICATE_H
17 #define CJX509CERTIFICATE_H
18 
19 #include "cf_api.h"
20 #include "x509_certificate.h"
21 
22 #include "cj_cert_common.h"
23 #include "cj_declare_macro.h"
24 
25 #define FFI_DECLARE_HcfX509Certificate(FUNC, RETURN_TYPE, ...) \
26     FFI_DECLARE_API(CjX509Certificate, FUNC, RETURN_TYPE, ##__VA_ARGS__)
27 
28 extern "C" {
29 typedef struct CjX509Certificate CjX509Certificate;
30 
31 struct CjX509Certificate {
32     HcfX509Certificate *cert;
33     CfObject *cfObj;
34 };
35 
36 FFI_DECLARE_INSTANCE(CjX509Certificate, const CfEncodingBlob *blob);
37 CfResult FfiCertCjX509CertificateFromHcfCert(HcfX509Certificate *hcfCert, CjX509Certificate *returnObj);
38 FFI_DECLARE_HcfX509Certificate(Verify, CfResult, HcfPubKey *pubKey);
39 FFI_DECLARE_HcfX509Certificate(GetEncoded, CfResult, CfEncodingBlob *encodedByte);
40 FFI_DECLARE_HcfX509Certificate(GetPublicKey, CfResult, HcfPubKey **retPubKey);
41 FFI_DECLARE_HcfX509Certificate(CheckValidityWithDate, CfResult, const char *date);
42 FFI_DECLARE_HcfX509Certificate(GetVersion, long);
43 FFI_DECLARE_HcfX509Certificate(GetSerialNumber, CfResult, CfBlob *out);
44 FFI_DECLARE_HcfX509Certificate(GetIssuerName, CfResult, CfBlob *out);
45 FFI_DECLARE_HcfX509Certificate(GetSubjectName, CfResult, CfBlob *out);
46 FFI_DECLARE_HcfX509Certificate(GetNotBeforeTime, CfResult, CfBlob *outDate);
47 FFI_DECLARE_HcfX509Certificate(GetNotAfterTime, CfResult, CfBlob *outDate);
48 FFI_DECLARE_HcfX509Certificate(GetSignature, CfResult, CfBlob *sigOut);
49 FFI_DECLARE_HcfX509Certificate(GetSignatureAlgName, CfResult, CfBlob *outName);
50 FFI_DECLARE_HcfX509Certificate(GetSignatureAlgOid, CfResult, CfBlob *out);
51 FFI_DECLARE_HcfX509Certificate(GetSignatureAlgParams, CfResult, CfBlob *sigAlgParamsOut);
52 FFI_DECLARE_HcfX509Certificate(GetKeyUsage, CfResult, CfBlob *boolArr);
53 FFI_DECLARE_HcfX509Certificate(GetExtKeyUsage, CfResult, CfArray *keyUsageOut);
54 FFI_DECLARE_HcfX509Certificate(GetBasicConstraints, int32_t);
55 FFI_DECLARE_HcfX509Certificate(GetSubjectAltNames, CfResult, CfArray *outName);
56 FFI_DECLARE_HcfX509Certificate(GetIssuerAltNames, CfResult, CfArray *outName);
57 FFI_DECLARE_HcfX509Certificate(Match, CfResult, const CjX509CertMatchParams *matchParams, bool *out);
58 FFI_DECLARE_HcfX509Certificate(GetCRLDistributionPointsURI, CfResult, CfArray *outURI);
59 FFI_DECLARE_HcfX509Certificate(ToString, CfResult, CfBlob *out);
60 FFI_DECLARE_HcfX509Certificate(HashCode, CfResult, CfBlob *out);
61 FFI_DECLARE_HcfX509Certificate(GetExtensionsObject, CfResult, CfBlob *out);
62 FFI_DECLARE_HcfX509Certificate(GetSubjectNameEx, CfResult, const CfEncodinigType encodingType, CfBlob *out);
63 FFI_DECLARE_HcfX509Certificate(GetItem, CfResult, const int32_t itemType, CfBlob *out);
64 }
65 
66 #endif //CJX509CERTIFICATE_H
67