/* -*- 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_*/