Blame crypto/asn1/a_digest.c

Packit c4476c
/*
Packit c4476c
 * Copyright 1995-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 <time.h>
Packit c4476c
#include <sys/types.h>
Packit c4476c
Packit c4476c
#include "internal/cryptlib.h"
Packit c4476c
Packit c4476c
#include <openssl/err.h>
Packit c4476c
#include <openssl/evp.h>
Packit c4476c
#include <openssl/buffer.h>
Packit c4476c
#include <openssl/x509.h>
Packit c4476c
Packit c4476c
#ifndef NO_ASN1_OLD
Packit c4476c
Packit c4476c
int ASN1_digest(i2d_of_void *i2d, const EVP_MD *type, char *data,
Packit c4476c
                unsigned char *md, unsigned int *len)
Packit c4476c
{
Packit c4476c
    int inl;
Packit c4476c
    unsigned char *str, *p;
Packit c4476c
Packit c4476c
    inl = i2d(data, NULL);
Packit c4476c
    if (inl <= 0) {
Packit c4476c
        ASN1err(ASN1_F_ASN1_DIGEST, ERR_R_INTERNAL_ERROR);
Packit c4476c
        return 0;
Packit c4476c
    }
Packit c4476c
    if ((str = OPENSSL_malloc(inl)) == NULL) {
Packit c4476c
        ASN1err(ASN1_F_ASN1_DIGEST, ERR_R_MALLOC_FAILURE);
Packit c4476c
        return 0;
Packit c4476c
    }
Packit c4476c
    p = str;
Packit c4476c
    i2d(data, &p);
Packit c4476c
Packit c4476c
    if (!EVP_Digest(str, inl, md, len, type, NULL)) {
Packit c4476c
        OPENSSL_free(str);
Packit c4476c
        return 0;
Packit c4476c
    }
Packit c4476c
    OPENSSL_free(str);
Packit c4476c
    return 1;
Packit c4476c
}
Packit c4476c
Packit c4476c
#endif
Packit c4476c
Packit c4476c
int ASN1_item_digest(const ASN1_ITEM *it, const EVP_MD *type, void *asn,
Packit c4476c
                     unsigned char *md, unsigned int *len)
Packit c4476c
{
Packit c4476c
    int i;
Packit c4476c
    unsigned char *str = NULL;
Packit c4476c
Packit c4476c
    i = ASN1_item_i2d(asn, &str, it);
Packit c4476c
    if (!str)
Packit c4476c
        return 0;
Packit c4476c
Packit c4476c
    if (!EVP_Digest(str, i, md, len, type, NULL)) {
Packit c4476c
        OPENSSL_free(str);
Packit c4476c
        return 0;
Packit c4476c
    }
Packit c4476c
    OPENSSL_free(str);
Packit c4476c
    return 1;
Packit c4476c
}