a_digest.c 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. /*
  2. * Copyright 1995-2020 The OpenSSL Project Authors. All Rights Reserved.
  3. *
  4. * Licensed under the Apache License 2.0 (the "License"). You may not use
  5. * this file except in compliance with the License. You can obtain a copy
  6. * in the file LICENSE in the source distribution or at
  7. * https://www.openssl.org/source/license.html
  8. */
  9. /* We need to use some engine deprecated APIs */
  10. #define OPENSSL_SUPPRESS_DEPRECATED
  11. #include <stdio.h>
  12. #include <time.h>
  13. #include <sys/types.h>
  14. #include "internal/cryptlib.h"
  15. #include <openssl/engine.h>
  16. #include <openssl/err.h>
  17. #include <openssl/evp.h>
  18. #include <openssl/buffer.h>
  19. #include <openssl/x509.h>
  20. #include "crypto/x509.h"
  21. #ifndef OPENSSL_NO_DEPRECATED_3_0
  22. int ASN1_digest(i2d_of_void *i2d, const EVP_MD *type, char *data,
  23. unsigned char *md, unsigned int *len)
  24. {
  25. int inl;
  26. unsigned char *str, *p;
  27. inl = i2d(data, NULL);
  28. if (inl <= 0) {
  29. ERR_raise(ERR_LIB_ASN1, ERR_R_INTERNAL_ERROR);
  30. return 0;
  31. }
  32. if ((str = OPENSSL_malloc(inl)) == NULL) {
  33. ERR_raise(ERR_LIB_ASN1, ERR_R_MALLOC_FAILURE);
  34. return 0;
  35. }
  36. p = str;
  37. i2d(data, &p);
  38. if (!EVP_Digest(str, inl, md, len, type, NULL)) {
  39. OPENSSL_free(str);
  40. return 0;
  41. }
  42. OPENSSL_free(str);
  43. return 1;
  44. }
  45. #endif
  46. int asn1_item_digest_ex(const ASN1_ITEM *it, const EVP_MD *md, void *asn,
  47. unsigned char *data, unsigned int *len,
  48. OSSL_LIB_CTX *libctx, const char *propq)
  49. {
  50. int i, ret = 0;
  51. unsigned char *str = NULL;
  52. EVP_MD *fetched_md = (EVP_MD *)md;
  53. i = ASN1_item_i2d(asn, &str, it);
  54. if (i < 0 || str == NULL)
  55. return 0;
  56. if (EVP_MD_provider(md) == NULL) {
  57. #if !defined(OPENSSL_NO_ENGINE)
  58. ENGINE *tmpeng = ENGINE_get_digest_engine(EVP_MD_type(md));
  59. if (tmpeng != NULL)
  60. ENGINE_finish(tmpeng);
  61. else
  62. #endif
  63. fetched_md = EVP_MD_fetch(libctx, EVP_MD_name(md), propq);
  64. }
  65. if (fetched_md == NULL)
  66. goto err;
  67. ret = EVP_Digest(str, i, data, len, fetched_md, NULL);
  68. err:
  69. OPENSSL_free(str);
  70. if (fetched_md != md)
  71. EVP_MD_free(fetched_md);
  72. return ret;
  73. }
  74. int ASN1_item_digest(const ASN1_ITEM *it, const EVP_MD *md, void *asn,
  75. unsigned char *data, unsigned int *len)
  76. {
  77. return asn1_item_digest_ex(it, md, asn, data, len, NULL, NULL);
  78. }