x509.c 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. /*
  2. * Copyright 2016-2021 The OpenSSL Project Authors. All Rights Reserved.
  3. *
  4. * Licensed under the OpenSSL licenses, (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. * https://www.openssl.org/source/license.html
  8. * or in the file LICENSE in the source distribution.
  9. */
  10. #include <openssl/x509.h>
  11. #include <openssl/bio.h>
  12. #include <openssl/err.h>
  13. #include <openssl/rand.h>
  14. #include "fuzzer.h"
  15. #include "rand.inc"
  16. int FuzzerInitialize(int *argc, char ***argv)
  17. {
  18. OPENSSL_init_crypto(OPENSSL_INIT_LOAD_CRYPTO_STRINGS, NULL);
  19. ERR_get_state();
  20. CRYPTO_free_ex_index(0, -1);
  21. FuzzerSetRand();
  22. return 1;
  23. }
  24. int FuzzerTestOneInput(const uint8_t *buf, size_t len)
  25. {
  26. const unsigned char *p = buf;
  27. unsigned char *der = NULL;
  28. X509 *x509 = d2i_X509(NULL, &p, len);
  29. if (x509 != NULL) {
  30. BIO *bio = BIO_new(BIO_s_null());
  31. /* This will load and print the public key as well as extensions */
  32. X509_print(bio, x509);
  33. BIO_free(bio);
  34. X509_issuer_and_serial_hash(x509);
  35. i2d_X509(x509, &der);
  36. OPENSSL_free(der);
  37. X509_free(x509);
  38. }
  39. ERR_clear_error();
  40. return 0;
  41. }
  42. void FuzzerCleanup(void)
  43. {
  44. }