x509cset.c 6.3 KB
Newer Older
1 2 3
/*
 * Written by Dr Stephen N Henson (steve@openssl.org) for the OpenSSL project
 * 2001.
D
 
Dr. Stephen Henson 已提交
4 5 6 7 8 9 10 11 12
 */
/* ====================================================================
 * Copyright (c) 2001 The OpenSSL Project.  All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *
 * 1. Redistributions of source code must retain the above copyright
13
 *    notice, this list of conditions and the following disclaimer.
D
 
Dr. Stephen Henson 已提交
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
 *
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in
 *    the documentation and/or other materials provided with the
 *    distribution.
 *
 * 3. All advertising materials mentioning features or use of this
 *    software must display the following acknowledgment:
 *    "This product includes software developed by the OpenSSL Project
 *    for use in the OpenSSL Toolkit. (http://www.OpenSSL.org/)"
 *
 * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
 *    endorse or promote products derived from this software without
 *    prior written permission. For written permission, please contact
 *    licensing@OpenSSL.org.
 *
 * 5. Products derived from this software may not be called "OpenSSL"
 *    nor may "OpenSSL" appear in their names without prior written
 *    permission of the OpenSSL Project.
 *
 * 6. Redistributions of any form whatsoever must retain the following
 *    acknowledgment:
 *    "This product includes software developed by the OpenSSL Project
 *    for use in the OpenSSL Toolkit (http://www.OpenSSL.org/)"
 *
 * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
 * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE OpenSSL PROJECT OR
 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
 * OF THE POSSIBILITY OF SUCH DAMAGE.
 * ====================================================================
 *
 * This product includes cryptographic software written by Eric Young
 * (eay@cryptsoft.com).  This product includes software written by Tim
 * Hudson (tjh@cryptsoft.com).
 *
 */

#include <stdio.h>
60
#include "internal/cryptlib.h"
D
 
Dr. Stephen Henson 已提交
61 62 63 64
#include <openssl/asn1.h>
#include <openssl/objects.h>
#include <openssl/evp.h>
#include <openssl/x509.h>
D
Dr. Stephen Henson 已提交
65
#include "internal/x509_int.h"
D
 
Dr. Stephen Henson 已提交
66 67

int X509_CRL_set_version(X509_CRL *x, long version)
68 69 70
{
    if (x == NULL)
        return (0);
D
Dr. Stephen Henson 已提交
71 72
    if (x->crl.version == NULL) {
        if ((x->crl.version = ASN1_INTEGER_new()) == NULL)
73 74
            return (0);
    }
D
Dr. Stephen Henson 已提交
75
    return (ASN1_INTEGER_set(x->crl.version, version));
76
}
D
 
Dr. Stephen Henson 已提交
77 78

int X509_CRL_set_issuer_name(X509_CRL *x, X509_NAME *name)
79
{
D
Dr. Stephen Henson 已提交
80
    if (x == NULL)
81
        return (0);
D
Dr. Stephen Henson 已提交
82
    return (X509_NAME_set(&x->crl.issuer, name));
83
}
D
 
Dr. Stephen Henson 已提交
84

N
Nils Larsch 已提交
85
int X509_CRL_set_lastUpdate(X509_CRL *x, const ASN1_TIME *tm)
86 87
{
    ASN1_TIME *in;
D
 
Dr. Stephen Henson 已提交
88

89 90
    if (x == NULL)
        return (0);
D
Dr. Stephen Henson 已提交
91
    in = x->crl.lastUpdate;
92
    if (in != tm) {
D
Dr. Stephen Henson 已提交
93
        in = ASN1_STRING_dup(tm);
94
        if (in != NULL) {
D
Dr. Stephen Henson 已提交
95 96
            ASN1_TIME_free(x->crl.lastUpdate);
            x->crl.lastUpdate = in;
97 98 99 100
        }
    }
    return (in != NULL);
}
D
 
Dr. Stephen Henson 已提交
101

N
Nils Larsch 已提交
102
int X509_CRL_set_nextUpdate(X509_CRL *x, const ASN1_TIME *tm)
103 104
{
    ASN1_TIME *in;
D
 
Dr. Stephen Henson 已提交
105

106 107
    if (x == NULL)
        return (0);
D
Dr. Stephen Henson 已提交
108
    in = x->crl.nextUpdate;
109
    if (in != tm) {
D
Dr. Stephen Henson 已提交
110
        in = ASN1_STRING_dup(tm);
111
        if (in != NULL) {
D
Dr. Stephen Henson 已提交
112 113
            ASN1_TIME_free(x->crl.nextUpdate);
            x->crl.nextUpdate = in;
114 115 116 117
        }
    }
    return (in != NULL);
}
D
 
Dr. Stephen Henson 已提交
118 119

