t_x509.c revision 7d3d122363e2a85d516db314892f3d6112cb1377
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>
75656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
76656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef OPENSSL_NO_FP_API
77656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint X509_print_fp(FILE *fp, X509 *x)
78656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	{
79656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return X509_print_ex_fp(fp, x, XN_FLAG_COMPAT, X509_FLAG_COMPAT);
80656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
81656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
82656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint X509_print_ex_fp(FILE *fp, X509 *x, unsigned long nmflag, unsigned long cflag)
83656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        {
84656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        BIO *b;
85656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        int ret;
86656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
87656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        if ((b=BIO_new(BIO_s_file())) == NULL)
88656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
89656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		X509err(X509_F_X509_PRINT_EX_FP,ERR_R_BUF_LIB);
90656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project                return(0);
91656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
92656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        BIO_set_fp(b,fp,BIO_NOCLOSE);
93656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        ret=X509_print_ex(b, x, nmflag, cflag);
94656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        BIO_free(b);
95656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        return(ret);
96656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project        }
97656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
98656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
99656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint X509_print(BIO *bp, X509 *x)
100656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project{
101656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return X509_print_ex(bp, x, XN_FLAG_COMPAT, X509_FLAG_COMPAT);
102656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project}
103656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
104656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint X509_print_ex(BIO *bp, X509 *x, unsigned long nmflags, unsigned long cflag)
105656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	{
106656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	long l;
107656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int ret=0,i;
108656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	char *m=NULL,mlch = ' ';
109656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int nmindent = 0;
110656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	X509_CINF *ci;
111656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	ASN1_INTEGER *bs;
112656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	EVP_PKEY *pkey=NULL;
113656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	const char *neg;
114656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
115656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if((nmflags & XN_FLAG_SEP_MASK) == XN_FLAG_SEP_MULTILINE) {
116656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			mlch = '\n';
117656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			nmindent = 12;
118656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
119656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
120656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(nmflags == X509_FLAG_COMPAT)
121656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		nmindent = 16;
122656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
123656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	ci=x->cert_info;
124656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_HEADER))
125656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
126656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"Certificate:\n",13) <= 0) goto err;
127656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"    Data:\n",10) <= 0) goto err;
128656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
129656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_VERSION))
130656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
131656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		l=X509_get_version(x);
132656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_printf(bp,"%8sVersion: %lu (0x%lx)\n","",l+1,l) <= 0) goto err;
133656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
134656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_SERIAL))
135656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
136656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
137656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"        Serial Number:",22) <= 0) goto err;
138656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
139656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		bs=X509_get_serialNumber(x);
140656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (bs->length <= 4)
141656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
142656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			l=ASN1_INTEGER_get(bs);
1437d3d122363e2a85d516db314892f3d6112cb1377Brian Carlstrom			if (bs->type == V_ASN1_NEG_INTEGER)
144656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				{
145656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				l= -l;
146656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				neg="-";
147656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				}
148656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			else
149656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				neg="";
150656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (BIO_printf(bp," %s%lu (%s0x%lx)\n",neg,l,neg,l) <= 0)
151656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				goto err;
152656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
153656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else
154656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
155656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			neg=(bs->type == V_ASN1_NEG_INTEGER)?" (Negative)":"";
156656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (BIO_printf(bp,"\n%12s%s","",neg) <= 0) goto err;
157656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
158656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			for (i=0; i<bs->length; i++)
159656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				{
160656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				if (BIO_printf(bp,"%02x%c",bs->data[i],
161656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					((i+1 == bs->length)?'\n':':')) <= 0)
162656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					goto err;
163656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				}
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	if(!(cflag & X509_FLAG_NO_SIGNAME))
169656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
170656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_printf(bp,"%8sSignature Algorithm: ","") <= 0)
171656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto err;
172656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (i2a_ASN1_OBJECT(bp, ci->signature->algorithm) <= 0)
173656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto err;
174656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_puts(bp, "\n") <= 0)
175656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto err;
176656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
177656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
178656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_ISSUER))
179656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
180656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_printf(bp,"        Issuer:%c",mlch) <= 0) goto err;
181656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (X509_NAME_print_ex(bp,X509_get_issuer_name(x),nmindent, nmflags) < 0) goto err;
182656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"\n",1) <= 0) goto err;
183656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
184656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_VALIDITY))
185656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
186656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"        Validity\n",17) <= 0) goto err;
187656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"            Not Before: ",24) <= 0) goto err;
188656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (!ASN1_TIME_print(bp,X509_get_notBefore(x))) goto err;
189656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"\n            Not After : ",25) <= 0) goto err;
190656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (!ASN1_TIME_print(bp,X509_get_notAfter(x))) goto err;
191656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"\n",1) <= 0) goto err;
192656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
193656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_SUBJECT))
194656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
195656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_printf(bp,"        Subject:%c",mlch) <= 0) goto err;
196656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (X509_NAME_print_ex(bp,X509_get_subject_name(x),nmindent, nmflags) < 0) goto err;
197656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"\n",1) <= 0) goto err;
198656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
199656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_PUBKEY))
200656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
201656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,"        Subject Public Key Info:\n",33) <= 0)
202656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto err;
203656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_printf(bp,"%12sPublic Key Algorithm: ","") <= 0)
204656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto err;
205656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (i2a_ASN1_OBJECT(bp, ci->key->algor->algorithm) <= 0)
206656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto err;
207656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_puts(bp, "\n") <= 0)
208656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto err;
209656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
210656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		pkey=X509_get_pubkey(x);
211656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (pkey == NULL)
212656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
213656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			BIO_printf(bp,"%12sUnable to load Public Key\n","");
214656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			ERR_print_errors(bp);
215656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
216656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else
217656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
218221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstrom			EVP_PKEY_print_public(bp, pkey, 16, NULL);
219221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstrom			EVP_PKEY_free(pkey);
220656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
221656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
222656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
223656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (!(cflag & X509_FLAG_NO_EXTENSIONS))
224656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		X509V3_extensions_print(bp, "X509v3 extensions",
225656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					ci->extensions, cflag, 8);
226656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
227656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_SIGDUMP))
228656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
229656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if(X509_signature_print(bp, x->sig_alg, x->signature) <= 0) goto err;
230656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
231656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(!(cflag & X509_FLAG_NO_AUX))
232656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
233656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (!X509_CERT_AUX_print(bp, x->aux, 0)) goto err;
234656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
235656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	ret=1;
236656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projecterr:
237656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (m != NULL) OPENSSL_free(m);
238656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return(ret);
239656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
240656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
241656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint X509_ocspid_print (BIO *bp, X509 *x)
242656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	{
243656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	unsigned char *der=NULL ;
244656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	unsigned char *dertmp;
245656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int derlen;
246656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int i;
247656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	unsigned char SHA1md[SHA_DIGEST_LENGTH];
248656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
249656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	/* display the hash of the subject as it would appear
250656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	   in OCSP requests */
251656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (BIO_printf(bp,"        Subject OCSP hash: ") <= 0)
252656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		goto err;
253656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	derlen = i2d_X509_NAME(x->cert_info->subject, NULL);
254656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if ((der = dertmp = (unsigned char *)OPENSSL_malloc (derlen)) == NULL)
255656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		goto err;
256656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	i2d_X509_NAME(x->cert_info->subject, &dertmp);
257656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
258656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	EVP_Digest(der, derlen, SHA1md, NULL, EVP_sha1(), NULL);
259656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	for (i=0; i < SHA_DIGEST_LENGTH; i++)
260656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
261656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_printf(bp,"%02X",SHA1md[i]) <= 0) goto err;
262656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
263656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	OPENSSL_free (der);
264656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	der=NULL;
265656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
266656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	/* display the hash of the public key as it would appear
267656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	   in OCSP requests */
268656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (BIO_printf(bp,"\n        Public key OCSP hash: ") <= 0)
269656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		goto err;
270656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
271656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	EVP_Digest(x->cert_info->key->public_key->data,
272656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		x->cert_info->key->public_key->length, SHA1md, NULL, EVP_sha1(), NULL);
273656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	for (i=0; i < SHA_DIGEST_LENGTH; i++)
274656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
275656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_printf(bp,"%02X",SHA1md[i]) <= 0)
276656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			goto err;
277656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
278656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	BIO_printf(bp,"\n");
279656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
280656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return (1);
281656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projecterr:
282656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (der != NULL) OPENSSL_free(der);
283656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return(0);
284656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
285656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
286656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint X509_signature_print(BIO *bp, X509_ALGOR *sigalg, ASN1_STRING *sig)
287656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project{
288656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	unsigned char *s;
289656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int i, n;
290656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (BIO_puts(bp,"    Signature Algorithm: ") <= 0) return 0;
291656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (i2a_ASN1_OBJECT(bp, sigalg->algorithm) <= 0) return 0;
292656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
293656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	n=sig->length;
294656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	s=sig->data;
295656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	for (i=0; i<n; i++)
296656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
297656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if ((i%18) == 0)
298656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (BIO_write(bp,"\n        ",9) <= 0) return 0;
299656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (BIO_printf(bp,"%02x%s",s[i],
300656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				((i+1) == n)?"":":") <= 0) return 0;
301656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
302656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (BIO_write(bp,"\n",1) != 1) return 0;
303656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return 1;
304656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project}
305656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
306221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstromint ASN1_STRING_print(BIO *bp, const ASN1_STRING *v)
307656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	{
308656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int i,n;
309221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstrom	char buf[80];
310221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstrom	const char *p;
311656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
312656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (v == NULL) return(0);
313656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	n=0;
314221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstrom	p=(const char *)v->data;
315656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	for (i=0; i<v->length; i++)
316656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
317656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if ((p[i] > '~') || ((p[i] < ' ') &&
318656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			(p[i] != '\n') && (p[i] != '\r')))
319656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			buf[n]='.';
320656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		else
321656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			buf[n]=p[i];
322656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		n++;
323656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (n >= 80)
324656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
325656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (BIO_write(bp,buf,n) <= 0)
326656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				return(0);
327656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			n=0;
328656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
329656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
330656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (n > 0)
331656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (BIO_write(bp,buf,n) <= 0)
332656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			return(0);
333656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return(1);
334656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
335656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
336221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstromint ASN1_TIME_print(BIO *bp, const ASN1_TIME *tm)
337656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project{
338656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(tm->type == V_ASN1_UTCTIME) return ASN1_UTCTIME_print(bp, tm);
339656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if(tm->type == V_ASN1_GENERALIZEDTIME)
340656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				return ASN1_GENERALIZEDTIME_print(bp, tm);
341656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	BIO_write(bp,"Bad time value",14);
342656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return(0);
343656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project}
344656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
345656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectstatic const char *mon[12]=
346656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project    {
347656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project    "Jan","Feb","Mar","Apr","May","Jun",
348656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project    "Jul","Aug","Sep","Oct","Nov","Dec"
349656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project    };
350656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
351221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstromint ASN1_GENERALIZEDTIME_print(BIO *bp, const ASN1_GENERALIZEDTIME *tm)
352656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	{
353656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	char *v;
354656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int gmt=0;
355656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int i;
356656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int y=0,M=0,d=0,h=0,m=0,s=0;
35798d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom	char *f = NULL;
35898d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom	int f_len = 0;
359656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
360656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	i=tm->length;
361656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	v=(char *)tm->data;
362656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
363656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (i < 12) goto err;
364656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (v[i-1] == 'Z') gmt=1;
365656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	for (i=0; i<12; i++)
366656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if ((v[i] > '9') || (v[i] < '0')) goto err;
367656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	y= (v[0]-'0')*1000+(v[1]-'0')*100 + (v[2]-'0')*10+(v[3]-'0');
368656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	M= (v[4]-'0')*10+(v[5]-'0');
369656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if ((M > 12) || (M < 1)) goto err;
370656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	d= (v[6]-'0')*10+(v[7]-'0');
371656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	h= (v[8]-'0')*10+(v[9]-'0');
372656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	m=  (v[10]-'0')*10+(v[11]-'0');
373e45f106cb6b47af1f21efe76e933bdea2f5dd1caNagendra Modadugu	if (tm->length >= 14 &&
374e45f106cb6b47af1f21efe76e933bdea2f5dd1caNagendra Modadugu	    (v[12] >= '0') && (v[12] <= '9') &&
375e45f106cb6b47af1f21efe76e933bdea2f5dd1caNagendra Modadugu	    (v[13] >= '0') && (v[13] <= '9'))
37698d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom		{
377656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		s=  (v[12]-'0')*10+(v[13]-'0');
37898d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom		/* Check for fractions of seconds. */
37998d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom		if (tm->length >= 15 && v[14] == '.')
38098d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom			{
38198d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom			int l = tm->length;
38298d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom			f = &v[14];	/* The decimal point. */
38398d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom			f_len = 1;
38498d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom			while (14 + f_len < l && f[f_len] >= '0' && f[f_len] <= '9')
38598d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom				++f_len;
38698d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom			}
38798d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom		}
388656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
38998d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom	if (BIO_printf(bp,"%s %2d %02d:%02d:%02d%.*s %d%s",
39098d58bb80c64b02a33662f0ea80351d4a1535267Brian Carlstrom		mon[M-1],d,h,m,s,f_len,f,y,(gmt)?" GMT":"") <= 0)
391656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		return(0);
392656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	else
393656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		return(1);
394656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projecterr:
395656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	BIO_write(bp,"Bad time value",14);
396656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return(0);
397656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
398656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
399221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstromint ASN1_UTCTIME_print(BIO *bp, const ASN1_UTCTIME *tm)
400656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	{
401221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstrom	const char *v;
402656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int gmt=0;
403656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int i;
404656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int y=0,M=0,d=0,h=0,m=0,s=0;
405656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
406656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	i=tm->length;
407221304ee937bc0910948a8be1320cb8cc4eb6d36Brian Carlstrom	v=(const char *)tm->data;
408656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
409656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (i < 10) goto err;
410656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (v[i-1] == 'Z') gmt=1;
411656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	for (i=0; i<10; i++)
412656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if ((v[i] > '9') || (v[i] < '0')) goto err;
413656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	y= (v[0]-'0')*10+(v[1]-'0');
414656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (y < 50) y+=100;
415656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	M= (v[2]-'0')*10+(v[3]-'0');
416656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if ((M > 12) || (M < 1)) goto err;
417656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	d= (v[4]-'0')*10+(v[5]-'0');
418656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	h= (v[6]-'0')*10+(v[7]-'0');
419656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	m=  (v[8]-'0')*10+(v[9]-'0');
420e45f106cb6b47af1f21efe76e933bdea2f5dd1caNagendra Modadugu	if (tm->length >=12 &&
421e45f106cb6b47af1f21efe76e933bdea2f5dd1caNagendra Modadugu	    (v[10] >= '0') && (v[10] <= '9') &&
422e45f106cb6b47af1f21efe76e933bdea2f5dd1caNagendra Modadugu	    (v[11] >= '0') && (v[11] <= '9'))
423656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		s=  (v[10]-'0')*10+(v[11]-'0');
424656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
425656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (BIO_printf(bp,"%s %2d %02d:%02d:%02d %d%s",
426656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		mon[M-1],d,h,m,s,y+1900,(gmt)?" GMT":"") <= 0)
427656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		return(0);
428656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	else
429656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		return(1);
430656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projecterr:
431656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	BIO_write(bp,"Bad time value",14);
432656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return(0);
433656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
434656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
435656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projectint X509_NAME_print(BIO *bp, X509_NAME *name, int obase)
436656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	{
437656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	char *s,*c,*b;
438656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	int ret=0,l,i;
439656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
440656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	l=80-2-obase;
441656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
442656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	b=X509_NAME_oneline(name,NULL,0);
443656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (!*b)
444656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
445656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		OPENSSL_free(b);
446656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		return 1;
447656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
448656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	s=b+1; /* skip the first slash */
449656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
450656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	c=s;
451656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	for (;;)
452656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
453656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#ifndef CHARSET_EBCDIC
454656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (	((*s == '/') &&
455656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				((s[1] >= 'A') && (s[1] <= 'Z') && (
456656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					(s[2] == '=') ||
457656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					((s[2] >= 'A') && (s[2] <= 'Z') &&
458656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					(s[3] == '='))
459656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				 ))) ||
460656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			(*s == '\0'))
461656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#else
462656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (	((*s == '/') &&
463656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				(isupper(s[1]) && (
464656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					(s[2] == '=') ||
465656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					(isupper(s[2]) &&
466656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project					(s[3] == '='))
467656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				 ))) ||
468656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			(*s == '\0'))
469656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project#endif
470656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			{
471656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			i=s-c;
472656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (BIO_write(bp,c,i) != i) goto err;
473656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			c=s+1;	/* skip following slash */
474656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			if (*s != '\0')
475656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				{
476656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				if (BIO_write(bp,", ",2) != 2) goto err;
477656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project				}
478656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			l--;
479656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project			}
480656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		if (*s == '\0') break;
481656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		s++;
482656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		l--;
483656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
484656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project
485656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	ret=1;
486656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	if (0)
487656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		{
488656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Projecterr:
489656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		X509err(X509_F_X509_NAME_PRINT,ERR_R_BUF_LIB);
490656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project		}
491656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	OPENSSL_free(b);
492656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	return(ret);
493656d9c7f52f88b3a3daccafa7655dec086c4756eThe Android Open Source Project	}
494