1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
/* -*- Mode: C; tab-width: 8 -*-*/
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef _CMMFT_H_
#define _CMMFT_H_
#include "secasn1.h"
/*
* These are the enumerations used to distinguish between the different
* choices available for the CMMFCertOrEncCert structure.
*/
typedef enum {
cmmfNoCertOrEncCert = 0,
cmmfCertificate = 1,
cmmfEncryptedCert = 2
} CMMFCertOrEncCertChoice;
/*
* This is the enumeration and the corresponding values used to
* represent the CMMF type PKIStatus
*/
typedef enum {
cmmfNoPKIStatus = -1,
cmmfGranted = 0,
cmmfGrantedWithMods = 1,
cmmfRejection = 2,
cmmfWaiting = 3,
cmmfRevocationWarning = 4,
cmmfRevocationNotification = 5,
cmmfKeyUpdateWarning = 6,
cmmfNumPKIStatus
} CMMFPKIStatus;
/*
* These enumerations are used to represent the corresponding values
* in PKIFailureInfo defined in CMMF.
*/
typedef enum {
cmmfBadAlg = 0,
cmmfBadMessageCheck = 1,
cmmfBadRequest = 2,
cmmfBadTime = 3,
cmmfBadCertId = 4,
cmmfBadDataFormat = 5,
cmmfWrongAuthority = 6,
cmmfIncorrectData = 7,
cmmfMissingTimeStamp = 8,
cmmfNoFailureInfo = 9
} CMMFPKIFailureInfo;
typedef struct CMMFPKIStatusInfoStr CMMFPKIStatusInfo;
typedef struct CMMFCertOrEncCertStr CMMFCertOrEncCert;
typedef struct CMMFCertifiedKeyPairStr CMMFCertifiedKeyPair;
typedef struct CMMFCertResponseStr CMMFCertResponse;
typedef struct CMMFCertResponseSeqStr CMMFCertResponseSeq;
typedef struct CMMFPOPODecKeyChallContentStr CMMFPOPODecKeyChallContent;
typedef struct CMMFChallengeStr CMMFChallenge;
typedef struct CMMFRandStr CMMFRand;
typedef struct CMMFPOPODecKeyRespContentStr CMMFPOPODecKeyRespContent;
typedef struct CMMFKeyRecRepContentStr CMMFKeyRecRepContent;
typedef struct CMMFCertRepContentStr CMMFCertRepContent;
/* Export this so people can call SEC_ASN1EncodeItem instead of having to
* write callbacks that are passed in to the high level encode function
* for CMMFCertRepContent.
*/
extern const SEC_ASN1Template CMMFCertRepContentTemplate[];
extern const SEC_ASN1Template CMMFPOPODecKeyChallContentTemplate[];
#endif /*_CMMFT_H_*/
|