1e1051a39Sopenharmony_ci/* 2e1051a39Sopenharmony_ci * Copyright 2006-2021 The OpenSSL Project Authors. All Rights Reserved. 3e1051a39Sopenharmony_ci * 4e1051a39Sopenharmony_ci * Licensed under the Apache License 2.0 (the "License"). You may not use 5e1051a39Sopenharmony_ci * this file except in compliance with the License. You can obtain a copy 6e1051a39Sopenharmony_ci * in the file LICENSE in the source distribution or at 7e1051a39Sopenharmony_ci * https://www.openssl.org/source/license.html 8e1051a39Sopenharmony_ci */ 9e1051a39Sopenharmony_ci 10e1051a39Sopenharmony_ci#include "internal/cryptlib.h" 11e1051a39Sopenharmony_ci#include <openssl/objects.h> 12e1051a39Sopenharmony_ci#include <openssl/ts.h> 13e1051a39Sopenharmony_ci#include "ts_local.h" 14e1051a39Sopenharmony_ci 15e1051a39Sopenharmony_ciTS_VERIFY_CTX *TS_VERIFY_CTX_new(void) 16e1051a39Sopenharmony_ci{ 17e1051a39Sopenharmony_ci TS_VERIFY_CTX *ctx = OPENSSL_zalloc(sizeof(*ctx)); 18e1051a39Sopenharmony_ci 19e1051a39Sopenharmony_ci if (ctx == NULL) 20e1051a39Sopenharmony_ci ERR_raise(ERR_LIB_TS, ERR_R_MALLOC_FAILURE); 21e1051a39Sopenharmony_ci return ctx; 22e1051a39Sopenharmony_ci} 23e1051a39Sopenharmony_ci 24e1051a39Sopenharmony_civoid TS_VERIFY_CTX_init(TS_VERIFY_CTX *ctx) 25e1051a39Sopenharmony_ci{ 26e1051a39Sopenharmony_ci OPENSSL_assert(ctx != NULL); 27e1051a39Sopenharmony_ci memset(ctx, 0, sizeof(*ctx)); 28e1051a39Sopenharmony_ci} 29e1051a39Sopenharmony_ci 30e1051a39Sopenharmony_civoid TS_VERIFY_CTX_free(TS_VERIFY_CTX *ctx) 31e1051a39Sopenharmony_ci{ 32e1051a39Sopenharmony_ci if (!ctx) 33e1051a39Sopenharmony_ci return; 34e1051a39Sopenharmony_ci 35e1051a39Sopenharmony_ci TS_VERIFY_CTX_cleanup(ctx); 36e1051a39Sopenharmony_ci OPENSSL_free(ctx); 37e1051a39Sopenharmony_ci} 38e1051a39Sopenharmony_ci 39e1051a39Sopenharmony_ciint TS_VERIFY_CTX_add_flags(TS_VERIFY_CTX *ctx, int f) 40e1051a39Sopenharmony_ci{ 41e1051a39Sopenharmony_ci ctx->flags |= f; 42e1051a39Sopenharmony_ci return ctx->flags; 43e1051a39Sopenharmony_ci} 44e1051a39Sopenharmony_ci 45e1051a39Sopenharmony_ciint TS_VERIFY_CTX_set_flags(TS_VERIFY_CTX *ctx, int f) 46e1051a39Sopenharmony_ci{ 47e1051a39Sopenharmony_ci ctx->flags = f; 48e1051a39Sopenharmony_ci return ctx->flags; 49e1051a39Sopenharmony_ci} 50e1051a39Sopenharmony_ci 51e1051a39Sopenharmony_ciBIO *TS_VERIFY_CTX_set_data(TS_VERIFY_CTX *ctx, BIO *b) 52e1051a39Sopenharmony_ci{ 53e1051a39Sopenharmony_ci ctx->data = b; 54e1051a39Sopenharmony_ci return ctx->data; 55e1051a39Sopenharmony_ci} 56e1051a39Sopenharmony_ci 57e1051a39Sopenharmony_ciX509_STORE *TS_VERIFY_CTX_set_store(TS_VERIFY_CTX *ctx, X509_STORE *s) 58e1051a39Sopenharmony_ci{ 59e1051a39Sopenharmony_ci ctx->store = s; 60e1051a39Sopenharmony_ci return ctx->store; 61e1051a39Sopenharmony_ci} 62e1051a39Sopenharmony_ci 63e1051a39Sopenharmony_ciSTACK_OF(X509) *TS_VERIFY_CTX_set_certs(TS_VERIFY_CTX *ctx, 64e1051a39Sopenharmony_ci STACK_OF(X509) *certs) 65e1051a39Sopenharmony_ci{ 66e1051a39Sopenharmony_ci ctx->certs = certs; 67e1051a39Sopenharmony_ci return ctx->certs; 68e1051a39Sopenharmony_ci} 69e1051a39Sopenharmony_ci 70e1051a39Sopenharmony_ciunsigned char *TS_VERIFY_CTX_set_imprint(TS_VERIFY_CTX *ctx, 71e1051a39Sopenharmony_ci unsigned char *hexstr, long len) 72e1051a39Sopenharmony_ci{ 73e1051a39Sopenharmony_ci OPENSSL_free(ctx->imprint); 74e1051a39Sopenharmony_ci ctx->imprint = hexstr; 75e1051a39Sopenharmony_ci ctx->imprint_len = len; 76e1051a39Sopenharmony_ci return ctx->imprint; 77e1051a39Sopenharmony_ci} 78e1051a39Sopenharmony_ci 79e1051a39Sopenharmony_civoid TS_VERIFY_CTX_cleanup(TS_VERIFY_CTX *ctx) 80e1051a39Sopenharmony_ci{ 81e1051a39Sopenharmony_ci if (!ctx) 82e1051a39Sopenharmony_ci return; 83e1051a39Sopenharmony_ci 84e1051a39Sopenharmony_ci X509_STORE_free(ctx->store); 85e1051a39Sopenharmony_ci sk_X509_pop_free(ctx->certs, X509_free); 86e1051a39Sopenharmony_ci 87e1051a39Sopenharmony_ci ASN1_OBJECT_free(ctx->policy); 88e1051a39Sopenharmony_ci 89e1051a39Sopenharmony_ci X509_ALGOR_free(ctx->md_alg); 90e1051a39Sopenharmony_ci OPENSSL_free(ctx->imprint); 91e1051a39Sopenharmony_ci 92e1051a39Sopenharmony_ci BIO_free_all(ctx->data); 93e1051a39Sopenharmony_ci 94e1051a39Sopenharmony_ci ASN1_INTEGER_free(ctx->nonce); 95e1051a39Sopenharmony_ci 96e1051a39Sopenharmony_ci GENERAL_NAME_free(ctx->tsa_name); 97e1051a39Sopenharmony_ci 98e1051a39Sopenharmony_ci TS_VERIFY_CTX_init(ctx); 99e1051a39Sopenharmony_ci} 100e1051a39Sopenharmony_ci 101e1051a39Sopenharmony_ciTS_VERIFY_CTX *TS_REQ_to_TS_VERIFY_CTX(TS_REQ *req, TS_VERIFY_CTX *ctx) 102e1051a39Sopenharmony_ci{ 103e1051a39Sopenharmony_ci TS_VERIFY_CTX *ret = ctx; 104e1051a39Sopenharmony_ci ASN1_OBJECT *policy; 105e1051a39Sopenharmony_ci TS_MSG_IMPRINT *imprint; 106e1051a39Sopenharmony_ci X509_ALGOR *md_alg; 107e1051a39Sopenharmony_ci ASN1_OCTET_STRING *msg; 108e1051a39Sopenharmony_ci const ASN1_INTEGER *nonce; 109e1051a39Sopenharmony_ci 110e1051a39Sopenharmony_ci OPENSSL_assert(req != NULL); 111e1051a39Sopenharmony_ci if (ret) 112e1051a39Sopenharmony_ci TS_VERIFY_CTX_cleanup(ret); 113e1051a39Sopenharmony_ci else if ((ret = TS_VERIFY_CTX_new()) == NULL) 114e1051a39Sopenharmony_ci return NULL; 115e1051a39Sopenharmony_ci 116e1051a39Sopenharmony_ci ret->flags = TS_VFY_ALL_IMPRINT & ~(TS_VFY_TSA_NAME | TS_VFY_SIGNATURE); 117e1051a39Sopenharmony_ci 118e1051a39Sopenharmony_ci if ((policy = req->policy_id) != NULL) { 119e1051a39Sopenharmony_ci if ((ret->policy = OBJ_dup(policy)) == NULL) 120e1051a39Sopenharmony_ci goto err; 121e1051a39Sopenharmony_ci } else 122e1051a39Sopenharmony_ci ret->flags &= ~TS_VFY_POLICY; 123e1051a39Sopenharmony_ci 124e1051a39Sopenharmony_ci imprint = req->msg_imprint; 125e1051a39Sopenharmony_ci md_alg = imprint->hash_algo; 126e1051a39Sopenharmony_ci if ((ret->md_alg = X509_ALGOR_dup(md_alg)) == NULL) 127e1051a39Sopenharmony_ci goto err; 128e1051a39Sopenharmony_ci msg = imprint->hashed_msg; 129e1051a39Sopenharmony_ci ret->imprint_len = ASN1_STRING_length(msg); 130e1051a39Sopenharmony_ci if (ret->imprint_len <= 0) 131e1051a39Sopenharmony_ci goto err; 132e1051a39Sopenharmony_ci if ((ret->imprint = OPENSSL_malloc(ret->imprint_len)) == NULL) 133e1051a39Sopenharmony_ci goto err; 134e1051a39Sopenharmony_ci memcpy(ret->imprint, ASN1_STRING_get0_data(msg), ret->imprint_len); 135e1051a39Sopenharmony_ci 136e1051a39Sopenharmony_ci if ((nonce = req->nonce) != NULL) { 137e1051a39Sopenharmony_ci if ((ret->nonce = ASN1_INTEGER_dup(nonce)) == NULL) 138e1051a39Sopenharmony_ci goto err; 139e1051a39Sopenharmony_ci } else 140e1051a39Sopenharmony_ci ret->flags &= ~TS_VFY_NONCE; 141e1051a39Sopenharmony_ci 142e1051a39Sopenharmony_ci return ret; 143e1051a39Sopenharmony_ci err: 144e1051a39Sopenharmony_ci if (ctx) 145e1051a39Sopenharmony_ci TS_VERIFY_CTX_cleanup(ctx); 146e1051a39Sopenharmony_ci else 147e1051a39Sopenharmony_ci TS_VERIFY_CTX_free(ret); 148e1051a39Sopenharmony_ci return NULL; 149e1051a39Sopenharmony_ci} 150