int X509_CRL_sort(X509_CRL *c)
120 121 122 123 124 125
{
    int i;
    X509_REVOKED *r;
    /*
     * sort the data so it will be written in serial number order
     */
D
Dr. Stephen Henson 已提交
126 127 128
    sk_X509_REVOKED_sort(c->crl.revoked);
    for (i = 0; i < sk_X509_REVOKED_num(c->crl.revoked); i++) {
        r = sk_X509_REVOKED_value(c->crl.revoked, i);
129 130
        r->sequence = i;
    }
D
Dr. Stephen Henson 已提交
131
    c->crl.enc.modified = 1;
132 133
    return 1;
}
D
 
Dr. Stephen Henson 已提交
134

135 136
void X509_CRL_up_ref(X509_CRL *crl)
{
137 138
    int i;
    CRYPTO_atomic_add(&crl->references, 1, &i, crl->lock);
139 140
}

D
Dr. Stephen Henson 已提交
141 142
long X509_CRL_get_version(X509_CRL *crl)
{
D
Dr. Stephen Henson 已提交
143
    return ASN1_INTEGER_get(crl->crl.version);
D
Dr. Stephen Henson 已提交
144 145 146 147
}

ASN1_TIME *X509_CRL_get_lastUpdate(X509_CRL *crl)
{
D
Dr. Stephen Henson 已提交
148
    return crl->crl.lastUpdate;
D
Dr. Stephen Henson 已提交
149 150 151 152
}

ASN1_TIME *X509_CRL_get_nextUpdate(X509_CRL *crl)
{
D
Dr. Stephen Henson 已提交
153
    return crl->crl.nextUpdate;
D
Dr. Stephen Henson 已提交
154 155 156 157
}

X509_NAME *X509_CRL_get_issuer(X509_CRL *crl)
{
D
Dr. Stephen Henson 已提交
158
    return crl->crl.issuer;
D
Dr. Stephen Henson 已提交
159 160
}

161 162 163 164 165
STACK_OF(X509_EXTENSION) *X509_CRL_get0_extensions(X509_CRL *crl)
{
    return crl->crl.extensions;
}

D
Dr. Stephen Henson 已提交
166 167
STACK_OF(X509_REVOKED) *X509_CRL_get_REVOKED(X509_CRL *crl)
{
D
Dr. Stephen Henson 已提交
168
    return crl->crl.revoked;
D
Dr. Stephen Henson 已提交
169 170 171
}

void X509_CRL_get0_signature(ASN1_BIT_STRING **psig, X509_ALGOR **palg,
172
                             X509_CRL *crl)
D
Dr. Stephen Henson 已提交
173
{
D
typo  
Dr. Stephen Henson 已提交
174
    if (psig != NULL)
175
        *psig = &crl->signature;
D
typo  
Dr. Stephen Henson 已提交
176
    if (palg != NULL)
177
        *palg = &crl->sig_alg;
D
Dr. Stephen Henson 已提交
178 179
}

180 181 182 183 184
int X509_CRL_get_signature_nid(const X509_CRL *crl)
{
    return OBJ_obj2nid(crl->sig_alg.algorithm);
}

185 186 187 188 189
ASN1_TIME *X509_REVOKED_get0_revocationDate(X509_REVOKED *x)
{
    return x->revocationDate;
}

D
 
Dr. Stephen Henson 已提交
190
int X509_REVOKED_set_revocationDate(X509_REVOKED *x, ASN1_TIME *tm)
191 192
{
    ASN1_TIME *in;
D
 
Dr. Stephen Henson 已提交
193

194 195 196 197
    if (x == NULL)
        return (0);
    in = x->revocationDate;
    if (in != tm) {
D
Dr. Stephen Henson 已提交
198
        in = ASN1_STRING_dup(tm);
199
        if (in != NULL) {
D
Dr. Stephen Henson 已提交
200
            ASN1_TIME_free(x->revocationDate);
201 202 203 204 205
            x->revocationDate = in;
        }
    }
    return (in != NULL);
}
D
 
Dr. Stephen Henson 已提交
206

207 208
ASN1_INTEGER *X509_REVOKED_get0_serialNumber(X509_REVOKED *x)
{
209
    return &x->serialNumber;
210 211
}

D
 
Dr. Stephen Henson 已提交
212
int X509_REVOKED_set_serialNumber(X509_REVOKED *x, ASN1_INTEGER *serial)
213 214
{
    ASN1_INTEGER *in;
D
 
Dr. Stephen Henson 已提交
215

216 217
    if (x == NULL)
        return (0);
218 219 220 221
    in = &x->serialNumber;
    if (in != serial)
        return ASN1_STRING_copy(in, serial);
    return 1;
222
}
223

224 225 226 227 228
STACK_OF(X509_EXTENSION) *X509_REVOKED_get0_extensions(X509_REVOKED *r)
{
    return r->extensions;
}

229 230 231 232 233
int i2d_re_X509_CRL_tbs(X509_CRL *crl, unsigned char **pp)
{
    crl->crl.enc.modified = 1;
    return i2d_X509_CRL_INFO(&crl->crl, pp);
}