channeltls.h 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /* * Copyright (c) 2012-2019, The Tor Project, Inc. */
  2. /* See LICENSE for licensing information */
  3. /**
  4. * \file channeltls.h
  5. * \brief Header file for channeltls.c
  6. **/
  7. #ifndef TOR_CHANNELTLS_H
  8. #define TOR_CHANNELTLS_H
  9. #include "core/or/or.h"
  10. #include "core/or/channel.h"
  11. struct ed25519_public_key_t;
  12. struct curve25519_public_key_t;
  13. #define TLS_PER_CELL_OVERHEAD 29
  14. #define BASE_CHAN_TO_TLS(c) (channel_tls_from_base((c)))
  15. #define TLS_CHAN_TO_BASE(c) (channel_tls_to_base((c)))
  16. #define TLS_CHAN_MAGIC 0x8a192427U
  17. #ifdef TOR_CHANNEL_INTERNAL_
  18. struct channel_tls_s {
  19. /* Base channel_t struct */
  20. channel_t base_;
  21. /* or_connection_t pointer */
  22. or_connection_t *conn;
  23. };
  24. #endif /* defined(TOR_CHANNEL_INTERNAL_) */
  25. channel_t * channel_tls_connect(const tor_addr_t *addr, uint16_t port,
  26. const char *id_digest,
  27. const struct ed25519_public_key_t *ed_id);
  28. channel_listener_t * channel_tls_get_listener(void);
  29. channel_listener_t * channel_tls_start_listener(void);
  30. channel_t * channel_tls_handle_incoming(or_connection_t *orconn);
  31. /* Casts */
  32. channel_t * channel_tls_to_base(channel_tls_t *tlschan);
  33. channel_tls_t * channel_tls_from_base(channel_t *chan);
  34. /* Things for connection_or.c to call back into */
  35. void channel_tls_handle_cell(cell_t *cell, or_connection_t *conn);
  36. void channel_tls_handle_state_change_on_orconn(channel_tls_t *chan,
  37. or_connection_t *conn,
  38. uint8_t old_state,
  39. uint8_t state);
  40. void channel_tls_handle_var_cell(var_cell_t *var_cell,
  41. or_connection_t *conn);
  42. void channel_tls_update_marks(or_connection_t *conn);
  43. /* Cleanup at shutdown */
  44. void channel_tls_free_all(void);
  45. extern uint64_t stats_n_authorize_cells_processed;
  46. extern uint64_t stats_n_authenticate_cells_processed;
  47. extern uint64_t stats_n_versions_cells_processed;
  48. extern uint64_t stats_n_netinfo_cells_processed;
  49. extern uint64_t stats_n_vpadding_cells_processed;
  50. extern uint64_t stats_n_certs_cells_processed;
  51. extern uint64_t stats_n_auth_challenge_cells_processed;
  52. #ifdef CHANNELTLS_PRIVATE
  53. STATIC void channel_tls_process_certs_cell(var_cell_t *cell,
  54. channel_tls_t *tlschan);
  55. STATIC void channel_tls_process_auth_challenge_cell(var_cell_t *cell,
  56. channel_tls_t *tlschan);
  57. STATIC void channel_tls_common_init(channel_tls_t *tlschan);
  58. STATIC void channel_tls_process_authenticate_cell(var_cell_t *cell,
  59. channel_tls_t *tlschan);
  60. #endif /* defined(CHANNELTLS_PRIVATE) */
  61. #endif /* !defined(TOR_CHANNELTLS_H) */