PageRenderTime 12ms CodeModel.GetById 1ms app.highlight 8ms RepoModel.GetById 1ms app.codeStats 1ms

/security/nss/lib/libpkix/pkix_pl_nss/pki/pkix_pl_cert.h

http://github.com/zpao/v8monkey
C Header | 137 lines | 78 code | 13 blank | 46 comment | 0 complexity | 541d7e9f5b4e9484d5e6546252ef51f2 MD5 | raw file
  1/* ***** BEGIN LICENSE BLOCK *****
  2 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
  3 *
  4 * The contents of this file are subject to the Mozilla Public License Version
  5 * 1.1 (the "License"); you may not use this file except in compliance with
  6 * the License. You may obtain a copy of the License at
  7 * http://www.mozilla.org/MPL/
  8 *
  9 * Software distributed under the License is distributed on an "AS IS" basis,
 10 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
 11 * for the specific language governing rights and limitations under the
 12 * License.
 13 *
 14 * The Original Code is the PKIX-C library.
 15 *
 16 * The Initial Developer of the Original Code is
 17 * Sun Microsystems, Inc.
 18 * Portions created by the Initial Developer are
 19 * Copyright 2004-2007 Sun Microsystems, Inc.  All Rights Reserved.
 20 *
 21 * Contributor(s):
 22 *   Sun Microsystems, Inc.
 23 *
 24 * Alternatively, the contents of this file may be used under the terms of
 25 * either the GNU General Public License Version 2 or later (the "GPL"), or
 26 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
 27 * in which case the provisions of the GPL or the LGPL are applicable instead
 28 * of those above. If you wish to allow use of your version of this file only
 29 * under the terms of either the GPL or the LGPL, and not to allow others to
 30 * use your version of this file under the terms of the MPL, indicate your
 31 * decision by deleting the provisions above and replace them with the notice
 32 * and other provisions required by the GPL or the LGPL. If you do not delete
 33 * the provisions above, a recipient may use your version of this file under
 34 * the terms of any one of the MPL, the GPL or the LGPL.
 35 *
 36 * ***** END LICENSE BLOCK ***** */
 37/*
 38 * pkix_pl_cert.h
 39 *
 40 * Certificate Object Definitions
 41 *
 42 */
 43
 44#ifndef _PKIX_PL_CERT_H
 45#define _PKIX_PL_CERT_H
 46
 47#include "pkix_pl_common.h"
 48
 49#ifdef __cplusplus
 50extern "C" {
 51#endif
 52
 53struct PKIX_PL_CertStruct {
 54        CERTCertificate *nssCert;
 55        CERTGeneralName *nssSubjAltNames;
 56        PLArenaPool *arenaNameConstraints;
 57        PKIX_PL_X500Name *issuer;
 58        PKIX_PL_X500Name *subject;
 59        PKIX_List *subjAltNames;
 60        PKIX_Boolean subjAltNamesAbsent;
 61        PKIX_PL_OID *publicKeyAlgId;
 62        PKIX_PL_PublicKey *publicKey;
 63        PKIX_PL_BigInt *serialNumber;
 64        PKIX_List *critExtOids;
 65        PKIX_PL_ByteArray *subjKeyId;
 66        PKIX_Boolean subjKeyIdAbsent;
 67        PKIX_PL_ByteArray *authKeyId;
 68        PKIX_Boolean authKeyIdAbsent;
 69        PKIX_List *extKeyUsages;
 70        PKIX_Boolean extKeyUsagesAbsent;
 71        PKIX_PL_CertBasicConstraints *certBasicConstraints;
 72        PKIX_Boolean basicConstraintsAbsent;
 73        PKIX_List *certPolicyInfos;
 74        PKIX_Boolean policyInfoAbsent;
 75        PKIX_Boolean policyMappingsAbsent;
 76        PKIX_List *certPolicyMappings; /* List of PKIX_PL_CertPolicyMap */
 77        PKIX_Boolean policyConstraintsProcessed;
 78        PKIX_Int32 policyConstraintsExplicitPolicySkipCerts;
 79        PKIX_Int32 policyConstraintsInhibitMappingSkipCerts;
 80        PKIX_Boolean inhibitAnyPolicyProcessed;
 81        PKIX_Int32 inhibitAnySkipCerts;
 82        PKIX_PL_CertNameConstraints *nameConstraints;
 83        PKIX_Boolean nameConstraintsAbsent;
 84        PKIX_Boolean cacheFlag;
 85        PKIX_CertStore *store;
 86        PKIX_List *authorityInfoAccess; /* list of PKIX_PL_InfoAccess */
 87        PKIX_List *subjectInfoAccess; /* list of PKIX_PL_InfoAccess */
 88        PKIX_Boolean isUserTrustAnchor;
 89        PKIX_List *crldpList; /* list of CRL DPs based on der in nssCert arena.
 90                               * Destruction is needed for pkix object and
 91                               * not for undelying der as it is a part
 92                               * nssCert arena. */ 
 93};
 94
 95/* see source file for function documentation */
 96
 97PKIX_Error *
 98pkix_pl_Cert_RegisterSelf(void *plContext);
 99
100PKIX_Error *
101pkix_pl_Cert_CreateWithNSSCert(
102        CERTCertificate *nssCert,
103        PKIX_PL_Cert **pCert,
104        void *plContext);
105
106PKIX_Error *
107pkix_pl_Cert_CreateToList(
108        SECItem *derCertItem,
109        PKIX_List *certList,
110        void *plContext);
111
112PKIX_Error *
113pkix_pl_Cert_CheckSubjectAltNameConstraints(
114        PKIX_PL_Cert *cert,
115        PKIX_PL_CertNameConstraints *nameConstraints,
116        PKIX_Boolean matchAll,
117        void *plContext);
118
119PKIX_Error *
120pkix_pl_Cert_ToString_Helper(
121        PKIX_PL_Cert *cert,
122        PKIX_Boolean partialString,
123        PKIX_PL_String **pString,
124        void *plContext);
125
126PKIX_Error *
127pkix_pl_Cert_CheckExtendedKeyUsage(
128        PKIX_PL_Cert *cert,
129        PKIX_UInt32 requiredExtendedKeyUsages,
130        PKIX_Boolean *pPass,
131        void *plContext);
132
133#ifdef __cplusplus
134}
135#endif
136
137#endif /* _PKIX_PL_CERT_H */