xref: /netbsd-src/crypto/external/bsd/openssl.old/dist/doc/man3/OBJ_nid2obj.pod (revision 4724848cf0da353df257f730694b7882798e5daf)
1*4724848cSchristos=pod
2*4724848cSchristos
3*4724848cSchristos=head1 NAME
4*4724848cSchristos
5*4724848cSchristosi2t_ASN1_OBJECT,
6*4724848cSchristosOBJ_length, OBJ_get0_data, OBJ_nid2obj, OBJ_nid2ln,
7*4724848cSchristosOBJ_nid2sn, OBJ_obj2nid, OBJ_txt2nid, OBJ_ln2nid, OBJ_sn2nid, OBJ_cmp,
8*4724848cSchristosOBJ_dup, OBJ_txt2obj, OBJ_obj2txt, OBJ_create, OBJ_cleanup
9*4724848cSchristos- ASN1 object utility functions
10*4724848cSchristos
11*4724848cSchristos=head1 SYNOPSIS
12*4724848cSchristos
13*4724848cSchristos #include <openssl/objects.h>
14*4724848cSchristos
15*4724848cSchristos ASN1_OBJECT *OBJ_nid2obj(int n);
16*4724848cSchristos const char *OBJ_nid2ln(int n);
17*4724848cSchristos const char *OBJ_nid2sn(int n);
18*4724848cSchristos
19*4724848cSchristos int OBJ_obj2nid(const ASN1_OBJECT *o);
20*4724848cSchristos int OBJ_ln2nid(const char *ln);
21*4724848cSchristos int OBJ_sn2nid(const char *sn);
22*4724848cSchristos
23*4724848cSchristos int OBJ_txt2nid(const char *s);
24*4724848cSchristos
25*4724848cSchristos ASN1_OBJECT *OBJ_txt2obj(const char *s, int no_name);
26*4724848cSchristos int OBJ_obj2txt(char *buf, int buf_len, const ASN1_OBJECT *a, int no_name);
27*4724848cSchristos
28*4724848cSchristos int i2t_ASN1_OBJECT(char *buf, int buf_len, const ASN1_OBJECT *a);
29*4724848cSchristos
30*4724848cSchristos int OBJ_cmp(const ASN1_OBJECT *a, const ASN1_OBJECT *b);
31*4724848cSchristos ASN1_OBJECT *OBJ_dup(const ASN1_OBJECT *o);
32*4724848cSchristos
33*4724848cSchristos int OBJ_create(const char *oid, const char *sn, const char *ln);
34*4724848cSchristos
35*4724848cSchristos size_t OBJ_length(const ASN1_OBJECT *obj);
36*4724848cSchristos const unsigned char *OBJ_get0_data(const ASN1_OBJECT *obj);
37*4724848cSchristos
38*4724848cSchristosDeprecated:
39*4724848cSchristos
40*4724848cSchristos #if OPENSSL_API_COMPAT < 0x10100000L
41*4724848cSchristos void OBJ_cleanup(void)
42*4724848cSchristos #endif
43*4724848cSchristos
44*4724848cSchristos=head1 DESCRIPTION
45*4724848cSchristos
46*4724848cSchristosThe ASN1 object utility functions process ASN1_OBJECT structures which are
47*4724848cSchristosa representation of the ASN1 OBJECT IDENTIFIER (OID) type.
48*4724848cSchristosFor convenience, OIDs are usually represented in source code as numeric
49*4724848cSchristosidentifiers, or I<NID>s.  OpenSSL has an internal table of OIDs that
50*4724848cSchristosare generated when the library is built, and their corresponding NIDs
51*4724848cSchristosare available as defined constants.  For the functions below, application
52*4724848cSchristoscode should treat all returned values -- OIDs, NIDs, or names -- as
53*4724848cSchristosconstants.
54*4724848cSchristos
55*4724848cSchristosOBJ_nid2obj(), OBJ_nid2ln() and OBJ_nid2sn() convert the NID I<n> to
56*4724848cSchristosan ASN1_OBJECT structure, its long name and its short name respectively,
57*4724848cSchristosor B<NULL> if an error occurred.
58*4724848cSchristos
59*4724848cSchristosOBJ_obj2nid(), OBJ_ln2nid(), OBJ_sn2nid() return the corresponding NID
60*4724848cSchristosfor the object I<o>, the long name <ln> or the short name <sn> respectively
61*4724848cSchristosor NID_undef if an error occurred.
62*4724848cSchristos
63*4724848cSchristosOBJ_txt2nid() returns NID corresponding to text string I<s>. I<s> can be
64*4724848cSchristosa long name, a short name or the numerical representation of an object.
65*4724848cSchristos
66*4724848cSchristosOBJ_txt2obj() converts the text string I<s> into an ASN1_OBJECT structure.
67*4724848cSchristosIf I<no_name> is 0 then long names and short names will be interpreted
68*4724848cSchristosas well as numerical forms. If I<no_name> is 1 only the numerical form
69*4724848cSchristosis acceptable.
70*4724848cSchristos
71*4724848cSchristosOBJ_obj2txt() converts the B<ASN1_OBJECT> I<a> into a textual representation.
72*4724848cSchristosUnless I<buf> is NULL,
73*4724848cSchristosthe representation is written as a NUL-terminated string to I<buf>, where
74*4724848cSchristosat most I<buf_len> bytes are written, truncating the result if necessary.
75*4724848cSchristosIn any case it returns the total string length, excluding the NUL character,
76*4724848cSchristosrequired for non-truncated representation, or -1 on error.
77*4724848cSchristosIf I<no_name> is 0 then if the object has a long or short name
78*4724848cSchristosthen that will be used, otherwise the numerical form will be used.
79*4724848cSchristosIf I<no_name> is 1 then the numerical form will always be used.
80*4724848cSchristos
81*4724848cSchristosi2t_ASN1_OBJECT() is the same as OBJ_obj2txt() with the I<no_name> set to zero.
82*4724848cSchristos
83*4724848cSchristosOBJ_cmp() compares I<a> to I<b>. If the two are identical 0 is returned.
84*4724848cSchristos
85*4724848cSchristosOBJ_dup() returns a copy of I<o>.
86*4724848cSchristos
87*4724848cSchristosOBJ_create() adds a new object to the internal table. I<oid> is the
88*4724848cSchristosnumerical form of the object, I<sn> the short name and I<ln> the
89*4724848cSchristoslong name. A new NID is returned for the created object in case of
90*4724848cSchristossuccess and NID_undef in case of failure.
91*4724848cSchristos
92*4724848cSchristosOBJ_length() returns the size of the content octets of I<obj>.
93*4724848cSchristos
94*4724848cSchristosOBJ_get0_data() returns a pointer to the content octets of I<obj>.
95*4724848cSchristosThe returned pointer is an internal pointer which B<must not> be freed.
96*4724848cSchristos
97*4724848cSchristosOBJ_cleanup() releases any resources allocated by creating new objects.
98*4724848cSchristos
99*4724848cSchristos=head1 NOTES
100*4724848cSchristos
101*4724848cSchristosObjects in OpenSSL can have a short name, a long name and a numerical
102*4724848cSchristosidentifier (NID) associated with them. A standard set of objects is
103*4724848cSchristosrepresented in an internal table. The appropriate values are defined
104*4724848cSchristosin the header file B<objects.h>.
105*4724848cSchristos
106*4724848cSchristosFor example the OID for commonName has the following definitions:
107*4724848cSchristos
108*4724848cSchristos #define SN_commonName                   "CN"
109*4724848cSchristos #define LN_commonName                   "commonName"
110*4724848cSchristos #define NID_commonName                  13
111*4724848cSchristos
112*4724848cSchristosNew objects can be added by calling OBJ_create().
113*4724848cSchristos
114*4724848cSchristosTable objects have certain advantages over other objects: for example
115*4724848cSchristostheir NIDs can be used in a C language switch statement. They are
116*4724848cSchristosalso static constant structures which are shared: that is there
117*4724848cSchristosis only a single constant structure for each table object.
118*4724848cSchristos
119*4724848cSchristosObjects which are not in the table have the NID value NID_undef.
120*4724848cSchristos
121*4724848cSchristosObjects do not need to be in the internal tables to be processed,
122*4724848cSchristosthe functions OBJ_txt2obj() and OBJ_obj2txt() can process the numerical
123*4724848cSchristosform of an OID.
124*4724848cSchristos
125*4724848cSchristosSome objects are used to represent algorithms which do not have a
126*4724848cSchristoscorresponding ASN.1 OBJECT IDENTIFIER encoding (for example no OID currently
127*4724848cSchristosexists for a particular algorithm). As a result they B<cannot> be encoded or
128*4724848cSchristosdecoded as part of ASN.1 structures. Applications can determine if there
129*4724848cSchristosis a corresponding OBJECT IDENTIFIER by checking OBJ_length() is not zero.
130*4724848cSchristos
131*4724848cSchristosThese functions cannot return B<const> because an B<ASN1_OBJECT> can
132*4724848cSchristosrepresent both an internal, constant, OID and a dynamically-created one.
133*4724848cSchristosThe latter cannot be constant because it needs to be freed after use.
134*4724848cSchristos
135*4724848cSchristos=head1 RETURN VALUES
136*4724848cSchristos
137*4724848cSchristosOBJ_nid2obj() returns an B<ASN1_OBJECT> structure or B<NULL> is an
138*4724848cSchristoserror occurred.
139*4724848cSchristos
140*4724848cSchristosOBJ_nid2ln() and OBJ_nid2sn() returns a valid string or B<NULL>
141*4724848cSchristoson error.
142*4724848cSchristos
143*4724848cSchristosOBJ_obj2nid(), OBJ_ln2nid(), OBJ_sn2nid() and OBJ_txt2nid() return
144*4724848cSchristosa NID or B<NID_undef> on error.
145*4724848cSchristos
146*4724848cSchristosOBJ_add_sigid() returns 1 on success or 0 on error.
147*4724848cSchristos
148*4724848cSchristosi2t_ASN1_OBJECT() an OBJ_obj2txt() return -1 on error.
149*4724848cSchristosOn success, they return the length of the string written to I<buf> if I<buf> is
150*4724848cSchristosnot NULL and I<buf_len> is big enough, otherwise the total string length.
151*4724848cSchristosNote that this does not count the trailing NUL character.
152*4724848cSchristos
153*4724848cSchristos=head1 EXAMPLES
154*4724848cSchristos
155*4724848cSchristosCreate an object for B<commonName>:
156*4724848cSchristos
157*4724848cSchristos ASN1_OBJECT *o = OBJ_nid2obj(NID_commonName);
158*4724848cSchristos
159*4724848cSchristosCheck if an object is B<commonName>
160*4724848cSchristos
161*4724848cSchristos if (OBJ_obj2nid(obj) == NID_commonName)
162*4724848cSchristos     /* Do something */
163*4724848cSchristos
164*4724848cSchristosCreate a new NID and initialize an object from it:
165*4724848cSchristos
166*4724848cSchristos int new_nid = OBJ_create("1.2.3.4", "NewOID", "New Object Identifier");
167*4724848cSchristos ASN1_OBJECT *obj = OBJ_nid2obj(new_nid);
168*4724848cSchristos
169*4724848cSchristosCreate a new object directly:
170*4724848cSchristos
171*4724848cSchristos obj = OBJ_txt2obj("1.2.3.4", 1);
172*4724848cSchristos
173*4724848cSchristos=head1 SEE ALSO
174*4724848cSchristos
175*4724848cSchristosL<ERR_get_error(3)>
176*4724848cSchristos
177*4724848cSchristos=head1 HISTORY
178*4724848cSchristos
179*4724848cSchristosOBJ_cleanup() was deprecated in OpenSSL 1.1.0 by L<OPENSSL_init_crypto(3)>
180*4724848cSchristosand should not be used.
181*4724848cSchristos
182*4724848cSchristos=head1 COPYRIGHT
183*4724848cSchristos
184*4724848cSchristosCopyright 2002-2022 The OpenSSL Project Authors. All Rights Reserved.
185*4724848cSchristos
186*4724848cSchristosLicensed under the OpenSSL license (the "License").  You may not use
187*4724848cSchristosthis file except in compliance with the License.  You can obtain a copy
188*4724848cSchristosin the file LICENSE in the source distribution or at
189*4724848cSchristosL<https://www.openssl.org/source/license.html>.
190*4724848cSchristos
191*4724848cSchristos=cut
192