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