onion_tap.h 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. /* Copyright (c) 2001 Matej Pfajfar.
  2. * Copyright (c) 2001-2004, Roger Dingledine.
  3. * Copyright (c) 2004-2006, Roger Dingledine, Nick Mathewson.
  4. * Copyright (c) 2007-2019, The Tor Project, Inc. */
  5. /* See LICENSE for licensing information */
  6. /**
  7. * \file onion_tap.h
  8. * \brief Header file for onion_tap.c.
  9. **/
  10. #ifndef TOR_ONION_TAP_H
  11. #define TOR_ONION_TAP_H
  12. #define TAP_ONIONSKIN_CHALLENGE_LEN (PKCS1_OAEP_PADDING_OVERHEAD+\
  13. CIPHER_KEY_LEN+\
  14. DH1024_KEY_LEN)
  15. #define TAP_ONIONSKIN_REPLY_LEN (DH1024_KEY_LEN+DIGEST_LEN)
  16. struct crypto_dh_t;
  17. struct crypto_pk_t;
  18. int onion_skin_TAP_create(struct crypto_pk_t *router_key,
  19. struct crypto_dh_t **handshake_state_out,
  20. char *onion_skin_out);
  21. int onion_skin_TAP_server_handshake(const char *onion_skin,
  22. struct crypto_pk_t *private_key,
  23. struct crypto_pk_t *prev_private_key,
  24. char *handshake_reply_out,
  25. char *key_out,
  26. size_t key_out_len);
  27. int onion_skin_TAP_client_handshake(struct crypto_dh_t *handshake_state,
  28. const char *handshake_reply,
  29. char *key_out,
  30. size_t key_out_len,
  31. const char **msg_out);
  32. #endif /* !defined(TOR_ONION_TAP_H) */