safe_connection.h 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. /* Copyright (c) 2013-2019, The Tor Project, Inc. */
  2. /* See LICENSE for licensing information */
  3. #ifndef OR_SAFE_CONN_H
  4. #define OR_SAFE_CONN_H
  5. #include "core/or/relay.h"
  6. #include "lib/evloop/compat_libevent.h"
  7. #include "lib/evloop/events.h"
  8. #include "lib/evloop/token_bucket.h"
  9. #include "lib/lock/compat_mutex.h"
  10. #include "lib/tls/x509.h"
  11. extern event_label_t safe_or_conn_tcp_connecting_ev;
  12. extern event_label_t safe_or_conn_tls_handshaking_ev;
  13. extern event_label_t safe_or_conn_link_handshaking_ev;
  14. extern event_label_t safe_or_conn_open_ev;
  15. extern event_label_t safe_or_conn_closed_ev;
  16. extern event_label_t safe_or_conn_has_buffered_data_ev;
  17. typedef struct link_handshaking_ev_data_t {
  18. tor_x509_cert_t *tls_own_cert; // the ownership is passed in this event
  19. tor_x509_cert_t *tls_peer_cert; // the ownership is passed in this event
  20. } link_handshaking_ev_data;
  21. void link_handshaking_ev_free(void *ptr);
  22. //#define SAFE_BASE_CONN_MAGIC 0x64DB4EE2u
  23. #define SAFE_OR_CONN_MAGIC 0x1221ABBAu
  24. typedef enum tor_error_t {
  25. E_SUCCESS = 0,
  26. E_ERROR = 1,
  27. } tor_error_t;
  28. typedef enum or_conn_state_t {
  29. SAFE_OR_CONN_STATE_UNINITIALIZED,
  30. SAFE_OR_CONN_STATE_NO_SOCKET,
  31. SAFE_OR_CONN_STATE_TCP_CONNECTING,
  32. SAFE_OR_CONN_STATE_PROXY_HANDSHAKING,
  33. SAFE_OR_CONN_STATE_TLS_HANDSHAKING,
  34. SAFE_OR_CONN_STATE_LINK_HANDSHAKING,
  35. SAFE_OR_CONN_STATE_OPEN,
  36. SAFE_OR_CONN_STATE_CLOSED,
  37. } or_conn_state_t;
  38. typedef struct socket_rw_state_t {
  39. bool state;
  40. } socket_rw_state_t;
  41. typedef struct safe_connection_t {
  42. uint32_t magic;
  43. tor_mutex_t lock;
  44. bool linked;
  45. tor_socket_t socket;
  46. struct event *read_event;
  47. struct event *write_event;
  48. socket_rw_state_t read_allowed;
  49. socket_rw_state_t write_allowed;
  50. bool (*is_read_wanted)(struct safe_connection_t *);
  51. bool (*is_write_wanted)(struct safe_connection_t *);
  52. void (*read_cb)(struct safe_connection_t *);
  53. void (*write_cb)(struct safe_connection_t *);
  54. void (*socket_added_cb)(struct safe_connection_t *);
  55. void (*inbuf_modified_cb)(struct safe_connection_t *);
  56. void (*outbuf_modified_cb)(struct safe_connection_t *);
  57. struct buf_t *inbuf;
  58. struct buf_t *outbuf;
  59. event_source_t *event_source;
  60. } safe_connection_t;
  61. typedef struct safe_or_connection_t {
  62. safe_connection_t base_;
  63. token_bucket_rw_t bucket;
  64. struct tor_tls_t *tls;
  65. or_conn_state_t state;
  66. bool is_outgoing;
  67. char *remote_address_str;
  68. socket_rw_state_t tor_read_wanted;
  69. socket_rw_state_t tor_write_wanted;
  70. socket_rw_state_t tls_read_wanted;
  71. socket_rw_state_t tls_write_wanted;
  72. socket_rw_state_t bucket_read_allowed;
  73. socket_rw_state_t bucket_write_allowed;
  74. //bool tls_read_waiting_on_socket_writable;
  75. //bool tls_write_waiting_on_socket_readable;
  76. } safe_or_connection_t;
  77. safe_or_connection_t *TO_SAFE_OR_CONN(safe_connection_t *safe_conn);
  78. #define TO_SAFE_CONN(c) (&(((c)->base_)))
  79. void safe_or_conn_register_events(event_registry_t *registry);
  80. /********************************************************/
  81. void
  82. safe_connection_init(safe_connection_t *safe_conn, uint32_t type_magic,
  83. bool (*is_read_wanted)(safe_connection_t *),
  84. bool (*is_write_wanted)(safe_connection_t *),
  85. void (*read_cb)(safe_connection_t *),
  86. void (*write_cb)(safe_connection_t *),
  87. void (*socket_added_cb)(safe_connection_t *),
  88. void (*inbuf_modified_cb)(safe_connection_t *),
  89. void (*outbuf_modified_cb)(safe_connection_t *),
  90. bool requires_buffers, bool linked);
  91. void
  92. safe_connection_set_socket(safe_connection_t *safe_conn, tor_socket_t socket);
  93. void
  94. safe_connection_subscribe(safe_connection_t *safe_conn,
  95. event_listener_t *listener, event_label_t label,
  96. bool send_full_event);
  97. void
  98. safe_connection_unsubscribe_all(safe_connection_t *safe_conn,
  99. event_listener_t *listener);
  100. void
  101. safe_connection_unregister_events(safe_connection_t *safe_conn);
  102. tor_error_t
  103. safe_connection_register_events(safe_connection_t *safe_conn,
  104. struct event_base *event_base);
  105. void
  106. safe_connection_set_read_permission(safe_connection_t *safe_conn,
  107. bool read_allowed);
  108. void
  109. safe_connection_set_write_permission(safe_connection_t *safe_conn,
  110. bool write_allowed);
  111. void
  112. safe_connection_inbuf_modified(safe_connection_t *safe_conn);
  113. void
  114. safe_connection_outbuf_modified(safe_connection_t *safe_conn);
  115. /********************************************************/
  116. safe_or_connection_t *
  117. safe_or_connection_new(bool requires_buffers, bool is_outgoing,
  118. const char *remote_address_str);
  119. void
  120. safe_or_connection_get_tls_desc(safe_or_connection_t *safe_or_conn,
  121. char *buf, size_t buf_size);
  122. int
  123. safe_or_connection_tls_secrets(safe_or_connection_t *safe_or_conn,
  124. uint8_t *secrets_out);
  125. int
  126. safe_or_connection_key_material(safe_or_connection_t *safe_or_conn,
  127. uint8_t *secrets_out,
  128. const uint8_t *context,
  129. size_t context_len, const char *label);
  130. void
  131. safe_or_connection_refill_buckets(safe_or_connection_t *safe_or_conn,
  132. uint32_t now_ts);
  133. void
  134. safe_or_connection_adjust_buckets(safe_or_connection_t *safe_or_conn,
  135. uint32_t rate, uint32_t burst,
  136. bool reset, uint32_t now_ts);
  137. #endif