Hex Artifact Content

Artifact 1388b833765e97973f10576f7118e419dc4b8110:


0000: 2f 2a 0a 20 2a 20 42 61 73 69 63 20 69 6d 70 6c  /*. * Basic impl
0010: 65 6d 65 6e 74 61 74 69 6f 6e 20 6f 66 20 49 54  ementation of IT
0020: 55 2d 54 20 58 2e 36 39 30 20 28 30 37 2f 32 30  U-T X.690 (07/20
0030: 30 32 29 20 66 6f 72 20 70 61 72 73 69 6e 67 20  02) for parsing 
0040: 42 45 52 20 65 6e 63 6f 64 65 64 0a 20 2a 20 58  BER encoded. * X
0050: 2e 35 30 39 20 63 65 72 74 69 66 69 63 61 74 65  .509 certificate
0060: 73 0a 20 2a 2f 0a 0a 23 69 66 64 65 66 20 48 41  s. */..#ifdef HA
0070: 56 45 5f 43 4f 4e 46 49 47 5f 48 0a 23 20 20 69  VE_CONFIG_H.#  i
0080: 6e 63 6c 75 64 65 20 22 63 6f 6e 66 69 67 2e 68  nclude "config.h
0090: 22 0a 23 65 6e 64 69 66 0a 0a 23 69 66 64 65 66  ".#endif..#ifdef
00a0: 20 48 41 56 45 5f 55 4e 49 53 54 44 5f 48 0a 23   HAVE_UNISTD_H.#
00b0: 20 20 69 6e 63 6c 75 64 65 20 3c 75 6e 69 73 74    include <unist
00c0: 64 2e 68 3e 0a 23 65 6e 64 69 66 0a 23 69 66 64  d.h>.#endif.#ifd
00d0: 65 66 20 48 41 56 45 5f 53 54 44 4c 49 42 5f 48  ef HAVE_STDLIB_H
00e0: 0a 23 20 20 69 6e 63 6c 75 64 65 20 3c 73 74 64  .#  include <std
00f0: 6c 69 62 2e 68 3e 0a 23 65 6e 64 69 66 0a 23 69  lib.h>.#endif.#i
0100: 66 64 65 66 20 48 41 56 45 5f 53 54 44 41 52 47  fdef HAVE_STDARG
0110: 5f 48 0a 23 20 20 69 6e 63 6c 75 64 65 20 3c 73  _H.#  include <s
0120: 74 64 61 72 67 2e 68 3e 0a 23 65 6e 64 69 66 0a  tdarg.h>.#endif.
0130: 23 69 66 64 65 66 20 48 41 56 45 5f 53 54 44 49  #ifdef HAVE_STDI
0140: 4f 5f 48 0a 23 20 20 69 6e 63 6c 75 64 65 20 3c  O_H.#  include <
0150: 73 74 64 69 6f 2e 68 3e 0a 23 65 6e 64 69 66 0a  stdio.h>.#endif.
0160: 23 69 66 64 65 66 20 48 41 56 45 5f 53 54 52 49  #ifdef HAVE_STRI
0170: 4e 47 5f 48 0a 23 20 20 69 6e 63 6c 75 64 65 20  NG_H.#  include 
0180: 3c 73 74 72 69 6e 67 2e 68 3e 0a 23 65 6e 64 69  <string.h>.#endi
0190: 66 0a 0a 23 69 6e 63 6c 75 64 65 20 22 61 73 6e  f..#include "asn
01a0: 31 2d 78 35 30 39 2e 68 22 0a 0a 73 74 72 75 63  1-x509.h"..struc
01b0: 74 20 61 73 6e 31 5f 6f 62 6a 65 63 74 20 7b 0a  t asn1_object {.
01c0: 09 75 6e 73 69 67 6e 65 64 20 6c 6f 6e 67 20 74  .unsigned long t
01d0: 61 67 3b 0a 09 75 6e 73 69 67 6e 65 64 20 6c 6f  ag;..unsigned lo
01e0: 6e 67 20 73 69 7a 65 3b 0a 09 76 6f 69 64 20 2a  ng size;..void *
01f0: 63 6f 6e 74 65 6e 74 73 3b 0a 0a 09 75 6e 73 69  contents;...unsi
0200: 67 6e 65 64 20 6c 6f 6e 67 20 61 73 6e 31 72 65  gned long asn1re
0210: 70 5f 6c 65 6e 3b 0a 09 76 6f 69 64 20 2a 61 73  p_len;..void *as
0220: 6e 31 72 65 70 3b 0a 7d 3b 0a 0a 73 74 72 75 63  n1rep;.};..struc
0230: 74 20 78 35 30 39 5f 6f 62 6a 65 63 74 20 7b 0a  t x509_object {.
0240: 09 73 74 72 75 63 74 20 61 73 6e 31 5f 6f 62 6a  .struct asn1_obj
0250: 65 63 74 20 77 68 6f 6c 65 74 68 69 6e 67 3b 0a  ect wholething;.
0260: 09 09 73 74 72 75 63 74 20 61 73 6e 31 5f 6f 62  ..struct asn1_ob
0270: 6a 65 63 74 20 63 65 72 74 69 66 69 63 61 74 65  ject certificate
0280: 3b 0a 09 09 09 73 74 72 75 63 74 20 61 73 6e 31  ;....struct asn1
0290: 5f 6f 62 6a 65 63 74 20 76 65 72 73 69 6f 6e 3b  _object version;
02a0: 0a 09 09 09 73 74 72 75 63 74 20 61 73 6e 31 5f  ....struct asn1_
02b0: 6f 62 6a 65 63 74 20 73 65 72 69 61 6c 5f 6e 75  object serial_nu
02c0: 6d 62 65 72 3b 0a 09 09 09 73 74 72 75 63 74 20  mber;....struct 
02d0: 61 73 6e 31 5f 6f 62 6a 65 63 74 20 73 69 67 6e  asn1_object sign
02e0: 61 74 75 72 65 5f 61 6c 67 6f 3b 0a 09 09 09 73  ature_algo;....s
02f0: 74 72 75 63 74 20 61 73 6e 31 5f 6f 62 6a 65 63  truct asn1_objec
0300: 74 20 69 73 73 75 65 72 3b 0a 09 09 09 73 74 72  t issuer;....str
0310: 75 63 74 20 61 73 6e 31 5f 6f 62 6a 65 63 74 20  uct asn1_object 
0320: 76 61 6c 69 64 69 74 79 3b 0a 09 09 09 73 74 72  validity;....str
0330: 75 63 74 20 61 73 6e 31 5f 6f 62 6a 65 63 74 20  uct asn1_object 
0340: 73 75 62 6a 65 63 74 3b 0a 09 09 09 73 74 72 75  subject;....stru
0350: 63 74 20 61 73 6e 31 5f 6f 62 6a 65 63 74 20 70  ct asn1_object p
0360: 75 62 6b 65 79 69 6e 66 6f 3b 0a 09 09 09 09 73  ubkeyinfo;.....s
0370: 74 72 75 63 74 20 61 73 6e 31 5f 6f 62 6a 65 63  truct asn1_objec
0380: 74 20 70 75 62 6b 65 79 5f 61 6c 67 6f 69 64 3b  t pubkey_algoid;
0390: 0a 09 09 09 09 09 73 74 72 75 63 74 20 61 73 6e  ......struct asn
03a0: 31 5f 6f 62 6a 65 63 74 20 70 75 62 6b 65 79 5f  1_object pubkey_
03b0: 61 6c 67 6f 3b 0a 09 09 09 09 09 73 74 72 75 63  algo;......struc
03c0: 74 20 61 73 6e 31 5f 6f 62 6a 65 63 74 20 70 75  t asn1_object pu
03d0: 62 6b 65 79 5f 61 6c 67 6f 70 61 72 6d 3b 0a 09  bkey_algoparm;..
03e0: 09 09 09 73 74 72 75 63 74 20 61 73 6e 31 5f 6f  ...struct asn1_o
03f0: 62 6a 65 63 74 20 70 75 62 6b 65 79 3b 0a 7d 3b  bject pubkey;.};
0400: 0a 0a 73 74 61 74 69 63 20 69 6e 74 20 5f 61 73  ..static int _as
0410: 6e 31 5f 78 35 30 39 5f 72 65 61 64 5f 61 73 6e  n1_x509_read_asn
0420: 31 5f 6f 62 6a 65 63 74 28 75 6e 73 69 67 6e 65  1_object(unsigne
0430: 64 20 63 68 61 72 20 2a 62 75 66 2c 20 73 69 7a  d char *buf, siz
0440: 65 5f 74 20 62 75 66 6c 65 6e 2c 20 76 61 5f 6c  e_t buflen, va_l
0450: 69 73 74 20 2a 61 72 67 73 29 20 7b 0a 09 75 6e  ist *args) {..un
0460: 73 69 67 6e 65 64 20 63 68 61 72 20 73 6d 61 6c  signed char smal
0470: 6c 5f 6f 62 6a 65 63 74 5f 73 69 7a 65 3b 0a 09  l_object_size;..
0480: 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20 2a 62  unsigned char *b
0490: 75 66 5f 70 3b 0a 09 73 74 72 75 63 74 20 61 73  uf_p;..struct as
04a0: 6e 31 5f 6f 62 6a 65 63 74 20 2a 6f 75 74 62 75  n1_object *outbu
04b0: 66 3b 0a 0a 09 6f 75 74 62 75 66 20 3d 20 76 61  f;...outbuf = va
04c0: 5f 61 72 67 28 2a 61 72 67 73 2c 20 73 74 72 75  _arg(*args, stru
04d0: 63 74 20 61 73 6e 31 5f 6f 62 6a 65 63 74 20 2a  ct asn1_object *
04e0: 29 3b 0a 0a 09 69 66 20 28 6f 75 74 62 75 66 20  );...if (outbuf 
04f0: 3d 3d 20 4e 55 4c 4c 29 20 7b 0a 09 09 72 65 74  == NULL) {...ret
0500: 75 72 6e 28 30 29 3b 0a 09 7d 0a 0a 09 69 66 20  urn(0);..}...if 
0510: 28 62 75 66 6c 65 6e 20 3d 3d 20 30 29 20 7b 0a  (buflen == 0) {.
0520: 09 09 72 65 74 75 72 6e 28 2d 31 29 3b 0a 09 7d  ..return(-1);..}
0530: 0a 0a 09 62 75 66 5f 70 20 3d 20 62 75 66 3b 0a  ...buf_p = buf;.
0540: 0a 09 6f 75 74 62 75 66 2d 3e 74 61 67 20 3d 20  ..outbuf->tag = 
0550: 2a 62 75 66 5f 70 3b 0a 09 62 75 66 5f 70 2b 2b  *buf_p;..buf_p++
0560: 3b 0a 09 62 75 66 6c 65 6e 2d 2d 3b 0a 0a 09 2f  ;..buflen--;.../
0570: 2a 20 4e 55 4c 4c 20 54 61 67 20 2d 2d 20 6e 6f  * NULL Tag -- no
0580: 20 73 69 7a 65 20 69 73 20 72 65 71 75 69 72 65   size is require
0590: 64 20 2a 2f 0a 09 69 66 20 28 6f 75 74 62 75 66  d */..if (outbuf
05a0: 2d 3e 74 61 67 20 3d 3d 20 30 78 30 30 29 20 7b  ->tag == 0x00) {
05b0: 0a 09 09 6f 75 74 62 75 66 2d 3e 73 69 7a 65 20  ...outbuf->size 
05c0: 3d 20 30 3b 0a 09 09 6f 75 74 62 75 66 2d 3e 61  = 0;...outbuf->a
05d0: 73 6e 31 72 65 70 5f 6c 65 6e 20 3d 20 31 3b 0a  sn1rep_len = 1;.
05e0: 09 09 6f 75 74 62 75 66 2d 3e 61 73 6e 31 72 65  ..outbuf->asn1re
05f0: 70 20 3d 20 62 75 66 3b 0a 0a 09 09 72 65 74 75  p = buf;....retu
0600: 72 6e 28 5f 61 73 6e 31 5f 78 35 30 39 5f 72 65  rn(_asn1_x509_re
0610: 61 64 5f 61 73 6e 31 5f 6f 62 6a 65 63 74 28 62  ad_asn1_object(b
0620: 75 66 5f 70 2c 20 62 75 66 6c 65 6e 2c 20 61 72  uf_p, buflen, ar
0630: 67 73 29 29 3b 0a 09 7d 0a 0a 09 69 66 20 28 62  gs));..}...if (b
0640: 75 66 6c 65 6e 20 3d 3d 20 30 29 20 7b 0a 09 09  uflen == 0) {...
0650: 72 65 74 75 72 6e 28 2d 31 29 3b 0a 09 7d 0a 0a  return(-1);..}..
0660: 09 73 6d 61 6c 6c 5f 6f 62 6a 65 63 74 5f 73 69  .small_object_si
0670: 7a 65 20 3d 20 2a 62 75 66 5f 70 3b 0a 09 62 75  ze = *buf_p;..bu
0680: 66 5f 70 2b 2b 3b 0a 09 62 75 66 6c 65 6e 2d 2d  f_p++;..buflen--
0690: 3b 0a 09 69 66 20 28 62 75 66 6c 65 6e 20 3d 3d  ;..if (buflen ==
06a0: 20 30 29 20 7b 0a 09 09 72 65 74 75 72 6e 28 2d   0) {...return(-
06b0: 31 29 3b 0a 09 7d 0a 0a 09 69 66 20 28 28 73 6d  1);..}...if ((sm
06c0: 61 6c 6c 5f 6f 62 6a 65 63 74 5f 73 69 7a 65 20  all_object_size 
06d0: 26 20 30 78 38 30 29 20 3d 3d 20 30 78 38 30 29  & 0x80) == 0x80)
06e0: 20 7b 0a 09 09 6f 75 74 62 75 66 2d 3e 73 69 7a   {...outbuf->siz
06f0: 65 20 3d 20 30 3b 0a 0a 09 09 66 6f 72 20 28 73  e = 0;....for (s
0700: 6d 61 6c 6c 5f 6f 62 6a 65 63 74 5f 73 69 7a 65  mall_object_size
0710: 20 5e 3d 20 30 78 38 30 3b 20 73 6d 61 6c 6c 5f   ^= 0x80; small_
0720: 6f 62 6a 65 63 74 5f 73 69 7a 65 3b 20 73 6d 61  object_size; sma
0730: 6c 6c 5f 6f 62 6a 65 63 74 5f 73 69 7a 65 2d 2d  ll_object_size--
0740: 29 20 7b 0a 09 09 09 6f 75 74 62 75 66 2d 3e 73  ) {....outbuf->s
0750: 69 7a 65 20 3c 3c 3d 20 38 3b 0a 09 09 09 6f 75  ize <<= 8;....ou
0760: 74 62 75 66 2d 3e 73 69 7a 65 20 2b 3d 20 2a 62  tbuf->size += *b
0770: 75 66 5f 70 3b 0a 0a 09 09 09 62 75 66 5f 70 2b  uf_p;.....buf_p+
0780: 2b 3b 0a 09 09 09 62 75 66 6c 65 6e 2d 2d 3b 0a  +;....buflen--;.
0790: 0a 09 09 09 69 66 20 28 62 75 66 6c 65 6e 20 3d  ....if (buflen =
07a0: 3d 20 30 29 20 7b 0a 09 09 09 09 62 72 65 61 6b  = 0) {.....break
07b0: 3b 0a 09 09 09 7d 0a 09 09 7d 0a 09 7d 20 65 6c  ;....}...}..} el
07c0: 73 65 20 7b 0a 09 09 6f 75 74 62 75 66 2d 3e 73  se {...outbuf->s
07d0: 69 7a 65 20 3d 20 73 6d 61 6c 6c 5f 6f 62 6a 65  ize = small_obje
07e0: 63 74 5f 73 69 7a 65 3b 0a 09 7d 0a 0a 09 69 66  ct_size;..}...if
07f0: 20 28 6f 75 74 62 75 66 2d 3e 73 69 7a 65 20 3e   (outbuf->size >
0800: 20 62 75 66 6c 65 6e 29 20 7b 0a 09 09 72 65 74   buflen) {...ret
0810: 75 72 6e 28 2d 31 29 3b 0a 09 7d 0a 0a 09 69 66  urn(-1);..}...if
0820: 20 28 62 75 66 6c 65 6e 20 21 3d 20 30 29 20 7b   (buflen != 0) {
0830: 0a 09 09 6f 75 74 62 75 66 2d 3e 63 6f 6e 74 65  ...outbuf->conte
0840: 6e 74 73 20 3d 20 62 75 66 5f 70 3b 0a 09 7d 0a  nts = buf_p;..}.
0850: 0a 09 6f 75 74 62 75 66 2d 3e 61 73 6e 31 72 65  ..outbuf->asn1re
0860: 70 5f 6c 65 6e 20 3d 20 6f 75 74 62 75 66 2d 3e  p_len = outbuf->
0870: 73 69 7a 65 20 2b 20 28 62 75 66 5f 70 20 2d 20  size + (buf_p - 
0880: 62 75 66 29 3b 0a 09 6f 75 74 62 75 66 2d 3e 61  buf);..outbuf->a
0890: 73 6e 31 72 65 70 20 3d 20 62 75 66 3b 0a 0a 09  sn1rep = buf;...
08a0: 62 75 66 5f 70 20 2b 3d 20 6f 75 74 62 75 66 2d  buf_p += outbuf-
08b0: 3e 73 69 7a 65 3b 0a 09 62 75 66 6c 65 6e 20 2d  >size;..buflen -
08c0: 3d 20 6f 75 74 62 75 66 2d 3e 73 69 7a 65 3b 0a  = outbuf->size;.
08d0: 0a 09 72 65 74 75 72 6e 28 5f 61 73 6e 31 5f 78  ..return(_asn1_x
08e0: 35 30 39 5f 72 65 61 64 5f 61 73 6e 31 5f 6f 62  509_read_asn1_ob
08f0: 6a 65 63 74 28 62 75 66 5f 70 2c 20 62 75 66 6c  ject(buf_p, bufl
0900: 65 6e 2c 20 61 72 67 73 29 29 3b 0a 7d 0a 0a 73  en, args));.}..s
0910: 74 61 74 69 63 20 69 6e 74 20 61 73 6e 31 5f 78  tatic int asn1_x
0920: 35 30 39 5f 72 65 61 64 5f 61 73 6e 31 5f 6f 62  509_read_asn1_ob
0930: 6a 65 63 74 28 75 6e 73 69 67 6e 65 64 20 63 68  ject(unsigned ch
0940: 61 72 20 2a 62 75 66 2c 20 73 69 7a 65 5f 74 20  ar *buf, size_t 
0950: 62 75 66 6c 65 6e 2c 20 2e 2e 2e 29 20 7b 0a 09  buflen, ...) {..
0960: 76 61 5f 6c 69 73 74 20 61 72 67 73 3b 0a 09 69  va_list args;..i
0970: 6e 74 20 72 65 74 76 61 6c 3b 0a 0a 09 76 61 5f  nt retval;...va_
0980: 73 74 61 72 74 28 61 72 67 73 2c 20 62 75 66 6c  start(args, bufl
0990: 65 6e 29 3b 0a 0a 09 72 65 74 76 61 6c 20 3d 20  en);...retval = 
09a0: 5f 61 73 6e 31 5f 78 35 30 39 5f 72 65 61 64 5f  _asn1_x509_read_
09b0: 61 73 6e 31 5f 6f 62 6a 65 63 74 28 62 75 66 2c  asn1_object(buf,
09c0: 20 62 75 66 6c 65 6e 2c 20 26 61 72 67 73 29 3b   buflen, &args);
09d0: 0a 0a 09 76 61 5f 65 6e 64 28 61 72 67 73 29 3b  ...va_end(args);
09e0: 0a 0a 09 72 65 74 75 72 6e 28 72 65 74 76 61 6c  ...return(retval
09f0: 29 3b 0a 7d 0a 0a 73 74 61 74 69 63 20 69 6e 74  );.}..static int
0a00: 20 61 73 6e 31 5f 78 35 30 39 5f 72 65 61 64 5f   asn1_x509_read_
0a10: 6f 62 6a 65 63 74 28 75 6e 73 69 67 6e 65 64 20  object(unsigned 
0a20: 63 68 61 72 20 2a 62 75 66 2c 20 73 69 7a 65 5f  char *buf, size_
0a30: 74 20 62 75 66 6c 65 6e 2c 20 73 74 72 75 63 74  t buflen, struct
0a40: 20 78 35 30 39 5f 6f 62 6a 65 63 74 20 2a 6f 75   x509_object *ou
0a50: 74 62 75 66 29 20 7b 0a 09 69 6e 74 20 72 65 61  tbuf) {..int rea
0a60: 64 5f 72 65 74 3b 0a 0a 09 72 65 61 64 5f 72 65  d_ret;...read_re
0a70: 74 20 3d 20 61 73 6e 31 5f 78 35 30 39 5f 72 65  t = asn1_x509_re
0a80: 61 64 5f 61 73 6e 31 5f 6f 62 6a 65 63 74 28 62  ad_asn1_object(b
0a90: 75 66 2c 20 62 75 66 6c 65 6e 2c 20 26 6f 75 74  uf, buflen, &out
0aa0: 62 75 66 2d 3e 77 68 6f 6c 65 74 68 69 6e 67 2c  buf->wholething,
0ab0: 20 4e 55 4c 4c 29 3b 0a 09 69 66 20 28 72 65 61   NULL);..if (rea
0ac0: 64 5f 72 65 74 20 21 3d 20 30 29 20 7b 0a 09 09  d_ret != 0) {...
0ad0: 43 41 43 4b 45 59 5f 44 45 42 55 47 5f 50 52 49  CACKEY_DEBUG_PRI
0ae0: 4e 54 46 28 22 46 61 69 6c 65 64 20 61 74 20 72  NTF("Failed at r
0af0: 65 61 64 69 6e 67 20 74 68 65 20 63 6f 6e 74 65  eading the conte
0b00: 6e 74 73 20 66 72 6f 6d 20 74 68 65 20 77 72 61  nts from the wra
0b10: 70 70 65 72 22 29 0a 0a 09 09 72 65 74 75 72 6e  pper")....return
0b20: 28 2d 31 29 3b 0a 09 7d 0a 0a 09 72 65 61 64 5f  (-1);..}...read_
0b30: 72 65 74 20 3d 20 61 73 6e 31 5f 78 35 30 39 5f  ret = asn1_x509_
0b40: 72 65 61 64 5f 61 73 6e 31 5f 6f 62 6a 65 63 74  read_asn1_object
0b50: 28 6f 75 74 62 75 66 2d 3e 77 68 6f 6c 65 74 68  (outbuf->wholeth
0b60: 69 6e 67 2e 63 6f 6e 74 65 6e 74 73 2c 20 6f 75  ing.contents, ou
0b70: 74 62 75 66 2d 3e 77 68 6f 6c 65 74 68 69 6e 67  tbuf->wholething
0b80: 2e 73 69 7a 65 2c 20 26 6f 75 74 62 75 66 2d 3e  .size, &outbuf->
0b90: 63 65 72 74 69 66 69 63 61 74 65 2c 20 4e 55 4c  certificate, NUL
0ba0: 4c 29 3b 0a 09 69 66 20 28 72 65 61 64 5f 72 65  L);..if (read_re
0bb0: 74 20 21 3d 20 30 29 20 7b 0a 09 09 43 41 43 4b  t != 0) {...CACK
0bc0: 45 59 5f 44 45 42 55 47 5f 50 52 49 4e 54 46 28  EY_DEBUG_PRINTF(
0bd0: 22 46 61 69 6c 65 64 20 61 74 20 72 65 61 64 69  "Failed at readi
0be0: 6e 67 20 74 68 65 20 63 65 72 74 69 66 69 63 61  ng the certifica
0bf0: 74 65 20 66 72 6f 6d 20 74 68 65 20 63 6f 6e 74  te from the cont
0c00: 65 6e 74 73 22 29 3b 0a 0a 09 09 72 65 74 75 72  ents");....retur
0c10: 6e 28 2d 31 29 3b 0a 09 7d 0a 0a 09 72 65 61 64  n(-1);..}...read
0c20: 5f 72 65 74 20 3d 20 61 73 6e 31 5f 78 35 30 39  _ret = asn1_x509
0c30: 5f 72 65 61 64 5f 61 73 6e 31 5f 6f 62 6a 65 63  _read_asn1_objec
0c40: 74 28 6f 75 74 62 75 66 2d 3e 63 65 72 74 69 66  t(outbuf->certif
0c50: 69 63 61 74 65 2e 63 6f 6e 74 65 6e 74 73 2c 20  icate.contents, 
0c60: 6f 75 74 62 75 66 2d 3e 63 65 72 74 69 66 69 63  outbuf->certific
0c70: 61 74 65 2e 73 69 7a 65 2c 20 26 6f 75 74 62 75  ate.size, &outbu
0c80: 66 2d 3e 76 65 72 73 69 6f 6e 2c 20 26 6f 75 74  f->version, &out
0c90: 62 75 66 2d 3e 73 65 72 69 61 6c 5f 6e 75 6d 62  buf->serial_numb
0ca0: 65 72 2c 20 26 6f 75 74 62 75 66 2d 3e 73 69 67  er, &outbuf->sig
0cb0: 6e 61 74 75 72 65 5f 61 6c 67 6f 2c 20 26 6f 75  nature_algo, &ou
0cc0: 74 62 75 66 2d 3e 69 73 73 75 65 72 2c 20 26 6f  tbuf->issuer, &o
0cd0: 75 74 62 75 66 2d 3e 76 61 6c 69 64 69 74 79 2c  utbuf->validity,
0ce0: 20 26 6f 75 74 62 75 66 2d 3e 73 75 62 6a 65 63   &outbuf->subjec
0cf0: 74 2c 20 26 6f 75 74 62 75 66 2d 3e 70 75 62 6b  t, &outbuf->pubk
0d00: 65 79 69 6e 66 6f 2c 20 4e 55 4c 4c 29 3b 0a 09  eyinfo, NULL);..
0d10: 69 66 20 28 72 65 61 64 5f 72 65 74 20 21 3d 20  if (read_ret != 
0d20: 30 29 20 7b 0a 09 09 43 41 43 4b 45 59 5f 44 45  0) {...CACKEY_DE
0d30: 42 55 47 5f 50 52 49 4e 54 46 28 22 46 61 69 6c  BUG_PRINTF("Fail
0d40: 65 64 20 61 74 20 72 65 61 64 69 6e 67 20 74 68  ed at reading th
0d50: 65 20 63 65 72 74 69 66 69 63 61 74 65 20 63 6f  e certificate co
0d60: 6d 70 6f 6e 65 6e 74 73 20 66 72 6f 6d 20 74 68  mponents from th
0d70: 65 20 63 65 72 74 69 66 69 63 61 74 65 22 29 3b  e certificate");
0d80: 0a 0a 09 09 72 65 74 75 72 6e 28 2d 31 29 3b 0a  ....return(-1);.
0d90: 09 7d 0a 0a 09 72 65 61 64 5f 72 65 74 20 3d 20  .}...read_ret = 
0da0: 61 73 6e 31 5f 78 35 30 39 5f 72 65 61 64 5f 61  asn1_x509_read_a
0db0: 73 6e 31 5f 6f 62 6a 65 63 74 28 6f 75 74 62 75  sn1_object(outbu
0dc0: 66 2d 3e 70 75 62 6b 65 79 69 6e 66 6f 2e 63 6f  f->pubkeyinfo.co
0dd0: 6e 74 65 6e 74 73 2c 20 6f 75 74 62 75 66 2d 3e  ntents, outbuf->
0de0: 70 75 62 6b 65 79 69 6e 66 6f 2e 73 69 7a 65 2c  pubkeyinfo.size,
0df0: 20 26 6f 75 74 62 75 66 2d 3e 70 75 62 6b 65 79   &outbuf->pubkey
0e00: 5f 61 6c 67 6f 69 64 2c 20 26 6f 75 74 62 75 66  _algoid, &outbuf
0e10: 2d 3e 70 75 62 6b 65 79 2c 20 4e 55 4c 4c 29 3b  ->pubkey, NULL);
0e20: 0a 09 69 66 20 28 72 65 61 64 5f 72 65 74 20 21  ..if (read_ret !
0e30: 3d 20 30 29 20 7b 0a 09 09 43 41 43 4b 45 59 5f  = 0) {...CACKEY_
0e40: 44 45 42 55 47 5f 50 52 49 4e 54 46 28 22 46 61  DEBUG_PRINTF("Fa
0e50: 69 6c 65 64 20 61 74 20 72 65 61 64 69 6e 67 20  iled at reading 
0e60: 74 68 65 20 70 75 62 6c 69 63 20 6b 65 79 20 66  the public key f
0e70: 72 6f 6d 20 74 68 65 20 63 65 72 74 69 66 69 63  rom the certific
0e80: 61 74 65 20 63 6f 6d 70 6f 6e 65 6e 74 73 22 29  ate components")
0e90: 3b 0a 0a 09 09 72 65 74 75 72 6e 28 2d 31 29 3b  ;....return(-1);
0ea0: 0a 09 7d 0a 0a 09 72 65 74 75 72 6e 28 30 29 3b  ..}...return(0);
0eb0: 0a 7d 0a 0a 73 73 69 7a 65 5f 74 20 78 35 30 39  .}..ssize_t x509
0ec0: 5f 74 6f 5f 69 73 73 75 65 72 28 76 6f 69 64 20  _to_issuer(void 
0ed0: 2a 78 35 30 39 5f 64 65 72 5f 62 75 66 2c 20 73  *x509_der_buf, s
0ee0: 69 7a 65 5f 74 20 78 35 30 39 5f 64 65 72 5f 62  ize_t x509_der_b
0ef0: 75 66 5f 6c 65 6e 2c 20 76 6f 69 64 20 2a 2a 6f  uf_len, void **o
0f00: 75 74 62 75 66 29 20 7b 0a 09 73 74 72 75 63 74  utbuf) {..struct
0f10: 20 78 35 30 39 5f 6f 62 6a 65 63 74 20 78 35 30   x509_object x50
0f20: 39 3b 0a 09 69 6e 74 20 72 65 61 64 5f 72 65 74  9;..int read_ret
0f30: 3b 0a 0a 09 72 65 61 64 5f 72 65 74 20 3d 20 61  ;...read_ret = a
0f40: 73 6e 31 5f 78 35 30 39 5f 72 65 61 64 5f 6f 62  sn1_x509_read_ob
0f50: 6a 65 63 74 28 78 35 30 39 5f 64 65 72 5f 62 75  ject(x509_der_bu
0f60: 66 2c 20 78 35 30 39 5f 64 65 72 5f 62 75 66 5f  f, x509_der_buf_
0f70: 6c 65 6e 2c 20 26 78 35 30 39 29 3b 0a 09 69 66  len, &x509);..if
0f80: 20 28 72 65 61 64 5f 72 65 74 20 21 3d 20 30 29   (read_ret != 0)
0f90: 20 7b 0a 09 09 72 65 74 75 72 6e 28 2d 31 29 3b   {...return(-1);
0fa0: 0a 09 7d 0a 0a 09 69 66 20 28 6f 75 74 62 75 66  ..}...if (outbuf
0fb0: 29 20 7b 0a 09 09 2a 6f 75 74 62 75 66 20 3d 20  ) {...*outbuf = 
0fc0: 78 35 30 39 2e 69 73 73 75 65 72 2e 61 73 6e 31  x509.issuer.asn1
0fd0: 72 65 70 3b 0a 09 7d 0a 0a 09 72 65 74 75 72 6e  rep;..}...return
0fe0: 28 78 35 30 39 2e 69 73 73 75 65 72 2e 61 73 6e  (x509.issuer.asn
0ff0: 31 72 65 70 5f 6c 65 6e 29 3b 0a 7d 0a 0a 73 73  1rep_len);.}..ss
1000: 69 7a 65 5f 74 20 78 35 30 39 5f 74 6f 5f 73 75  ize_t x509_to_su
1010: 62 6a 65 63 74 28 76 6f 69 64 20 2a 78 35 30 39  bject(void *x509
1020: 5f 64 65 72 5f 62 75 66 2c 20 73 69 7a 65 5f 74  _der_buf, size_t
1030: 20 78 35 30 39 5f 64 65 72 5f 62 75 66 5f 6c 65   x509_der_buf_le
1040: 6e 2c 20 76 6f 69 64 20 2a 2a 6f 75 74 62 75 66  n, void **outbuf
1050: 29 20 7b 0a 09 73 74 72 75 63 74 20 78 35 30 39  ) {..struct x509
1060: 5f 6f 62 6a 65 63 74 20 78 35 30 39 3b 0a 09 69  _object x509;..i
1070: 6e 74 20 72 65 61 64 5f 72 65 74 3b 0a 0a 09 72  nt read_ret;...r
1080: 65 61 64 5f 72 65 74 20 3d 20 61 73 6e 31 5f 78  ead_ret = asn1_x
1090: 35 30 39 5f 72 65 61 64 5f 6f 62 6a 65 63 74 28  509_read_object(
10a0: 78 35 30 39 5f 64 65 72 5f 62 75 66 2c 20 78 35  x509_der_buf, x5
10b0: 30 39 5f 64 65 72 5f 62 75 66 5f 6c 65 6e 2c 20  09_der_buf_len, 
10c0: 26 78 35 30 39 29 3b 0a 09 69 66 20 28 72 65 61  &x509);..if (rea
10d0: 64 5f 72 65 74 20 21 3d 20 30 29 20 7b 0a 09 09  d_ret != 0) {...
10e0: 72 65 74 75 72 6e 28 2d 31 29 3b 0a 09 7d 0a 0a  return(-1);..}..
10f0: 09 69 66 20 28 6f 75 74 62 75 66 29 20 7b 0a 09  .if (outbuf) {..
1100: 09 2a 6f 75 74 62 75 66 20 3d 20 78 35 30 39 2e  .*outbuf = x509.
1110: 73 75 62 6a 65 63 74 2e 61 73 6e 31 72 65 70 3b  subject.asn1rep;
1120: 0a 09 7d 0a 0a 09 72 65 74 75 72 6e 28 78 35 30  ..}...return(x50
1130: 39 2e 73 75 62 6a 65 63 74 2e 61 73 6e 31 72 65  9.subject.asn1re
1140: 70 5f 6c 65 6e 29 3b 0a 7d 0a 0a 73 74 61 74 69  p_len);.}..stati
1150: 63 20 73 73 69 7a 65 5f 74 20 78 35 30 39 5f 74  c ssize_t x509_t
1160: 6f 5f 73 65 72 69 61 6c 28 76 6f 69 64 20 2a 78  o_serial(void *x
1170: 35 30 39 5f 64 65 72 5f 62 75 66 2c 20 73 69 7a  509_der_buf, siz
1180: 65 5f 74 20 78 35 30 39 5f 64 65 72 5f 62 75 66  e_t x509_der_buf
1190: 5f 6c 65 6e 2c 20 76 6f 69 64 20 2a 2a 6f 75 74  _len, void **out
11a0: 62 75 66 29 20 7b 0a 09 73 74 72 75 63 74 20 78  buf) {..struct x
11b0: 35 30 39 5f 6f 62 6a 65 63 74 20 78 35 30 39 3b  509_object x509;
11c0: 0a 09 69 6e 74 20 72 65 61 64 5f 72 65 74 3b 0a  ..int read_ret;.
11d0: 0a 09 72 65 61 64 5f 72 65 74 20 3d 20 61 73 6e  ..read_ret = asn
11e0: 31 5f 78 35 30 39 5f 72 65 61 64 5f 6f 62 6a 65  1_x509_read_obje
11f0: 63 74 28 78 35 30 39 5f 64 65 72 5f 62 75 66 2c  ct(x509_der_buf,
1200: 20 78 35 30 39 5f 64 65 72 5f 62 75 66 5f 6c 65   x509_der_buf_le
1210: 6e 2c 20 26 78 35 30 39 29 3b 0a 09 69 66 20 28  n, &x509);..if (
1220: 72 65 61 64 5f 72 65 74 20 21 3d 20 30 29 20 7b  read_ret != 0) {
1230: 0a 09 09 43 41 43 4b 45 59 5f 44 45 42 55 47 5f  ...CACKEY_DEBUG_
1240: 50 52 49 4e 54 46 28 22 55 6e 61 62 6c 65 20 74  PRINTF("Unable t
1250: 6f 20 72 65 61 64 20 73 65 72 69 61 6c 20 6e 75  o read serial nu
1260: 6d 62 65 72 20 66 72 6f 6d 20 61 20 25 6c 75 20  mber from a %lu 
1270: 62 79 74 65 20 62 75 66 66 65 72 22 2c 20 28 75  byte buffer", (u
1280: 6e 73 69 67 6e 65 64 20 6c 6f 6e 67 29 20 78 35  nsigned long) x5
1290: 30 39 5f 64 65 72 5f 62 75 66 5f 6c 65 6e 29 3b  09_der_buf_len);
12a0: 0a 09 09 43 41 43 4b 45 59 5f 44 45 42 55 47 5f  ...CACKEY_DEBUG_
12b0: 50 52 49 4e 54 42 55 46 28 22 58 2e 35 30 39 20  PRINTBUF("X.509 
12c0: 44 45 52 3a 22 2c 20 78 35 30 39 5f 64 65 72 5f  DER:", x509_der_
12d0: 62 75 66 2c 20 78 35 30 39 5f 64 65 72 5f 62 75  buf, x509_der_bu
12e0: 66 5f 6c 65 6e 29 3b 0a 0a 09 09 72 65 74 75 72  f_len);....retur
12f0: 6e 28 2d 31 29 3b 0a 09 7d 0a 0a 09 69 66 20 28  n(-1);..}...if (
1300: 6f 75 74 62 75 66 29 20 7b 0a 09 09 2a 6f 75 74  outbuf) {...*out
1310: 62 75 66 20 3d 20 78 35 30 39 2e 73 65 72 69 61  buf = x509.seria
1320: 6c 5f 6e 75 6d 62 65 72 2e 61 73 6e 31 72 65 70  l_number.asn1rep
1330: 3b 0a 09 7d 0a 0a 09 72 65 74 75 72 6e 28 78 35  ;..}...return(x5
1340: 30 39 2e 73 65 72 69 61 6c 5f 6e 75 6d 62 65 72  09.serial_number
1350: 2e 61 73 6e 31 72 65 70 5f 6c 65 6e 29 3b 0a 7d  .asn1rep_len);.}
1360: 0a 0a 73 74 61 74 69 63 20 73 73 69 7a 65 5f 74  ..static ssize_t
1370: 20 78 35 30 39 5f 74 6f 5f 70 75 62 6b 65 79 28   x509_to_pubkey(
1380: 76 6f 69 64 20 2a 78 35 30 39 5f 64 65 72 5f 62  void *x509_der_b
1390: 75 66 2c 20 73 69 7a 65 5f 74 20 78 35 30 39 5f  uf, size_t x509_
13a0: 64 65 72 5f 62 75 66 5f 6c 65 6e 2c 20 76 6f 69  der_buf_len, voi
13b0: 64 20 2a 2a 6f 75 74 62 75 66 29 20 7b 0a 09 73  d **outbuf) {..s
13c0: 74 72 75 63 74 20 78 35 30 39 5f 6f 62 6a 65 63  truct x509_objec
13d0: 74 20 78 35 30 39 3b 0a 09 69 6e 74 20 72 65 61  t x509;..int rea
13e0: 64 5f 72 65 74 3b 0a 0a 09 72 65 61 64 5f 72 65  d_ret;...read_re
13f0: 74 20 3d 20 61 73 6e 31 5f 78 35 30 39 5f 72 65  t = asn1_x509_re
1400: 61 64 5f 6f 62 6a 65 63 74 28 78 35 30 39 5f 64  ad_object(x509_d
1410: 65 72 5f 62 75 66 2c 20 78 35 30 39 5f 64 65 72  er_buf, x509_der
1420: 5f 62 75 66 5f 6c 65 6e 2c 20 26 78 35 30 39 29  _buf_len, &x509)
1430: 3b 0a 09 69 66 20 28 72 65 61 64 5f 72 65 74 20  ;..if (read_ret 
1440: 21 3d 20 30 29 20 7b 0a 09 09 72 65 74 75 72 6e  != 0) {...return
1450: 28 2d 31 29 3b 0a 09 7d 0a 0a 09 2a 6f 75 74 62  (-1);..}...*outb
1460: 75 66 20 3d 20 78 35 30 39 2e 70 75 62 6b 65 79  uf = x509.pubkey
1470: 2e 63 6f 6e 74 65 6e 74 73 3b 0a 09 72 65 74 75  .contents;..retu
1480: 72 6e 28 78 35 30 39 2e 70 75 62 6b 65 79 2e 73  rn(x509.pubkey.s
1490: 69 7a 65 29 3b 0a 7d 0a 0a 73 74 61 74 69 63 20  ize);.}..static 
14a0: 73 73 69 7a 65 5f 74 20 78 35 30 39 5f 74 6f 5f  ssize_t x509_to_
14b0: 6d 6f 64 75 6c 75 73 28 76 6f 69 64 20 2a 78 35  modulus(void *x5
14c0: 30 39 5f 64 65 72 5f 62 75 66 2c 20 73 69 7a 65  09_der_buf, size
14d0: 5f 74 20 78 35 30 39 5f 64 65 72 5f 62 75 66 5f  _t x509_der_buf_
14e0: 6c 65 6e 2c 20 76 6f 69 64 20 2a 2a 6f 75 74 62  len, void **outb
14f0: 75 66 29 20 7b 0a 09 73 74 72 75 63 74 20 61 73  uf) {..struct as
1500: 6e 31 5f 6f 62 6a 65 63 74 20 6e 75 6c 6c 2c 20  n1_object null, 
1510: 70 75 62 6b 65 79 2c 20 6d 6f 64 75 6c 75 73 2c  pubkey, modulus,
1520: 20 65 78 70 6f 6e 65 6e 74 3b 0a 09 73 74 72 75   exponent;..stru
1530: 63 74 20 78 35 30 39 5f 6f 62 6a 65 63 74 20 78  ct x509_object x
1540: 35 30 39 3b 0a 09 69 6e 74 20 72 65 61 64 5f 72  509;..int read_r
1550: 65 74 3b 0a 0a 09 72 65 61 64 5f 72 65 74 20 3d  et;...read_ret =
1560: 20 61 73 6e 31 5f 78 35 30 39 5f 72 65 61 64 5f   asn1_x509_read_
1570: 6f 62 6a 65 63 74 28 78 35 30 39 5f 64 65 72 5f  object(x509_der_
1580: 62 75 66 2c 20 78 35 30 39 5f 64 65 72 5f 62 75  buf, x509_der_bu
1590: 66 5f 6c 65 6e 2c 20 26 78 35 30 39 29 3b 0a 09  f_len, &x509);..
15a0: 69 66 20 28 72 65 61 64 5f 72 65 74 20 21 3d 20  if (read_ret != 
15b0: 30 29 20 7b 0a 09 09 72 65 74 75 72 6e 28 2d 31  0) {...return(-1
15c0: 29 3b 0a 09 7d 0a 0a 09 2f 2a 20 54 68 65 20 73  );..}.../* The s
15d0: 74 72 75 63 74 75 72 65 20 6f 66 20 22 70 75 62  tructure of "pub
15e0: 6b 65 79 22 20 69 73 20 73 70 65 63 69 66 69 65  key" is specifie
15f0: 64 20 69 6e 20 50 4b 43 53 20 23 31 20 2a 2f 0a  d in PKCS #1 */.
1600: 09 72 65 61 64 5f 72 65 74 20 3d 20 61 73 6e 31  .read_ret = asn1
1610: 5f 78 35 30 39 5f 72 65 61 64 5f 61 73 6e 31 5f  _x509_read_asn1_
1620: 6f 62 6a 65 63 74 28 78 35 30 39 2e 70 75 62 6b  object(x509.pubk
1630: 65 79 2e 63 6f 6e 74 65 6e 74 73 2c 20 78 35 30  ey.contents, x50
1640: 39 2e 70 75 62 6b 65 79 2e 73 69 7a 65 2c 20 26  9.pubkey.size, &
1650: 6e 75 6c 6c 2c 20 26 70 75 62 6b 65 79 2c 20 4e  null, &pubkey, N
1660: 55 4c 4c 29 3b 0a 09 69 66 20 28 72 65 61 64 5f  ULL);..if (read_
1670: 72 65 74 20 21 3d 20 30 29 20 7b 0a 09 09 72 65  ret != 0) {...re
1680: 74 75 72 6e 28 2d 31 29 3b 0a 09 7d 0a 0a 09 72  turn(-1);..}...r
1690: 65 61 64 5f 72 65 74 20 3d 20 61 73 6e 31 5f 78  ead_ret = asn1_x
16a0: 35 30 39 5f 72 65 61 64 5f 61 73 6e 31 5f 6f 62  509_read_asn1_ob
16b0: 6a 65 63 74 28 70 75 62 6b 65 79 2e 63 6f 6e 74  ject(pubkey.cont
16c0: 65 6e 74 73 2c 20 70 75 62 6b 65 79 2e 73 69 7a  ents, pubkey.siz
16d0: 65 2c 20 26 6d 6f 64 75 6c 75 73 2c 20 26 65 78  e, &modulus, &ex
16e0: 70 6f 6e 65 6e 74 2c 20 4e 55 4c 4c 29 3b 0a 09  ponent, NULL);..
16f0: 69 66 20 28 72 65 61 64 5f 72 65 74 20 21 3d 20  if (read_ret != 
1700: 30 29 20 7b 0a 09 09 72 65 74 75 72 6e 28 2d 31  0) {...return(-1
1710: 29 3b 0a 09 7d 0a 0a 09 69 66 20 28 6f 75 74 62  );..}...if (outb
1720: 75 66 29 20 7b 0a 09 09 2a 6f 75 74 62 75 66 20  uf) {...*outbuf 
1730: 3d 20 6d 6f 64 75 6c 75 73 2e 63 6f 6e 74 65 6e  = modulus.conten
1740: 74 73 3b 0a 09 7d 0a 0a 09 72 65 74 75 72 6e 28  ts;..}...return(
1750: 6d 6f 64 75 6c 75 73 2e 73 69 7a 65 29 3b 0a 7d  modulus.size);.}
1760: 0a 0a 73 74 61 74 69 63 20 73 73 69 7a 65 5f 74  ..static ssize_t
1770: 20 78 35 30 39 5f 74 6f 5f 65 78 70 6f 6e 65 6e   x509_to_exponen
1780: 74 28 76 6f 69 64 20 2a 78 35 30 39 5f 64 65 72  t(void *x509_der
1790: 5f 62 75 66 2c 20 73 69 7a 65 5f 74 20 78 35 30  _buf, size_t x50
17a0: 39 5f 64 65 72 5f 62 75 66 5f 6c 65 6e 2c 20 76  9_der_buf_len, v
17b0: 6f 69 64 20 2a 2a 6f 75 74 62 75 66 29 20 7b 0a  oid **outbuf) {.
17c0: 09 73 74 72 75 63 74 20 61 73 6e 31 5f 6f 62 6a  .struct asn1_obj
17d0: 65 63 74 20 6e 75 6c 6c 2c 20 70 75 62 6b 65 79  ect null, pubkey
17e0: 2c 20 6d 6f 64 75 6c 75 73 2c 20 65 78 70 6f 6e  , modulus, expon
17f0: 65 6e 74 3b 0a 09 73 74 72 75 63 74 20 78 35 30  ent;..struct x50
1800: 39 5f 6f 62 6a 65 63 74 20 78 35 30 39 3b 0a 09  9_object x509;..
1810: 69 6e 74 20 72 65 61 64 5f 72 65 74 3b 0a 0a 09  int read_ret;...
1820: 72 65 61 64 5f 72 65 74 20 3d 20 61 73 6e 31 5f  read_ret = asn1_
1830: 78 35 30 39 5f 72 65 61 64 5f 6f 62 6a 65 63 74  x509_read_object
1840: 28 78 35 30 39 5f 64 65 72 5f 62 75 66 2c 20 78  (x509_der_buf, x
1850: 35 30 39 5f 64 65 72 5f 62 75 66 5f 6c 65 6e 2c  509_der_buf_len,
1860: 20 26 78 35 30 39 29 3b 0a 09 69 66 20 28 72 65   &x509);..if (re
1870: 61 64 5f 72 65 74 20 21 3d 20 30 29 20 7b 0a 09  ad_ret != 0) {..
1880: 09 72 65 74 75 72 6e 28 2d 31 29 3b 0a 09 7d 0a  .return(-1);..}.
1890: 0a 09 2f 2a 20 54 68 65 20 73 74 72 75 63 74 75  ../* The structu
18a0: 72 65 20 6f 66 20 22 70 75 62 6b 65 79 22 20 69  re of "pubkey" i
18b0: 73 20 73 70 65 63 69 66 69 65 64 20 69 6e 20 50  s specified in P
18c0: 4b 43 53 20 23 31 20 2a 2f 0a 09 72 65 61 64 5f  KCS #1 */..read_
18d0: 72 65 74 20 3d 20 61 73 6e 31 5f 78 35 30 39 5f  ret = asn1_x509_
18e0: 72 65 61 64 5f 61 73 6e 31 5f 6f 62 6a 65 63 74  read_asn1_object
18f0: 28 78 35 30 39 2e 70 75 62 6b 65 79 2e 63 6f 6e  (x509.pubkey.con
1900: 74 65 6e 74 73 2c 20 78 35 30 39 2e 70 75 62 6b  tents, x509.pubk
1910: 65 79 2e 73 69 7a 65 2c 20 26 6e 75 6c 6c 2c 20  ey.size, &null, 
1920: 26 70 75 62 6b 65 79 2c 20 4e 55 4c 4c 29 3b 0a  &pubkey, NULL);.
1930: 09 69 66 20 28 72 65 61 64 5f 72 65 74 20 21 3d  .if (read_ret !=
1940: 20 30 29 20 7b 0a 09 09 72 65 74 75 72 6e 28 2d   0) {...return(-
1950: 31 29 3b 0a 09 7d 0a 0a 09 72 65 61 64 5f 72 65  1);..}...read_re
1960: 74 20 3d 20 61 73 6e 31 5f 78 35 30 39 5f 72 65  t = asn1_x509_re
1970: 61 64 5f 61 73 6e 31 5f 6f 62 6a 65 63 74 28 70  ad_asn1_object(p
1980: 75 62 6b 65 79 2e 63 6f 6e 74 65 6e 74 73 2c 20  ubkey.contents, 
1990: 70 75 62 6b 65 79 2e 73 69 7a 65 2c 20 26 6d 6f  pubkey.size, &mo
19a0: 64 75 6c 75 73 2c 20 26 65 78 70 6f 6e 65 6e 74  dulus, &exponent
19b0: 2c 20 4e 55 4c 4c 29 3b 0a 09 69 66 20 28 72 65  , NULL);..if (re
19c0: 61 64 5f 72 65 74 20 21 3d 20 30 29 20 7b 0a 09  ad_ret != 0) {..
19d0: 09 72 65 74 75 72 6e 28 2d 31 29 3b 0a 09 7d 0a  .return(-1);..}.
19e0: 0a 09 69 66 20 28 6f 75 74 62 75 66 29 20 7b 0a  ..if (outbuf) {.
19f0: 09 09 2a 6f 75 74 62 75 66 20 3d 20 65 78 70 6f  ..*outbuf = expo
1a00: 6e 65 6e 74 2e 63 6f 6e 74 65 6e 74 73 3b 0a 09  nent.contents;..
1a10: 7d 0a 0a 09 72 65 74 75 72 6e 28 65 78 70 6f 6e  }...return(expon
1a20: 65 6e 74 2e 73 69 7a 65 29 3b 0a 7d 0a 0a 73 74  ent.size);.}..st
1a30: 61 74 69 63 20 73 73 69 7a 65 5f 74 20 78 35 30  atic ssize_t x50
1a40: 39 5f 74 6f 5f 6b 65 79 73 69 7a 65 28 76 6f 69  9_to_keysize(voi
1a50: 64 20 2a 78 35 30 39 5f 64 65 72 5f 62 75 66 2c  d *x509_der_buf,
1a60: 20 73 69 7a 65 5f 74 20 78 35 30 39 5f 64 65 72   size_t x509_der
1a70: 5f 62 75 66 5f 6c 65 6e 29 20 7b 0a 09 73 74 72  _buf_len) {..str
1a80: 75 63 74 20 61 73 6e 31 5f 6f 62 6a 65 63 74 20  uct asn1_object 
1a90: 6e 75 6c 6c 2c 20 70 75 62 6b 65 79 2c 20 6d 6f  null, pubkey, mo
1aa0: 64 75 6c 75 73 2c 20 65 78 70 6f 6e 65 6e 74 3b  dulus, exponent;
1ab0: 0a 09 73 74 72 75 63 74 20 78 35 30 39 5f 6f 62  ..struct x509_ob
1ac0: 6a 65 63 74 20 78 35 30 39 3b 0a 09 69 6e 74 20  ject x509;..int 
1ad0: 72 65 61 64 5f 72 65 74 3b 0a 0a 09 72 65 61 64  read_ret;...read
1ae0: 5f 72 65 74 20 3d 20 61 73 6e 31 5f 78 35 30 39  _ret = asn1_x509
1af0: 5f 72 65 61 64 5f 6f 62 6a 65 63 74 28 78 35 30  _read_object(x50
1b00: 39 5f 64 65 72 5f 62 75 66 2c 20 78 35 30 39 5f  9_der_buf, x509_
1b10: 64 65 72 5f 62 75 66 5f 6c 65 6e 2c 20 26 78 35  der_buf_len, &x5
1b20: 30 39 29 3b 0a 09 69 66 20 28 72 65 61 64 5f 72  09);..if (read_r
1b30: 65 74 20 21 3d 20 30 29 20 7b 0a 09 09 72 65 74  et != 0) {...ret
1b40: 75 72 6e 28 2d 31 29 3b 0a 09 7d 0a 0a 09 2f 2a  urn(-1);..}.../*
1b50: 20 54 68 65 20 73 74 72 75 63 74 75 72 65 20 6f   The structure o
1b60: 66 20 22 70 75 62 6b 65 79 22 20 69 73 20 73 70  f "pubkey" is sp
1b70: 65 63 69 66 69 65 64 20 69 6e 20 50 4b 43 53 20  ecified in PKCS 
1b80: 23 31 20 2a 2f 0a 09 72 65 61 64 5f 72 65 74 20  #1 */..read_ret 
1b90: 3d 20 61 73 6e 31 5f 78 35 30 39 5f 72 65 61 64  = asn1_x509_read
1ba0: 5f 61 73 6e 31 5f 6f 62 6a 65 63 74 28 78 35 30  _asn1_object(x50
1bb0: 39 2e 70 75 62 6b 65 79 2e 63 6f 6e 74 65 6e 74  9.pubkey.content
1bc0: 73 2c 20 78 35 30 39 2e 70 75 62 6b 65 79 2e 73  s, x509.pubkey.s
1bd0: 69 7a 65 2c 20 26 6e 75 6c 6c 2c 20 26 70 75 62  ize, &null, &pub
1be0: 6b 65 79 2c 20 4e 55 4c 4c 29 3b 0a 09 69 66 20  key, NULL);..if 
1bf0: 28 72 65 61 64 5f 72 65 74 20 21 3d 20 30 29 20  (read_ret != 0) 
1c00: 7b 0a 09 09 72 65 74 75 72 6e 28 2d 31 29 3b 0a  {...return(-1);.
1c10: 09 7d 0a 0a 09 72 65 61 64 5f 72 65 74 20 3d 20  .}...read_ret = 
1c20: 61 73 6e 31 5f 78 35 30 39 5f 72 65 61 64 5f 61  asn1_x509_read_a
1c30: 73 6e 31 5f 6f 62 6a 65 63 74 28 70 75 62 6b 65  sn1_object(pubke
1c40: 79 2e 63 6f 6e 74 65 6e 74 73 2c 20 70 75 62 6b  y.contents, pubk
1c50: 65 79 2e 73 69 7a 65 2c 20 26 6d 6f 64 75 6c 75  ey.size, &modulu
1c60: 73 2c 20 26 65 78 70 6f 6e 65 6e 74 2c 20 4e 55  s, &exponent, NU
1c70: 4c 4c 29 3b 0a 09 69 66 20 28 72 65 61 64 5f 72  LL);..if (read_r
1c80: 65 74 20 21 3d 20 30 29 20 7b 0a 09 09 72 65 74  et != 0) {...ret
1c90: 75 72 6e 28 2d 31 29 3b 0a 09 7d 0a 0a 09 72 65  urn(-1);..}...re
1ca0: 74 75 72 6e 28 6d 6f 64 75 6c 75 73 2e 73 69 7a  turn(modulus.siz
1cb0: 65 20 2d 20 31 29 3b 0a 7d 0a 0a 2f 2a 0a 20 2a  e - 1);.}../*. *
1cc0: 20 68 74 74 70 3a 2f 2f 77 77 77 2e 62 6c 61 63   http://www.blac
1cd0: 6b 62 65 72 72 79 2e 63 6f 6d 2f 64 65 76 65 6c  kberry.com/devel
1ce0: 6f 70 65 72 73 2f 64 6f 63 73 2f 34 2e 36 2e 30  opers/docs/4.6.0
1cf0: 61 70 69 2f 6a 61 76 61 78 2f 6d 69 63 72 6f 65  api/javax/microe
1d00: 64 69 74 69 6f 6e 2f 70 6b 69 2f 43 65 72 74 69  dition/pki/Certi
1d10: 66 69 63 61 74 65 2e 68 74 6d 6c 0a 20 2a 2f 0a  ficate.html. */.
1d20: 73 74 61 74 69 63 20 63 6f 6e 73 74 20 63 68 61  static const cha
1d30: 72 20 2a 5f 78 35 30 39 5f 6f 62 6a 65 63 74 69  r *_x509_objecti
1d40: 64 5f 74 6f 5f 6c 61 62 65 6c 5f 73 74 72 69 6e  d_to_label_strin
1d50: 67 28 76 6f 69 64 20 2a 62 75 66 2c 20 73 69 7a  g(void *buf, siz
1d60: 65 5f 74 20 62 75 66 6c 65 6e 29 20 7b 0a 09 73  e_t buflen) {..s
1d70: 77 69 74 63 68 20 28 62 75 66 6c 65 6e 29 20 7b  witch (buflen) {
1d80: 0a 09 09 63 61 73 65 20 33 3a 0a 09 09 09 69 66  ...case 3:....if
1d90: 20 28 6d 65 6d 63 6d 70 28 62 75 66 2c 20 22 5c   (memcmp(buf, "\
1da0: 78 35 35 5c 78 30 34 5c 78 30 33 22 2c 20 33 29  x55\x04\x03", 3)
1db0: 20 3d 3d 20 30 29 20 7b 0a 09 09 09 09 72 65 74   == 0) {.....ret
1dc0: 75 72 6e 28 22 43 4e 22 29 3b 0a 09 09 09 7d 0a  urn("CN");....}.
1dd0: 09 09 09 69 66 20 28 6d 65 6d 63 6d 70 28 62 75  ...if (memcmp(bu
1de0: 66 2c 20 22 5c 78 35 35 5c 78 30 34 5c 78 30 34  f, "\x55\x04\x04
1df0: 22 2c 20 33 29 20 3d 3d 20 30 29 20 7b 0a 09 09  ", 3) == 0) {...
1e00: 09 09 72 65 74 75 72 6e 28 22 53 4e 22 29 3b 0a  ..return("SN");.
1e10: 09 09 09 7d 0a 09 09 09 69 66 20 28 6d 65 6d 63  ...}....if (memc
1e20: 6d 70 28 62 75 66 2c 20 22 5c 78 35 35 5c 78 30  mp(buf, "\x55\x0
1e30: 34 5c 78 30 36 22 2c 20 33 29 20 3d 3d 20 30 29  4\x06", 3) == 0)
1e40: 20 7b 0a 09 09 09 09 72 65 74 75 72 6e 28 22 43   {.....return("C
1e50: 22 29 3b 0a 09 09 09 7d 0a 09 09 09 69 66 20 28  ");....}....if (
1e60: 6d 65 6d 63 6d 70 28 62 75 66 2c 20 22 5c 78 35  memcmp(buf, "\x5
1e70: 35 5c 78 30 34 5c 78 30 37 22 2c 20 33 29 20 3d  5\x04\x07", 3) =
1e80: 3d 20 30 29 20 7b 0a 09 09 09 09 72 65 74 75 72  = 0) {.....retur
1e90: 6e 28 22 4c 22 29 3b 0a 09 09 09 7d 0a 09 09 09  n("L");....}....
1ea0: 69 66 20 28 6d 65 6d 63 6d 70 28 62 75 66 2c 20  if (memcmp(buf, 
1eb0: 22 5c 78 35 35 5c 78 30 34 5c 78 30 38 22 2c 20  "\x55\x04\x08", 
1ec0: 33 29 20 3d 3d 20 30 29 20 7b 0a 09 09 09 09 72  3) == 0) {.....r
1ed0: 65 74 75 72 6e 28 22 53 54 22 29 3b 0a 09 09 09  eturn("ST");....
1ee0: 7d 0a 09 09 09 69 66 20 28 6d 65 6d 63 6d 70 28  }....if (memcmp(
1ef0: 62 75 66 2c 20 22 5c 78 35 35 5c 78 30 34 5c 78  buf, "\x55\x04\x
1f00: 30 39 22 2c 20 33 29 20 3d 3d 20 30 29 20 7b 0a  09", 3) == 0) {.
1f10: 09 09 09 09 72 65 74 75 72 6e 28 22 53 54 52 45  ....return("STRE
1f20: 45 54 22 29 3b 0a 09 09 09 7d 0a 09 09 09 69 66  ET");....}....if
1f30: 20 28 6d 65 6d 63 6d 70 28 62 75 66 2c 20 22 5c   (memcmp(buf, "\
1f40: 78 35 35 5c 78 30 34 5c 78 30 41 22 2c 20 33 29  x55\x04\x0A", 3)
1f50: 20 3d 3d 20 30 29 20 7b 0a 09 09 09 09 72 65 74   == 0) {.....ret
1f60: 75 72 6e 28 22 4f 22 29 3b 0a 09 09 09 7d 0a 09  urn("O");....}..
1f70: 09 09 69 66 20 28 6d 65 6d 63 6d 70 28 62 75 66  ..if (memcmp(buf
1f80: 2c 20 22 5c 78 35 35 5c 78 30 34 5c 78 30 42 22  , "\x55\x04\x0B"
1f90: 2c 20 33 29 20 3d 3d 20 30 29 20 7b 0a 09 09 09  , 3) == 0) {....
1fa0: 09 72 65 74 75 72 6e 28 22 4f 55 22 29 3b 0a 09  .return("OU");..
1fb0: 09 09 7d 0a 09 09 09 62 72 65 61 6b 3b 0a 09 09  ..}....break;...
1fc0: 63 61 73 65 20 39 3a 0a 09 09 09 69 66 20 28 6d  case 9:....if (m
1fd0: 65 6d 63 6d 70 28 62 75 66 2c 20 22 5c 78 32 41  emcmp(buf, "\x2A
1fe0: 5c 78 38 36 5c 78 34 38 5c 78 38 36 5c 78 46 37  \x86\x48\x86\xF7
1ff0: 5c 78 30 44 5c 78 30 31 5c 78 30 39 5c 78 30 31  \x0D\x01\x09\x01
2000: 22 2c 20 39 29 20 3d 3d 20 30 29 20 7b 0a 09 09  ", 9) == 0) {...
2010: 09 09 72 65 74 75 72 6e 28 22 45 6d 61 69 6c 41  ..return("EmailA
2020: 64 64 72 65 73 73 22 29 3b 0a 09 09 09 7d 0a 09  ddress");....}..
2030: 09 09 62 72 65 61 6b 3b 0a 09 7d 0a 0a 09 72 65  ..break;..}...re
2040: 74 75 72 6e 28 22 3f 3f 3f 22 29 3b 0a 7d 0a 0a  turn("???");.}..
2050: 73 74 61 74 69 63 20 73 73 69 7a 65 5f 74 20 78  static ssize_t x
2060: 35 30 39 5f 64 6e 5f 74 6f 5f 73 74 72 69 6e 67  509_dn_to_string
2070: 28 76 6f 69 64 20 2a 61 73 6e 31 5f 64 65 72 5f  (void *asn1_der_
2080: 62 75 66 2c 20 73 69 7a 65 5f 74 20 61 73 6e 31  buf, size_t asn1
2090: 5f 64 65 72 5f 62 75 66 5f 6c 65 6e 2c 20 63 68  _der_buf_len, ch
20a0: 61 72 20 2a 6f 75 74 62 75 66 2c 20 73 69 7a 65  ar *outbuf, size
20b0: 5f 74 20 6f 75 74 62 75 66 5f 6c 65 6e 2c 20 63  _t outbuf_len, c
20c0: 68 61 72 20 2a 6d 61 74 63 68 6c 61 62 65 6c 29  har *matchlabel)
20d0: 20 7b 0a 09 73 74 72 75 63 74 20 61 73 6e 31 5f   {..struct asn1_
20e0: 6f 62 6a 65 63 74 20 77 68 6f 6c 65 5f 74 68 69  object whole_thi
20f0: 6e 67 2c 20 63 75 72 72 65 6e 74 5f 73 65 74 2c  ng, current_set,
2100: 20 63 75 72 72 65 6e 74 5f 73 65 71 3b 0a 09 73   current_seq;..s
2110: 74 72 75 63 74 20 61 73 6e 31 5f 6f 62 6a 65 63  truct asn1_objec
2120: 74 20 6c 61 62 65 6c 2c 20 76 61 6c 75 65 3b 0a  t label, value;.
2130: 09 63 6f 6e 73 74 20 63 68 61 72 20 2a 6c 61 62  .const char *lab
2140: 65 6c 5f 73 74 72 3b 0a 09 73 73 69 7a 65 5f 74  el_str;..ssize_t
2150: 20 73 6e 70 72 69 6e 74 66 5f 72 65 74 2c 20 72   snprintf_ret, r
2160: 65 74 76 61 6c 3b 0a 09 63 68 61 72 20 2a 6f 75  etval;..char *ou
2170: 74 62 75 66 5f 73 3b 0a 09 69 6e 74 20 72 65 61  tbuf_s;..int rea
2180: 64 5f 72 65 74 3b 0a 09 69 6e 74 20 6f 66 66 73  d_ret;..int offs
2190: 65 74 3b 0a 0a 09 69 66 20 28 6f 75 74 62 75 66  et;...if (outbuf
21a0: 20 3d 3d 20 4e 55 4c 4c 29 20 7b 0a 09 09 72 65   == NULL) {...re
21b0: 74 75 72 6e 28 2d 31 29 3b 0a 09 7d 0a 0a 09 69  turn(-1);..}...i
21c0: 66 20 28 6f 75 74 62 75 66 5f 6c 65 6e 20 3d 3d  f (outbuf_len ==
21d0: 20 30 20 7c 7c 20 61 73 6e 31 5f 64 65 72 5f 62   0 || asn1_der_b
21e0: 75 66 5f 6c 65 6e 20 3d 3d 20 30 20 7c 7c 20 61  uf_len == 0 || a
21f0: 73 6e 31 5f 64 65 72 5f 62 75 66 20 3d 3d 20 4e  sn1_der_buf == N
2200: 55 4c 4c 29 20 7b 0a 09 09 72 65 74 75 72 6e 28  ULL) {...return(
2210: 30 29 3b 0a 09 7d 0a 0a 09 72 65 61 64 5f 72 65  0);..}...read_re
2220: 74 20 3d 20 61 73 6e 31 5f 78 35 30 39 5f 72 65  t = asn1_x509_re
2230: 61 64 5f 61 73 6e 31 5f 6f 62 6a 65 63 74 28 61  ad_asn1_object(a
2240: 73 6e 31 5f 64 65 72 5f 62 75 66 2c 20 61 73 6e  sn1_der_buf, asn
2250: 31 5f 64 65 72 5f 62 75 66 5f 6c 65 6e 2c 20 26  1_der_buf_len, &
2260: 77 68 6f 6c 65 5f 74 68 69 6e 67 2c 20 4e 55 4c  whole_thing, NUL
2270: 4c 29 3b 0a 09 69 66 20 28 72 65 61 64 5f 72 65  L);..if (read_re
2280: 74 20 21 3d 20 30 29 20 7b 0a 09 09 72 65 74 75  t != 0) {...retu
2290: 72 6e 28 2d 31 29 3b 0a 09 7d 0a 0a 09 2f 2a 20  rn(-1);..}.../* 
22a0: 54 65 72 6d 69 6e 61 74 65 20 73 74 72 69 6e 67  Terminate string
22b0: 2c 20 69 6e 20 63 61 73 65 20 6e 6f 20 76 61 6c  , in case no val
22c0: 69 64 20 65 6c 65 6d 65 6e 74 73 20 61 72 65 20  id elements are 
22d0: 66 6f 75 6e 64 20 77 65 20 73 74 69 6c 6c 20 72  found we still r
22e0: 65 74 75 72 6e 20 61 20 76 61 6c 69 64 20 73 74  eturn a valid st
22f0: 72 69 6e 67 20 2a 2f 0a 09 2a 6f 75 74 62 75 66  ring */..*outbuf
2300: 20 3d 20 27 5c 30 27 3b 0a 09 6f 75 74 62 75 66   = '\0';..outbuf
2310: 5f 73 20 3d 20 6f 75 74 62 75 66 3b 0a 0a 09 6f  _s = outbuf;...o
2320: 66 66 73 65 74 20 3d 20 30 3b 0a 09 77 68 69 6c  ffset = 0;..whil
2330: 65 20 28 31 29 20 7b 0a 09 09 72 65 61 64 5f 72  e (1) {...read_r
2340: 65 74 20 3d 20 61 73 6e 31 5f 78 35 30 39 5f 72  et = asn1_x509_r
2350: 65 61 64 5f 61 73 6e 31 5f 6f 62 6a 65 63 74 28  ead_asn1_object(
2360: 28 28 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20  ((unsigned char 
2370: 2a 29 20 77 68 6f 6c 65 5f 74 68 69 6e 67 2e 63  *) whole_thing.c
2380: 6f 6e 74 65 6e 74 73 29 20 2b 20 6f 66 66 73 65  ontents) + offse
2390: 74 2c 20 77 68 6f 6c 65 5f 74 68 69 6e 67 2e 73  t, whole_thing.s
23a0: 69 7a 65 20 2d 20 6f 66 66 73 65 74 2c 20 26 63  ize - offset, &c
23b0: 75 72 72 65 6e 74 5f 73 65 74 2c 20 4e 55 4c 4c  urrent_set, NULL
23c0: 29 3b 0a 09 09 69 66 20 28 72 65 61 64 5f 72 65  );...if (read_re
23d0: 74 20 21 3d 20 30 29 20 7b 0a 09 09 09 62 72 65  t != 0) {....bre
23e0: 61 6b 3b 0a 09 09 7d 0a 0a 09 09 6f 66 66 73 65  ak;...}....offse
23f0: 74 20 2b 3d 20 63 75 72 72 65 6e 74 5f 73 65 74  t += current_set
2400: 2e 73 69 7a 65 20 2b 20 32 3b 0a 0a 09 09 72 65  .size + 2;....re
2410: 61 64 5f 72 65 74 20 3d 20 61 73 6e 31 5f 78 35  ad_ret = asn1_x5
2420: 30 39 5f 72 65 61 64 5f 61 73 6e 31 5f 6f 62 6a  09_read_asn1_obj
2430: 65 63 74 28 63 75 72 72 65 6e 74 5f 73 65 74 2e  ect(current_set.
2440: 63 6f 6e 74 65 6e 74 73 2c 20 63 75 72 72 65 6e  contents, curren
2450: 74 5f 73 65 74 2e 73 69 7a 65 2c 20 26 63 75 72  t_set.size, &cur
2460: 72 65 6e 74 5f 73 65 71 2c 20 4e 55 4c 4c 29 3b  rent_seq, NULL);
2470: 0a 09 09 69 66 20 28 72 65 61 64 5f 72 65 74 20  ...if (read_ret 
2480: 21 3d 20 30 29 20 7b 0a 09 09 09 62 72 65 61 6b  != 0) {....break
2490: 3b 0a 09 09 7d 0a 0a 09 09 72 65 61 64 5f 72 65  ;...}....read_re
24a0: 74 20 3d 20 61 73 6e 31 5f 78 35 30 39 5f 72 65  t = asn1_x509_re
24b0: 61 64 5f 61 73 6e 31 5f 6f 62 6a 65 63 74 28 63  ad_asn1_object(c
24c0: 75 72 72 65 6e 74 5f 73 65 71 2e 63 6f 6e 74 65  urrent_seq.conte
24d0: 6e 74 73 2c 20 63 75 72 72 65 6e 74 5f 73 65 71  nts, current_seq
24e0: 2e 73 69 7a 65 2c 20 26 6c 61 62 65 6c 2c 20 26  .size, &label, &
24f0: 76 61 6c 75 65 2c 20 4e 55 4c 4c 29 3b 0a 0a 09  value, NULL);...
2500: 09 6c 61 62 65 6c 5f 73 74 72 20 3d 20 5f 78 35  .label_str = _x5
2510: 30 39 5f 6f 62 6a 65 63 74 69 64 5f 74 6f 5f 6c  09_objectid_to_l
2520: 61 62 65 6c 5f 73 74 72 69 6e 67 28 6c 61 62 65  abel_string(labe
2530: 6c 2e 63 6f 6e 74 65 6e 74 73 2c 20 6c 61 62 65  l.contents, labe
2540: 6c 2e 73 69 7a 65 29 3b 0a 0a 09 09 2f 2a 20 49  l.size);..../* I
2550: 66 20 74 68 65 20 75 73 65 72 20 72 65 71 75 65  f the user reque
2560: 73 74 65 64 20 6f 6e 6c 79 20 63 65 72 74 61 69  sted only certai
2570: 6e 20 6c 61 62 65 6c 73 2c 20 65 78 63 6c 75 64  n labels, exclud
2580: 65 20 6f 74 68 65 72 73 20 2a 2f 0a 09 09 69 66  e others */...if
2590: 20 28 6d 61 74 63 68 6c 61 62 65 6c 29 20 7b 0a   (matchlabel) {.
25a0: 09 09 09 69 66 20 28 73 74 72 63 6d 70 28 6d 61  ...if (strcmp(ma
25b0: 74 63 68 6c 61 62 65 6c 2c 20 6c 61 62 65 6c 5f  tchlabel, label_
25c0: 73 74 72 29 20 21 3d 20 30 29 20 7b 0a 09 09 09  str) != 0) {....
25d0: 09 63 6f 6e 74 69 6e 75 65 3b 0a 09 09 09 7d 0a  .continue;....}.
25e0: 09 09 7d 0a 0a 09 09 2f 2a 20 49 66 20 74 68 65  ..}..../* If the
25f0: 20 75 73 65 72 20 72 65 71 75 65 73 74 65 64 20   user requested 
2600: 6f 6e 6c 79 20 63 65 72 74 61 69 6e 20 6c 61 62  only certain lab
2610: 65 6c 73 2c 20 64 6f 6e 27 74 20 69 6e 63 6c 75  els, don't inclu
2620: 64 65 20 74 68 65 6d 20 69 6e 20 74 68 65 20 72  de them in the r
2630: 65 70 6c 79 20 2a 2f 0a 09 09 69 66 20 28 6d 61  eply */...if (ma
2640: 74 63 68 6c 61 62 65 6c 29 20 7b 0a 09 09 09 73  tchlabel) {....s
2650: 6e 70 72 69 6e 74 66 5f 72 65 74 20 3d 20 73 6e  nprintf_ret = sn
2660: 70 72 69 6e 74 66 28 6f 75 74 62 75 66 2c 20 6f  printf(outbuf, o
2670: 75 74 62 75 66 5f 6c 65 6e 2c 20 22 25 2e 2a 73  utbuf_len, "%.*s
2680: 2c 20 22 2c 20 28 75 6e 73 69 67 6e 65 64 20 69  , ", (unsigned i
2690: 6e 74 29 20 76 61 6c 75 65 2e 73 69 7a 65 2c 20  nt) value.size, 
26a0: 28 63 68 61 72 20 2a 29 20 76 61 6c 75 65 2e 63  (char *) value.c
26b0: 6f 6e 74 65 6e 74 73 29 3b 0a 09 09 7d 20 65 6c  ontents);...} el
26c0: 73 65 20 7b 0a 09 09 09 73 6e 70 72 69 6e 74 66  se {....snprintf
26d0: 5f 72 65 74 20 3d 20 73 6e 70 72 69 6e 74 66 28  _ret = snprintf(
26e0: 6f 75 74 62 75 66 2c 20 6f 75 74 62 75 66 5f 6c  outbuf, outbuf_l
26f0: 65 6e 2c 20 22 25 73 3d 25 2e 2a 73 2c 20 22 2c  en, "%s=%.*s, ",
2700: 20 6c 61 62 65 6c 5f 73 74 72 2c 20 28 75 6e 73   label_str, (uns
2710: 69 67 6e 65 64 20 69 6e 74 29 20 76 61 6c 75 65  igned int) value
2720: 2e 73 69 7a 65 2c 20 28 63 68 61 72 20 2a 29 20  .size, (char *) 
2730: 76 61 6c 75 65 2e 63 6f 6e 74 65 6e 74 73 29 3b  value.contents);
2740: 0a 09 09 7d 0a 09 09 69 66 20 28 73 6e 70 72 69  ...}...if (snpri
2750: 6e 74 66 5f 72 65 74 20 3c 20 30 29 20 7b 0a 09  ntf_ret < 0) {..
2760: 09 09 62 72 65 61 6b 3b 0a 09 09 7d 0a 0a 09 09  ..break;...}....
2770: 69 66 20 28 73 6e 70 72 69 6e 74 66 5f 72 65 74  if (snprintf_ret
2780: 20 3e 20 6f 75 74 62 75 66 5f 6c 65 6e 29 20 7b   > outbuf_len) {
2790: 0a 09 09 09 73 6e 70 72 69 6e 74 66 5f 72 65 74  ....snprintf_ret
27a0: 20 3d 20 6f 75 74 62 75 66 5f 6c 65 6e 3b 0a 09   = outbuf_len;..
27b0: 09 7d 0a 0a 09 09 6f 75 74 62 75 66 20 2b 3d 20  .}....outbuf += 
27c0: 73 6e 70 72 69 6e 74 66 5f 72 65 74 3b 0a 09 09  snprintf_ret;...
27d0: 6f 75 74 62 75 66 5f 6c 65 6e 20 2d 3d 20 73 6e  outbuf_len -= sn
27e0: 70 72 69 6e 74 66 5f 72 65 74 3b 0a 0a 09 09 69  printf_ret;....i
27f0: 66 20 28 6f 75 74 62 75 66 5f 6c 65 6e 20 3c 20  f (outbuf_len < 
2800: 32 29 20 7b 0a 09 09 09 62 72 65 61 6b 3b 0a 09  2) {....break;..
2810: 09 7d 0a 09 7d 0a 0a 09 72 65 74 76 61 6c 20 3d  .}..}...retval =
2820: 20 6f 75 74 62 75 66 20 2d 20 6f 75 74 62 75 66   outbuf - outbuf
2830: 5f 73 3b 0a 0a 09 2f 2a 20 52 65 6d 6f 76 65 20  _s;.../* Remove 
2840: 74 72 61 69 6c 69 6e 67 20 22 2c 20 22 20 61 64  trailing ", " ad
2850: 64 65 64 20 62 79 20 63 75 6d 75 6c 61 74 69 76  ded by cumulativ
2860: 65 20 70 72 6f 63 65 73 73 2c 20 69 66 20 66 6f  e process, if fo
2870: 75 6e 64 2e 20 2a 2f 0a 09 69 66 20 28 72 65 74  und. */..if (ret
2880: 76 61 6c 20 3e 20 32 29 20 7b 0a 09 09 69 66 20  val > 2) {...if 
2890: 28 6f 75 74 62 75 66 5f 73 5b 72 65 74 76 61 6c  (outbuf_s[retval
28a0: 20 2d 20 32 5d 20 3d 3d 20 27 2c 27 29 20 7b 0a   - 2] == ',') {.
28b0: 09 09 09 6f 75 74 62 75 66 5f 73 5b 72 65 74 76  ...outbuf_s[retv
28c0: 61 6c 20 2d 20 32 5d 20 3d 20 27 5c 30 27 3b 0a  al - 2] = '\0';.
28d0: 09 09 09 72 65 74 76 61 6c 20 2d 3d 20 32 3b 0a  ...retval -= 2;.
28e0: 09 09 7d 0a 09 7d 0a 0a 09 72 65 74 75 72 6e 28  ..}..}...return(
28f0: 72 65 74 76 61 6c 29 3b 0a 7d 0a                 retval);.}.