routerkeys.h 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /* Copyright (c) 2014, The Tor Project, Inc. */
  2. /* See LICENSE for licensing information */
  3. #ifndef TOR_ROUTERKEYS_H
  4. #define TOR_ROUTERKEYS_H
  5. #include "crypto_ed25519.h"
  6. #define INIT_ED_KEY_CREATE (1u<<0)
  7. #define INIT_ED_KEY_REPLACE (1u<<1)
  8. #define INIT_ED_KEY_SPLIT (1u<<2)
  9. #define INIT_ED_KEY_MISSING_SECRET_OK (1u<<3)
  10. #define INIT_ED_KEY_NEEDCERT (1u<<4)
  11. #define INIT_ED_KEY_EXTRA_STRONG (1u<<5)
  12. #define INIT_ED_KEY_INCLUDE_SIGNING_KEY_IN_CERT (1u<<6)
  13. #define INIT_ED_KEY_OMIT_SECRET (1u<<7)
  14. struct tor_cert_st;
  15. ed25519_keypair_t *ed_key_init_from_file(const char *fname, uint32_t flags,
  16. int severity,
  17. const ed25519_keypair_t *signing_key,
  18. time_t now,
  19. time_t lifetime,
  20. uint8_t cert_type,
  21. struct tor_cert_st **cert_out);
  22. ed25519_keypair_t *ed_key_new(const ed25519_keypair_t *signing_key,
  23. uint32_t flags,
  24. time_t now,
  25. time_t lifetime,
  26. uint8_t cert_type,
  27. struct tor_cert_st **cert_out);
  28. const ed25519_public_key_t *get_master_identity_key(void);
  29. const ed25519_keypair_t *get_master_signing_keypair(void);
  30. const struct tor_cert_st *get_master_signing_key_cert(void);
  31. const ed25519_keypair_t *get_current_auth_keypair(void);
  32. const struct tor_cert_st *get_current_link_cert_cert(void);
  33. const struct tor_cert_st *get_current_auth_key_cert(void);
  34. void get_master_rsa_crosscert(const uint8_t **cert_out,
  35. size_t *size_out);
  36. struct tor_cert_st *make_ntor_onion_key_crosscert(
  37. const curve25519_keypair_t *onion_key,
  38. const ed25519_public_key_t *master_id_key,
  39. time_t now, time_t lifetime,
  40. int *sign_out);
  41. uint8_t *make_tap_onion_key_crosscert(const crypto_pk_t *onion_key,
  42. const ed25519_public_key_t *master_id_key,
  43. const crypto_pk_t *rsa_id_key,
  44. int *len_out);
  45. int check_tap_onion_key_crosscert(const uint8_t *crosscert,
  46. int crosscert_len,
  47. const crypto_pk_t *onion_pkey,
  48. const ed25519_public_key_t *master_id_pkey,
  49. const uint8_t *rsa_id_digest);
  50. int load_ed_keys(const or_options_t *options, time_t now);
  51. int should_make_new_ed_keys(const or_options_t *options, const time_t now);
  52. int generate_ed_link_cert(const or_options_t *options, time_t now);
  53. void routerkeys_free_all(void);
  54. #endif