Blame crypto/x509/t_crl.c

Packit c4476c
/*
Packit c4476c
 * Copyright 1999-2016 The OpenSSL Project Authors. All Rights Reserved.
Packit c4476c
 *
Packit c4476c
 * Licensed under the OpenSSL license (the "License").  You may not use
Packit c4476c
 * this file except in compliance with the License.  You can obtain a copy
Packit c4476c
 * in the file LICENSE in the source distribution or at
Packit c4476c
 * https://www.openssl.org/source/license.html
Packit c4476c
 */
Packit c4476c
Packit c4476c
#include <stdio.h>
Packit c4476c
#include "internal/cryptlib.h"
Packit c4476c
#include <openssl/buffer.h>
Packit c4476c
#include <openssl/bn.h>
Packit c4476c
#include <openssl/objects.h>
Packit c4476c
#include <openssl/x509.h>
Packit c4476c
#include <openssl/x509v3.h>
Packit c4476c
Packit c4476c
#ifndef OPENSSL_NO_STDIO
Packit c4476c
int X509_CRL_print_fp(FILE *fp, X509_CRL *x)
Packit c4476c
{
Packit c4476c
    BIO *b;
Packit c4476c
    int ret;
Packit c4476c
Packit c4476c
    if ((b = BIO_new(BIO_s_file())) == NULL) {
Packit c4476c
        X509err(X509_F_X509_CRL_PRINT_FP, ERR_R_BUF_LIB);
Packit c4476c
        return 0;
Packit c4476c
    }
Packit c4476c
    BIO_set_fp(b, fp, BIO_NOCLOSE);
Packit c4476c
    ret = X509_CRL_print(b, x);
Packit c4476c
    BIO_free(b);
Packit c4476c
    return ret;
Packit c4476c
}
Packit c4476c
#endif
Packit c4476c
Packit c4476c
int X509_CRL_print(BIO *out, X509_CRL *x)
Packit c4476c
{
Packit c4476c
  return X509_CRL_print_ex(out, x, XN_FLAG_COMPAT);
Packit c4476c
}
Packit c4476c
Packit c4476c
int X509_CRL_print_ex(BIO *out, X509_CRL *x, unsigned long nmflag)
Packit c4476c
{
Packit c4476c
    STACK_OF(X509_REVOKED) *rev;
Packit c4476c
    X509_REVOKED *r;
Packit c4476c
    const X509_ALGOR *sig_alg;
Packit c4476c
    const ASN1_BIT_STRING *sig;
Packit c4476c
    long l;
Packit c4476c
    int i;
Packit c4476c
Packit c4476c
    BIO_printf(out, "Certificate Revocation List (CRL):\n");
Packit c4476c
    l = X509_CRL_get_version(x);
Packit c4476c
    if (l >= 0 && l <= 1)
Packit c4476c
        BIO_printf(out, "%8sVersion %ld (0x%lx)\n", "", l + 1, (unsigned long)l);
Packit c4476c
    else
Packit c4476c
        BIO_printf(out, "%8sVersion unknown (%ld)\n", "", l);
Packit c4476c
    X509_CRL_get0_signature(x, &sig, &sig_alg);
Packit c4476c
    BIO_puts(out, "    ");
Packit c4476c
    X509_signature_print(out, sig_alg, NULL);
Packit c4476c
    BIO_printf(out, "%8sIssuer: ", "");
Packit c4476c
    X509_NAME_print_ex(out, X509_CRL_get_issuer(x), 0, nmflag);
Packit c4476c
    BIO_puts(out, "\n");
Packit c4476c
    BIO_printf(out, "%8sLast Update: ", "");
Packit c4476c
    ASN1_TIME_print(out, X509_CRL_get0_lastUpdate(x));
Packit c4476c
    BIO_printf(out, "\n%8sNext Update: ", "");
Packit c4476c
    if (X509_CRL_get0_nextUpdate(x))
Packit c4476c
        ASN1_TIME_print(out, X509_CRL_get0_nextUpdate(x));
Packit c4476c
    else
Packit c4476c
        BIO_printf(out, "NONE");
Packit c4476c
    BIO_printf(out, "\n");
Packit c4476c
Packit c4476c
    X509V3_extensions_print(out, "CRL extensions",
Packit c4476c
                            X509_CRL_get0_extensions(x), 0, 8);
Packit c4476c
Packit c4476c
    rev = X509_CRL_get_REVOKED(x);
Packit c4476c
Packit c4476c
    if (sk_X509_REVOKED_num(rev) > 0)
Packit c4476c
        BIO_printf(out, "Revoked Certificates:\n");
Packit c4476c
    else
Packit c4476c
        BIO_printf(out, "No Revoked Certificates.\n");
Packit c4476c
Packit c4476c
    for (i = 0; i < sk_X509_REVOKED_num(rev); i++) {
Packit c4476c
        r = sk_X509_REVOKED_value(rev, i);
Packit c4476c
        BIO_printf(out, "    Serial Number: ");
Packit c4476c
        i2a_ASN1_INTEGER(out, X509_REVOKED_get0_serialNumber(r));
Packit c4476c
        BIO_printf(out, "\n        Revocation Date: ");
Packit c4476c
        ASN1_TIME_print(out, X509_REVOKED_get0_revocationDate(r));
Packit c4476c
        BIO_printf(out, "\n");
Packit c4476c
        X509V3_extensions_print(out, "CRL entry extensions",
Packit c4476c
                                X509_REVOKED_get0_extensions(r), 0, 8);
Packit c4476c
    }
Packit c4476c
    X509_signature_print(out, sig_alg, sig);
Packit c4476c
Packit c4476c
    return 1;
Packit c4476c
Packit c4476c
}