123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 |
- /* Copyright (c) 2001 Matej Pfajfar.
- * Copyright (c) 2001-2004, Roger Dingledine.
- * Copyright (c) 2004-2006, Roger Dingledine, Nick Mathewson.
- * Copyright (c) 2007-2013, The Tor Project, Inc. */
- /* See LICENSE for licensing information */
- /**
- * \file rendservice.h
- * \brief Header file for rendservice.c.
- **/
- #ifndef TOR_RENDSERVICE_H
- #define TOR_RENDSERVICE_H
- #include "or.h"
- typedef struct rend_intro_cell_s rend_intro_cell_t;
- #ifdef RENDSERVICE_PRIVATE
- /* This can be used for both INTRODUCE1 and INTRODUCE2 */
- struct rend_intro_cell_s {
- /* Is this an INTRODUCE1 or INTRODUCE2? (set to 1 or 2) */
- uint8_t type;
- /* Public key digest */
- uint8_t pk[DIGEST_LEN];
- /* Optionally, store ciphertext here */
- uint8_t *ciphertext;
- ssize_t ciphertext_len;
- /* Optionally, store plaintext */
- uint8_t *plaintext;
- ssize_t plaintext_len;
- /* Have we parsed the plaintext? */
- uint8_t parsed;
- /* intro protocol version (0, 1, 2 or 3) */
- uint8_t version;
- /* Version-specific parts */
- union {
- struct {
- /* Rendezvous point nickname */
- uint8_t rp[20];
- } v0;
- struct {
- /* Rendezvous point nickname or hex-encoded key digest */
- uint8_t rp[42];
- } v1;
- struct {
- /* The extend_info_t struct has everything v2 uses */
- extend_info_t *extend_info;
- } v2;
- struct {
- /* Auth type used */
- uint8_t auth_type;
- /* Length of auth data */
- uint16_t auth_len;
- /* Auth data */
- uint8_t *auth_data;
- /* Rendezvous point's IP address/port, identity digest and onion key */
- extend_info_t *extend_info;
- } v3;
- } u;
- /* Rendezvous cookie */
- uint8_t rc[REND_COOKIE_LEN];
- /* Diffie-Hellman data */
- uint8_t dh[DH_KEY_LEN];
- };
- #endif
- int num_rend_services(void);
- int rend_config_services(const or_options_t *options, int validate_only);
- int rend_service_load_all_keys(void);
- void rend_services_add_filenames_to_lists(smartlist_t *open_lst,
- smartlist_t *stat_lst);
- void rend_services_introduce(void);
- void rend_consider_services_upload(time_t now);
- void rend_hsdir_routers_changed(void);
- void rend_consider_descriptor_republication(void);
- void rend_service_intro_has_opened(origin_circuit_t *circuit);
- int rend_service_intro_established(origin_circuit_t *circuit,
- const uint8_t *request,
- size_t request_len);
- void rend_service_rendezvous_has_opened(origin_circuit_t *circuit);
- int rend_service_introduce(origin_circuit_t *circuit, const uint8_t *request,
- size_t request_len);
- int rend_service_decrypt_intro(rend_intro_cell_t *request,
- crypto_pk_t *key,
- char **err_msg_out);
- void rend_service_free_intro(rend_intro_cell_t *request);
- rend_intro_cell_t * rend_service_begin_parse_intro(const uint8_t *request,
- size_t request_len,
- uint8_t type,
- char **err_msg_out);
- int rend_service_parse_intro_plaintext(rend_intro_cell_t *intro,
- char **err_msg_out);
- int rend_service_validate_intro_early(const rend_intro_cell_t *intro,
- char **err_msg_out);
- int rend_service_validate_intro_late(const rend_intro_cell_t *intro,
- char **err_msg_out);
- void rend_service_relaunch_rendezvous(origin_circuit_t *oldcirc);
- int rend_service_set_connection_addr_port(edge_connection_t *conn,
- origin_circuit_t *circ);
- void rend_service_dump_stats(int severity);
- void rend_service_free_all(void);
- #endif
|