1656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project/* crypto/asn1/t_x509.c */
2656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
3656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * All rights reserved.
4656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
5656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * This package is an SSL implementation written
6656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * by Eric Young (eay@cryptsoft.com).
7656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * The implementation was written so as to conform with Netscapes SSL.
8656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
9656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * This library is free for commercial and non-commercial use as long as
10656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * the following conditions are aheared to.  The following conditions
11656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * apply to all code found in this distribution, be it the RC4, RSA,
12656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * lhash, DES, etc., code; not just the SSL code.  The SSL documentation
13656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * included with this distribution is covered by the same copyright terms
14656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * except that the holder is Tim Hudson (tjh@cryptsoft.com).
15656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
16656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * Copyright remains Eric Young's, and as such any Copyright notices in
17656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * the code are not to be removed.
18656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * If this package is used in a product, Eric Young should be given attribution
19656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * as the author of the parts of the library used.
20656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * This can be in the form of a textual message at program startup or
21656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * in documentation (online or textual) provided with the package.
22656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
23656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * Redistribution and use in source and binary forms, with or without
24656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * modification, are permitted provided that the following conditions
25656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * are met:
26656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * 1. Redistributions of source code must retain the copyright
27656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    notice, this list of conditions and the following disclaimer.
28656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * 2. Redistributions in binary form must reproduce the above copyright
29656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    notice, this list of conditions and the following disclaimer in the
30656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    documentation and/or other materials provided with the distribution.
31656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * 3. All advertising materials mentioning features or use of this software
32656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    must display the following acknowledgement:
33656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    "This product includes cryptographic software written by
34656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *     Eric Young (eay@cryptsoft.com)"
35656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    The word 'cryptographic' can be left out if the rouines from the library
36656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    being used are not cryptographic related :-).
37656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * 4. If you include any Windows specific code (or a derivative thereof) from
38656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    the apps directory (application code) you must include an acknowledgement:
39656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *    "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
40656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
41656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
42656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
43656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
44656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
45656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
46656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
47656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
48656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
49656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
50656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
51656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * SUCH DAMAGE.
52656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project *
53656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * The licence and distribution terms for any publically available version or
54656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * derivative of this code cannot be changed.  i.e. this code cannot simply be
55656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * copied and put under another distribution licence
56656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project * [including the GNU Public Licence.]
57656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project */
58656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
59656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <stdio.h>
60656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include "cryptlib.h"
61656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <openssl/buffer.h>
62656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <openssl/bn.h>
63656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_RSA
64656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <openssl/rsa.h>
65656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
66656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_DSA
67656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <openssl/dsa.h>
68656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
69656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_EC
70656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <openssl/ec.h>
71656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
72656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <openssl/objects.h>
73656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <openssl/x509.h>
74656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#include <openssl/x509v3.h>
75392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom#include "asn1_locl.h"
76656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
77656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_FP_API
78656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint X509_print_fp(FILE *fp, X509 *x)
79656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	{
80656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return X509_print_ex_fp(fp, x, XN_FLAG_COMPAT, X509_FLAG_COMPAT);
81656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
82656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
83656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint X509_print_ex_fp(FILE *fp, X509 *x, unsigned long nmflag, unsigned long cflag)
84656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        {
85656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        BIO *b;
86656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        int ret;
87656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
88656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        if ((b=BIO_new(BIO_s_file())) == NULL)
89656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
90656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		X509err(X509_F_X509_PRINT_EX_FP,ERR_R_BUF_LIB);
91656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project                return(0);
92656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
93656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        BIO_set_fp(b,fp,BIO_NOCLOSE);
94656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        ret=X509_print_ex(b, x, nmflag, cflag);
95656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        BIO_free(b);
96656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        return(ret);
97656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        }
98656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
99656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
100656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint X509_print(BIO *bp, X509 *x)
101656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project{
102656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return X509_print_ex(bp, x, XN_FLAG_COMPAT, X509_FLAG_COMPAT);
103656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project}
104656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
105656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint X509_print_ex(BIO *bp, X509 *x, unsigned long nmflags, unsigned long cflag)
106656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	{
107656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	long l;
108656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int ret=0,i;
109656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	char *m=NULL,mlch = ' ';
110656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int nmindent = 0;
111656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	X509_CINF *ci;
112656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	ASN1_INTEGER *bs;
113656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	EVP_PKEY *pkey=NULL;
114656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	const char *neg;
115656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
116656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if((nmflags & XN_FLAG_SEP_MASK) == XN_FLAG_SEP_MULTILINE) {
117656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			mlch = '\n';
118656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			nmindent = 12;
119656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
120656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
121656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(nmflags == X509_FLAG_COMPAT)
122656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		nmindent = 16;
123656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
124656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	ci=x->cert_info;
125656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_HEADER))
126656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
127656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"Certificate:\n",13) <= 0) goto err;
128656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"    Data:\n",10) <= 0) goto err;
129656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
130656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_VERSION))
131656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
132656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		l=X509_get_version(x);
133656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_printf(bp,"%8sVersion: %lu (0x%lx)\n","",l+1,l) <= 0) goto err;
134656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
135656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_SERIAL))
136656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
137656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
138656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"        Serial Number:",22) <= 0) goto err;
139656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
140656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		bs=X509_get_serialNumber(x);
141392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom		if (bs->length <= (int)sizeof(long))
142656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
143656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			l=ASN1_INTEGER_get(bs);
1447d3d122363e2a85d516db314892f3d6112cb1377Brian Carlstrom			if (bs->type == V_ASN1_NEG_INTEGER)
145656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				{
146656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				l= -l;
147656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				neg="-";
148656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				}
149656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			else
150656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				neg="";
151656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (BIO_printf(bp," %s%lu (%s0x%lx)\n",neg,l,neg,l) <= 0)
152656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				goto err;
153656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
154656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else
155656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
156656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			neg=(bs->type == V_ASN1_NEG_INTEGER)?" (Negative)":"";
157656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (BIO_printf(bp,"\n%12s%s","",neg) <= 0) goto err;
158656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
159656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			for (i=0; i<bs->length; i++)
160656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				{
161656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				if (BIO_printf(bp,"%02x%c",bs->data[i],
162656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					((i+1 == bs->length)?'\n':':')) <= 0)
163656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					goto err;
164656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				}
165656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
166656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
167656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
168656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
169656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_SIGNAME))
170656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
171392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom		if(X509_signature_print(bp, x->sig_alg, NULL) <= 0)
172392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom			goto err;
173392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom#if 0
174656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_printf(bp,"%8sSignature Algorithm: ","") <= 0)
175656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto err;
176656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (i2a_ASN1_OBJECT(bp, ci->signature->algorithm) <= 0)
177656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto err;
178656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_puts(bp, "\n") <= 0)
179656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto err;
180392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom#endif
181656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
182656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
183656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_ISSUER))
184656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
185656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_printf(bp,"        Issuer:%c",mlch) <= 0) goto err;
186656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (X509_NAME_print_ex(bp,X509_get_issuer_name(x),nmindent, nmflags) < 0) goto err;
187656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"\n",1) <= 0) goto err;
188656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
189656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_VALIDITY))
190656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
191656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"        Validity\n",17) <= 0) goto err;
192656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"            Not Before: ",24) <= 0) goto err;
193656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (!ASN1_TIME_print(bp,X509_get_notBefore(x))) goto err;
194656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"\n            Not After : ",25) <= 0) goto err;
195656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (!ASN1_TIME_print(bp,X509_get_notAfter(x))) goto err;
196656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"\n",1) <= 0) goto err;
197656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
198656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_SUBJECT))
199656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
200656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_printf(bp,"        Subject:%c",mlch) <= 0) goto err;
201656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (X509_NAME_print_ex(bp,X509_get_subject_name(x),nmindent, nmflags) < 0) goto err;
202656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"\n",1) <= 0) goto err;
203656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
204656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_PUBKEY))
205656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
206656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"        Subject Public Key Info:\n",33) <= 0)
207656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto err;
208656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_printf(bp,"%12sPublic Key Algorithm: ","") <= 0)
209656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto err;
210656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (i2a_ASN1_OBJECT(bp, ci->key->algor->algorithm) <= 0)
211656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto err;
212656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_puts(bp, "\n") <= 0)
213656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto err;
214656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
215656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		pkey=X509_get_pubkey(x);
216656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (pkey == NULL)
217656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
218656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			BIO_printf(bp,"%12sUnable to load Public Key\n","");
219656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			ERR_print_errors(bp);
220656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
221656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else
222656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
223221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstrom			EVP_PKEY_print_public(bp, pkey, 16, NULL);
224221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstrom			EVP_PKEY_free(pkey);
225656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
226656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
227656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
228656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (!(cflag & X509_FLAG_NO_EXTENSIONS))
229656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		X509V3_extensions_print(bp, "X509v3 extensions",
230656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					ci->extensions, cflag, 8);
231656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
232656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_SIGDUMP))
233656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
234656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if(X509_signature_print(bp, x->sig_alg, x->signature) <= 0) goto err;
235656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
236656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_AUX))
237656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
238656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (!X509_CERT_AUX_print(bp, x->aux, 0)) goto err;
239656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
240656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	ret=1;
241656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projecterr:
242656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (m != NULL) OPENSSL_free(m);
243656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return(ret);
244656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
245656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
246656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint X509_ocspid_print (BIO *bp, X509 *x)
247656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	{
248656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	unsigned char *der=NULL ;
249656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	unsigned char *dertmp;
250656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int derlen;
251656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int i;
252656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	unsigned char SHA1md[SHA_DIGEST_LENGTH];
253656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
254656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	/* display the hash of the subject as it would appear
255656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	   in OCSP requests */
256656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (BIO_printf(bp,"        Subject OCSP hash: ") <= 0)
257656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		goto err;
258656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	derlen = i2d_X509_NAME(x->cert_info->subject, NULL);
259656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if ((der = dertmp = (unsigned char *)OPENSSL_malloc (derlen)) == NULL)
260656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		goto err;
261656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	i2d_X509_NAME(x->cert_info->subject, &dertmp);
262656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
263392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom	if (!EVP_Digest(der, derlen, SHA1md, NULL, EVP_sha1(), NULL))
264392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom		goto err;
265656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	for (i=0; i < SHA_DIGEST_LENGTH; i++)
266656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
267656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_printf(bp,"%02X",SHA1md[i]) <= 0) goto err;
268656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
269656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	OPENSSL_free (der);
270656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	der=NULL;
271656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
272656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	/* display the hash of the public key as it would appear
273656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	   in OCSP requests */
274656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (BIO_printf(bp,"\n        Public key OCSP hash: ") <= 0)
275656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		goto err;
276656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
277392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom	if (!EVP_Digest(x->cert_info->key->public_key->data,
278392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom			x->cert_info->key->public_key->length,
279392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom			SHA1md, NULL, EVP_sha1(), NULL))
280392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom		goto err;
281656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	for (i=0; i < SHA_DIGEST_LENGTH; i++)
282656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
283656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_printf(bp,"%02X",SHA1md[i]) <= 0)
284656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto err;
285656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
286656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	BIO_printf(bp,"\n");
287656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
288656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return (1);
289656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projecterr:
290656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (der != NULL) OPENSSL_free(der);
291656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return(0);
292656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
293656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
294392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstromint X509_signature_dump(BIO *bp, const ASN1_STRING *sig, int indent)
295656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project{
296392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom	const unsigned char *s;
297656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int i, n;
298656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
299656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	n=sig->length;
300656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	s=sig->data;
301656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	for (i=0; i<n; i++)
302656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
303656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if ((i%18) == 0)
304392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom			{
305392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom			if (BIO_write(bp,"\n",1) <= 0) return 0;
306392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom			if (BIO_indent(bp, indent, indent) <= 0) return 0;
307392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom			}
308656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (BIO_printf(bp,"%02x%s",s[i],
309656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				((i+1) == n)?"":":") <= 0) return 0;
310656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
311656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (BIO_write(bp,"\n",1) != 1) return 0;
312392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom
313392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom	return 1;
314392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom}
315392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom
316392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstromint X509_signature_print(BIO *bp, X509_ALGOR *sigalg, ASN1_STRING *sig)
317392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom{
318392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom	int sig_nid;
319392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom	if (BIO_puts(bp,"    Signature Algorithm: ") <= 0) return 0;
320392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom	if (i2a_ASN1_OBJECT(bp, sigalg->algorithm) <= 0) return 0;
321392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom
322392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom	sig_nid = OBJ_obj2nid(sigalg->algorithm);
323392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom	if (sig_nid != NID_undef)
324392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom		{
325392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom		int pkey_nid, dig_nid;
326392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom		const EVP_PKEY_ASN1_METHOD *ameth;
327392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom		if (OBJ_find_sigid_algs(sig_nid, &dig_nid, &pkey_nid))
328392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom			{
329392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom			ameth = EVP_PKEY_asn1_find(NULL, pkey_nid);
330392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom			if (ameth && ameth->sig_print)
331392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom				return ameth->sig_print(bp, sigalg, sig, 9, 0);
332392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom			}
333392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom		}
334392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom	if (sig)
335392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom		return X509_signature_dump(bp, sig, 9);
336392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom	else if (BIO_puts(bp, "\n") <= 0)
337392aa7cc7d2b122614c5393c3e357da07fd07af3Brian Carlstrom		return 0;
338656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return 1;
339656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project}
340656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
341221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstromint ASN1_STRING_print(BIO *bp, const ASN1_STRING *v)
342656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	{
343656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int i,n;
344221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstrom	char buf[80];
345221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstrom	const char *p;
346656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
347656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (v == NULL) return(0);
348656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	n=0;
349221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstrom	p=(const char *)v->data;
350656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	for (i=0; i<v->length; i++)
351656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
352656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if ((p[i] > '~') || ((p[i] < ' ') &&
353656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			(p[i] != '\n') && (p[i] != '\r')))
354656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			buf[n]='.';
355656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else
356656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			buf[n]=p[i];
357656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		n++;
358656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (n >= 80)
359656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
360656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (BIO_write(bp,buf,n) <= 0)
361656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				return(0);
362656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			n=0;
363656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
364656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
365656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (n > 0)
366656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,buf,n) <= 0)
367656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			return(0);
368656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return(1);
369656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
370656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
371221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstromint ASN1_TIME_print(BIO *bp, const ASN1_TIME *tm)
372656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project{
373656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(tm->type == V_ASN1_UTCTIME) return ASN1_UTCTIME_print(bp, tm);
374656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(tm->type == V_ASN1_GENERALIZEDTIME)
375656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				return ASN1_GENERALIZEDTIME_print(bp, tm);
376656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	BIO_write(bp,"Bad time value",14);
377656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return(0);
378656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project}
379656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
380656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectstatic const char *mon[12]=
381656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project    {
382656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project    "Jan","Feb","Mar","Apr","May","Jun",
383656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project    "Jul","Aug","Sep","Oct","Nov","Dec"
384656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project    };
385656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
386221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstromint ASN1_GENERALIZEDTIME_print(BIO *bp, const ASN1_GENERALIZEDTIME *tm)
387656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	{
388656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	char *v;
389656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int gmt=0;
390656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int i;
391656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int y=0,M=0,d=0,h=0,m=0,s=0;
39298d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom	char *f = NULL;
39398d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom	int f_len = 0;
394656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
395656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	i=tm->length;
396656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	v=(char *)tm->data;
397656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
398656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (i < 12) goto err;
399656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (v[i-1] == 'Z') gmt=1;
400656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	for (i=0; i<12; i++)
401656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if ((v[i] > '9') || (v[i] < '0')) goto err;
402656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	y= (v[0]-'0')*1000+(v[1]-'0')*100 + (v[2]-'0')*10+(v[3]-'0');
403656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	M= (v[4]-'0')*10+(v[5]-'0');
404656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if ((M > 12) || (M < 1)) goto err;
405656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	d= (v[6]-'0')*10+(v[7]-'0');
406656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	h= (v[8]-'0')*10+(v[9]-'0');
407656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	m=  (v[10]-'0')*10+(v[11]-'0');
408e45f106cb6b47af1f21efe76e933bdea2f5dd1caNagendra Modadugu	if (tm->length >= 14 &&
409e45f106cb6b47af1f21efe76e933bdea2f5dd1caNagendra Modadugu	    (v[12] >= '0') && (v[12] <= '9') &&
410e45f106cb6b47af1f21efe76e933bdea2f5dd1caNagendra Modadugu	    (v[13] >= '0') && (v[13] <= '9'))
41198d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom		{
412656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		s=  (v[12]-'0')*10+(v[13]-'0');
41398d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom		/* Check for fractions of seconds. */
41498d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom		if (tm->length >= 15 && v[14] == '.')
41598d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom			{
41698d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom			int l = tm->length;
41798d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom			f = &v[14];	/* The decimal point. */
41898d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom			f_len = 1;
41998d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom			while (14 + f_len < l && f[f_len] >= '0' && f[f_len] <= '9')
42098d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom				++f_len;
42198d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom			}
42298d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom		}
423656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
42498d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom	if (BIO_printf(bp,"%s %2d %02d:%02d:%02d%.*s %d%s",
42598d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom		mon[M-1],d,h,m,s,f_len,f,y,(gmt)?" GMT":"") <= 0)
426656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		return(0);
427656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	else
428656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		return(1);
429656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projecterr:
430656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	BIO_write(bp,"Bad time value",14);
431656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return(0);
432656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
433656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
434221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstromint ASN1_UTCTIME_print(BIO *bp, const ASN1_UTCTIME *tm)
435656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	{
436221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstrom	const char *v;
437656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int gmt=0;
438656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int i;
439656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int y=0,M=0,d=0,h=0,m=0,s=0;
440656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
441656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	i=tm->length;
442221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstrom	v=(const char *)tm->data;
443656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
444656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (i < 10) goto err;
445656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (v[i-1] == 'Z') gmt=1;
446656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	for (i=0; i<10; i++)
447656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if ((v[i] > '9') || (v[i] < '0')) goto err;
448656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	y= (v[0]-'0')*10+(v[1]-'0');
449656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (y < 50) y+=100;
450656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	M= (v[2]-'0')*10+(v[3]-'0');
451656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if ((M > 12) || (M < 1)) goto err;
452656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	d= (v[4]-'0')*10+(v[5]-'0');
453656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	h= (v[6]-'0')*10+(v[7]-'0');
454656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	m=  (v[8]-'0')*10+(v[9]-'0');
455e45f106cb6b47af1f21efe76e933bdea2f5dd1caNagendra Modadugu	if (tm->length >=12 &&
456e45f106cb6b47af1f21efe76e933bdea2f5dd1caNagendra Modadugu	    (v[10] >= '0') && (v[10] <= '9') &&
457e45f106cb6b47af1f21efe76e933bdea2f5dd1caNagendra Modadugu	    (v[11] >= '0') && (v[11] <= '9'))
458656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		s=  (v[10]-'0')*10+(v[11]-'0');
459656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
460656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (BIO_printf(bp,"%s %2d %02d:%02d:%02d %d%s",
461656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		mon[M-1],d,h,m,s,y+1900,(gmt)?" GMT":"") <= 0)
462656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		return(0);
463656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	else
464656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		return(1);
465656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projecterr:
466656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	BIO_write(bp,"Bad time value",14);
467656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return(0);
468656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
469656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
470656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint X509_NAME_print(BIO *bp, X509_NAME *name, int obase)
471656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	{
472656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	char *s,*c,*b;
473656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int ret=0,l,i;
474656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
475656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	l=80-2-obase;
476656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
477656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	b=X509_NAME_oneline(name,NULL,0);
478656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (!*b)
479656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
480656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		OPENSSL_free(b);
481656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		return 1;
482656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
483656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	s=b+1; /* skip the first slash */
484656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
485656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	c=s;
486656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	for (;;)
487656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
488656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef CHARSET_EBCDIC
489656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (	((*s == '/') &&
490656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				((s[1] >= 'A') && (s[1] <= 'Z') && (
491656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					(s[2] == '=') ||
492656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					((s[2] >= 'A') && (s[2] <= 'Z') &&
493656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					(s[3] == '='))
494656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				 ))) ||
495656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			(*s == '\0'))
496656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#else
497656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (	((*s == '/') &&
498656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				(isupper(s[1]) && (
499656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					(s[2] == '=') ||
500656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					(isupper(s[2]) &&
501656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					(s[3] == '='))
502656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				 ))) ||
503656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			(*s == '\0'))
504656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
505656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
506656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			i=s-c;
507656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (BIO_write(bp,c,i) != i) goto err;
508656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			c=s+1;	/* skip following slash */
509656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (*s != '\0')
510656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				{
511656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				if (BIO_write(bp,", ",2) != 2) goto err;
512656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				}
513656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			l--;
514656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
515656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (*s == '\0') break;
516656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		s++;
517656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		l--;
518656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
519656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
520656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	ret=1;
521656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (0)
522656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
523656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projecterr:
524656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		X509err(X509_F_X509_NAME_PRINT,ERR_R_BUF_LIB);
525656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
526656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	OPENSSL_free(b);
527656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return(ret);
528656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
529