summaryrefslogtreecommitdiffstats
path: root/security/nss/lib/certdb/genname.h
blob: 5824157108b333cb1357ac099bd323db2398795e (plain)
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
/* 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 _GENAME_H_
#define _GENAME_H_

#include "plarena.h"
#include "seccomon.h"
#include "secoidt.h"
#include "secasn1.h"
#include "secder.h"
#include "certt.h"

/************************************************************************/
SEC_BEGIN_PROTOS

extern const SEC_ASN1Template CERT_GeneralNamesTemplate[];

extern SECItem **cert_EncodeGeneralNames(PLArenaPool *arena,
                                         CERTGeneralName *names);

extern CERTGeneralName *cert_DecodeGeneralNames(PLArenaPool *arena,
                                                SECItem **encodedGenName);

extern SECStatus cert_DestroyGeneralNames(CERTGeneralName *name);

extern SECStatus cert_EncodeNameConstraints(CERTNameConstraints *constraints,
                                            PLArenaPool *arena, SECItem *dest);

extern CERTNameConstraints *cert_DecodeNameConstraints(
    PLArenaPool *arena, const SECItem *encodedConstraints);

extern CERTGeneralName *cert_CombineNamesLists(CERTGeneralName *list1,
                                               CERTGeneralName *list2);

extern CERTNameConstraint *cert_CombineConstraintsLists(
    CERTNameConstraint *list1, CERTNameConstraint *list2);

/*********************************************************************/
/* A thread safe implementation of General Names                     */
/*********************************************************************/

/* Destroy a Single CERTGeneralName */
void CERT_DestroyGeneralName(CERTGeneralName *name);

SECStatus CERT_CompareGeneralName(CERTGeneralName *a, CERTGeneralName *b);

SECStatus CERT_CopyGeneralName(PLArenaPool *arena, CERTGeneralName *dest,
                               CERTGeneralName *src);

/* General Name Lists are a thread safe, reference counting layer to
 * general names */

/* Destroys a CERTGeneralNameList */
void CERT_DestroyGeneralNameList(CERTGeneralNameList *list);

/* Creates a CERTGeneralNameList */
CERTGeneralNameList *CERT_CreateGeneralNameList(CERTGeneralName *name);

/* Compares two CERTGeneralNameList */
SECStatus CERT_CompareGeneralNameLists(CERTGeneralNameList *a,
                                       CERTGeneralNameList *b);

/* returns a copy of the first name of the type requested */
void *CERT_GetGeneralNameFromListByType(CERTGeneralNameList *list,
                                        CERTGeneralNameType type,
                                        PLArenaPool *arena);

/* Adds a name to the tail of the list */
void CERT_AddGeneralNameToList(CERTGeneralNameList *list,
                               CERTGeneralNameType type, void *data,
                               SECItem *oid);

/* returns a duplicate of the CERTGeneralNameList */
CERTGeneralNameList *CERT_DupGeneralNameList(CERTGeneralNameList *list);

/* returns the number of CERTGeneralName objects in the  doubly linked
** list of which *names is a member.
*/
extern int CERT_GetNamesLength(CERTGeneralName *names);

/************************************************************************/

SECStatus CERT_CompareNameSpace(CERTCertificate *cert,
                                CERTGeneralName *namesList,
                                CERTCertificate **certsList,
                                PLArenaPool *reqArena,
                                CERTCertificate **pBadCert);

SEC_END_PROTOS

#endif