2006-02-09 06:46:49 +01:00
|
|
|
/* Copyright (c) 2001 Matej Pfajfar.
|
|
|
|
* Copyright (c) 2001-2004, Roger Dingledine.
|
2007-12-12 22:09:01 +01:00
|
|
|
* Copyright (c) 2004-2006, Roger Dingledine, Nick Mathewson.
|
2009-05-02 22:00:54 +02:00
|
|
|
* Copyright (c) 2007-2009, The Tor Project, Inc. */
|
Implemented link padding and receiver token buckets
Each socket reads at most 'bandwidth' bytes per second sustained, but
can handle bursts of up to 10*bandwidth bytes.
Cells are now sent out at evenly-spaced intervals, with padding sent
out otherwise. Set Linkpadding=0 in the rc file to send cells as soon
as they're available (and to never send padding cells).
Added license/copyrights statements at the top of most files.
router->min and router->max have been merged into a single 'bandwidth'
value. We should make the routerinfo_t reflect this (want to do that,
Mat?)
As the bandwidth increases, and we want to stop sleeping more and more
frequently to send a single cell, cpu usage goes up. At 128kB/s we're
pretty much calling poll with a timeout of 1ms or even 0ms. The current
code takes a timeout of 0-9ms and makes it 10ms. prepare_for_poll()
handles everything that should have happened in the past, so as long as
our buffers don't get too full in that 10ms, we're ok.
Speaking of too full, if you run three servers at 100kB/s with -l debug,
it spends too much time printing debugging messages to be able to keep
up with the cells. The outbuf ultimately fills up and it kills that
connection. If you run with -l err, it works fine up through 500kB/s and
probably beyond. Down the road we'll want to teach it to recognize when
an outbuf is getting full, and back off.
svn:r50
2002-07-16 03:12:15 +02:00
|
|
|
/* See LICENSE for licensing information */
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
/**
|
|
|
|
* \file or.h
|
|
|
|
* \brief Master header file for Tor-specific functionality.
|
2005-06-11 07:31:17 +02:00
|
|
|
**/
|
2004-05-10 08:52:01 +02:00
|
|
|
|
2008-12-29 03:21:02 +01:00
|
|
|
#ifndef _TOR_OR_H
|
|
|
|
#define _TOR_OR_H
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2002-09-03 20:44:24 +02:00
|
|
|
#include "orconfig.h"
|
2008-12-11 22:11:26 +01:00
|
|
|
|
|
|
|
#ifdef __COVERITY__
|
|
|
|
/* If we're building for a static analysis, turn on all the off-by-default
|
|
|
|
* features. */
|
|
|
|
#ifndef INSTRUMENT_DOWNLOADS
|
|
|
|
#define INSTRUMENT_DOWNLOADS 1
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
2004-03-11 07:19:08 +01:00
|
|
|
#ifdef MS_WINDOWS
|
|
|
|
#define WIN32_WINNT 0x400
|
|
|
|
#define _WIN32_WINNT 0x400
|
|
|
|
#define WIN32_LEAN_AND_MEAN
|
|
|
|
#endif
|
2002-09-03 20:44:24 +02:00
|
|
|
|
2003-08-12 05:08:41 +02:00
|
|
|
#ifdef HAVE_UNISTD_H
|
2002-06-27 00:45:49 +02:00
|
|
|
#include <unistd.h>
|
2003-08-12 05:08:41 +02:00
|
|
|
#endif
|
|
|
|
#ifdef HAVE_SIGNAL_H
|
2002-06-27 00:45:49 +02:00
|
|
|
#include <signal.h>
|
2003-08-12 05:08:41 +02:00
|
|
|
#endif
|
|
|
|
#ifdef HAVE_NETDB_H
|
2002-06-27 00:45:49 +02:00
|
|
|
#include <netdb.h>
|
2003-08-12 05:08:41 +02:00
|
|
|
#endif
|
2004-06-01 19:03:01 +02:00
|
|
|
#ifdef HAVE_SYS_PARAM_H
|
|
|
|
#include <sys/param.h> /* FreeBSD needs this to know what version it is */
|
|
|
|
#endif
|
2007-08-08 07:50:31 +02:00
|
|
|
#include "torint.h"
|
2003-08-12 08:41:53 +02:00
|
|
|
#ifdef HAVE_SYS_WAIT_H
|
|
|
|
#include <sys/wait.h>
|
|
|
|
#endif
|
2003-08-12 05:08:41 +02:00
|
|
|
#ifdef HAVE_SYS_FCNTL_H
|
2002-06-27 00:45:49 +02:00
|
|
|
#include <sys/fcntl.h>
|
2003-08-12 05:08:41 +02:00
|
|
|
#endif
|
|
|
|
#ifdef HAVE_FCNTL_H
|
|
|
|
#include <fcntl.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_SYS_IOCTL_H
|
2002-06-27 00:45:49 +02:00
|
|
|
#include <sys/ioctl.h>
|
2003-08-12 05:08:41 +02:00
|
|
|
#endif
|
2007-06-05 22:54:49 +02:00
|
|
|
#ifdef HAVE_SYS_UN_H
|
|
|
|
#include <sys/un.h>
|
|
|
|
#endif
|
2003-08-12 05:08:41 +02:00
|
|
|
#ifdef HAVE_SYS_STAT_H
|
2002-09-24 12:43:57 +02:00
|
|
|
#include <sys/stat.h>
|
2003-08-12 05:08:41 +02:00
|
|
|
#endif
|
|
|
|
#ifdef HAVE_ARPA_INET_H
|
2002-06-27 00:45:49 +02:00
|
|
|
#include <arpa/inet.h>
|
2003-08-12 05:08:41 +02:00
|
|
|
#endif
|
|
|
|
#ifdef HAVE_ERRNO_H
|
2002-06-27 00:45:49 +02:00
|
|
|
#include <errno.h>
|
2003-08-12 05:08:41 +02:00
|
|
|
#endif
|
|
|
|
#ifdef HAVE_ASSERT_H
|
2002-06-27 00:45:49 +02:00
|
|
|
#include <assert.h>
|
2003-08-12 05:08:41 +02:00
|
|
|
#endif
|
|
|
|
#ifdef HAVE_TIME_H
|
2002-08-22 09:30:03 +02:00
|
|
|
#include <time.h>
|
2003-08-12 05:08:41 +02:00
|
|
|
#endif
|
2004-10-21 01:30:38 +02:00
|
|
|
|
2003-08-12 17:08:51 +02:00
|
|
|
#ifdef MS_WINDOWS
|
2003-08-12 05:08:41 +02:00
|
|
|
#include <io.h>
|
2003-10-04 03:37:01 +02:00
|
|
|
#include <process.h>
|
2004-03-09 23:01:17 +01:00
|
|
|
#include <direct.h>
|
2003-08-12 05:08:41 +02:00
|
|
|
#include <windows.h>
|
2003-08-12 17:08:51 +02:00
|
|
|
#define snprintf _snprintf
|
2003-08-12 05:08:41 +02:00
|
|
|
#endif
|
|
|
|
|
2007-08-08 07:50:31 +02:00
|
|
|
#include "crypto.h"
|
|
|
|
#include "tortls.h"
|
|
|
|
#include "log.h"
|
|
|
|
#include "compat.h"
|
|
|
|
#include "container.h"
|
|
|
|
#include "util.h"
|
|
|
|
#include "torgzip.h"
|
2008-07-25 16:43:24 +02:00
|
|
|
#include "address.h"
|
2009-06-04 07:05:23 +02:00
|
|
|
#include "compat_libevent.h"
|
2007-08-19 04:56:16 +02:00
|
|
|
|
2005-06-28 01:35:04 +02:00
|
|
|
/* These signals are defined to help control_signal_act work.
|
|
|
|
*/
|
|
|
|
#ifndef SIGHUP
|
|
|
|
#define SIGHUP 1
|
|
|
|
#endif
|
|
|
|
#ifndef SIGINT
|
|
|
|
#define SIGINT 2
|
|
|
|
#endif
|
|
|
|
#ifndef SIGUSR1
|
|
|
|
#define SIGUSR1 10
|
|
|
|
#endif
|
|
|
|
#ifndef SIGUSR2
|
|
|
|
#define SIGUSR2 12
|
|
|
|
#endif
|
|
|
|
#ifndef SIGTERM
|
|
|
|
#define SIGTERM 15
|
|
|
|
#endif
|
2006-03-09 01:18:16 +01:00
|
|
|
/* Controller signals start at a high number so we don't
|
|
|
|
* conflict with system-defined signals. */
|
|
|
|
#define SIGNEWNYM 129
|
2006-10-25 23:46:21 +02:00
|
|
|
#define SIGCLEARDNSCACHE 130
|
2005-06-28 01:35:04 +02:00
|
|
|
|
2005-02-22 05:26:45 +01:00
|
|
|
#if (SIZEOF_CELL_T != 0)
|
|
|
|
/* On Irix, stdlib.h defines a cell_t type, so we need to make sure
|
|
|
|
* that our stuff always calls cell_t something different. */
|
|
|
|
#define cell_t tor_cell_t
|
|
|
|
#endif
|
|
|
|
|
2007-02-16 21:00:50 +01:00
|
|
|
/** Length of longest allowable configured nickname. */
|
2004-04-05 02:47:48 +02:00
|
|
|
#define MAX_NICKNAME_LEN 19
|
2007-02-16 21:00:50 +01:00
|
|
|
/** Length of a router identity encoded as a hexadecimal digest, plus
|
|
|
|
* possible dollar sign. */
|
2004-11-01 22:46:27 +01:00
|
|
|
#define MAX_HEX_NICKNAME_LEN (HEX_DIGEST_LEN+1)
|
2007-02-24 08:50:38 +01:00
|
|
|
/** Maximum length of verbose router identifier: dollar sign, hex ID digest,
|
|
|
|
* equal sign or tilde, nickname. */
|
2006-10-03 20:58:40 +02:00
|
|
|
#define MAX_VERBOSE_NICKNAME_LEN (1+HEX_DIGEST_LEN+1+MAX_NICKNAME_LEN)
|
|
|
|
|
2005-04-08 00:13:17 +02:00
|
|
|
/** Maximum size, in bytes, for resized buffers. */
|
2007-02-16 21:00:50 +01:00
|
|
|
#define MAX_BUF_SIZE ((1<<24)-1) /* 16MB-1 */
|
2007-02-24 08:50:38 +01:00
|
|
|
/** Maximum size, in bytes, for any directory object that we've downloaded. */
|
2007-02-16 21:00:50 +01:00
|
|
|
#define MAX_DIR_DL_SIZE MAX_BUF_SIZE
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2009-05-27 23:55:51 +02:00
|
|
|
/** For HTTP parsing: Maximum number of bytes we'll accept in the headers
|
2007-02-24 08:50:38 +01:00
|
|
|
* of an HTTP request or response. */
|
2005-02-24 11:56:55 +01:00
|
|
|
#define MAX_HEADERS_SIZE 50000
|
2007-02-16 21:00:50 +01:00
|
|
|
/** Maximum size, in bytes, for any directory object that we're accepting
|
|
|
|
* as an upload. */
|
2009-03-31 06:03:37 +02:00
|
|
|
#define MAX_DIR_UL_SIZE MAX_BUF_SIZE
|
2005-02-24 11:56:55 +01:00
|
|
|
|
2007-12-02 07:11:53 +01:00
|
|
|
/** Maximum size, in bytes, of a single router descriptor uploaded to us
|
|
|
|
* as a directory authority. Caches and clients fetch whatever descriptors
|
|
|
|
* the authorities tell them to fetch, and don't care about size. */
|
|
|
|
#define MAX_DESCRIPTOR_UPLOAD_SIZE 20000
|
|
|
|
|
|
|
|
/** Maximum size of a single extrainfo document, as above. */
|
|
|
|
#define MAX_EXTRAINFO_UPLOAD_SIZE 50000
|
|
|
|
|
2006-06-03 23:41:14 +02:00
|
|
|
/** How long do we keep DNS cache entries before purging them (regardless of
|
|
|
|
* their TTL)? */
|
2005-06-08 21:45:17 +02:00
|
|
|
#define MAX_DNS_ENTRY_AGE (30*60)
|
2007-02-16 21:00:50 +01:00
|
|
|
/** How long do we cache/tell clients to cache DNS records when no TTL is
|
|
|
|
* known? */
|
2006-06-03 23:41:14 +02:00
|
|
|
#define DEFAULT_DNS_TTL (30*60)
|
|
|
|
/** How long can a TTL be before we stop believing it? */
|
|
|
|
#define MAX_DNS_TTL (3*60*60)
|
2007-08-27 17:33:58 +02:00
|
|
|
/** How small can a TTL be before we stop believing it? Provides rudimentary
|
|
|
|
* pinning. */
|
2006-06-03 23:41:14 +02:00
|
|
|
#define MIN_DNS_TTL (60)
|
2003-12-14 08:40:47 +01:00
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
/** How often do we rotate onion keys? */
|
2006-03-12 23:48:18 +01:00
|
|
|
#define MIN_ONION_KEY_LIFETIME (7*24*60*60)
|
2004-05-10 08:52:01 +02:00
|
|
|
/** How often do we rotate TLS contexts? */
|
2006-03-12 23:48:18 +01:00
|
|
|
#define MAX_SSL_KEY_LIFETIME (2*60*60)
|
2004-04-25 00:17:50 +02:00
|
|
|
|
2005-11-26 10:27:36 +01:00
|
|
|
/** How old do we allow a router to get before removing it
|
|
|
|
* from the router list? In seconds. */
|
2006-03-08 07:29:52 +01:00
|
|
|
#define ROUTER_MAX_AGE (60*60*48)
|
|
|
|
/** How old can a router get before we (as a server) will no longer
|
|
|
|
* consider it live? In seconds. */
|
|
|
|
#define ROUTER_MAX_AGE_TO_PUBLISH (60*60*20)
|
2006-10-20 01:04:56 +02:00
|
|
|
/** How old do we let a saved descriptor get before force-removing it? */
|
|
|
|
#define OLD_ROUTER_DESC_MAX_AGE (60*60*24*5)
|
2004-05-20 07:10:30 +02:00
|
|
|
|
2007-02-16 21:00:50 +01:00
|
|
|
/** Possible rules for generating circuit IDs on an OR connection. */
|
2004-11-10 21:14:37 +01:00
|
|
|
typedef enum {
|
2007-02-16 21:00:50 +01:00
|
|
|
CIRC_ID_TYPE_LOWER=0, /**< Pick from 0..1<<15-1. */
|
2007-02-24 08:50:38 +01:00
|
|
|
CIRC_ID_TYPE_HIGHER=1, /**< Pick from 1<<15..1<<16-1. */
|
2007-02-16 21:00:50 +01:00
|
|
|
/** The other side of a connection is an OP: never create circuits to it,
|
|
|
|
* and let it use any circuit ID it wants. */
|
2007-02-12 22:39:33 +01:00
|
|
|
CIRC_ID_TYPE_NEITHER=2
|
2004-11-10 21:14:37 +01:00
|
|
|
} circ_id_type_t;
|
Integrated onion proxy into or/
The 'or' process can now be told (by the global_role variable) what
roles this server should play -- connect to all ORs, listen for ORs,
listen for OPs, listen for APs, or any combination.
* everything in /src/op/ is now obsolete.
* connection_ap.c now handles all interactions with application proxies
* "port" is now or_port, op_port, ap_port. But routers are still always
referenced (say, in conn_get_by_addr_port()) by addr / or_port. We
should make routers.c actually read these new ports (currently I've
kludged it so op_port = or_port+10, ap_port=or_port+20)
* circuits currently know if they're at the beginning of the path because
circ->cpath is set. They use this instead for crypts (both ways),
if it's set.
* I still obey the "send a 0 back to the AP when you're ready" protocol,
but I think we should phase it out. I can simply not read from the AP
socket until I'm ready.
I need to do a lot of cleanup work here, but the code appears to work, so
now's a good time for a checkin.
svn:r22
2002-07-02 11:36:58 +02:00
|
|
|
|
2003-09-16 21:36:19 +02:00
|
|
|
#define _CONN_TYPE_MIN 3
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Type for sockets listening for OR connections. */
|
2002-06-27 00:45:49 +02:00
|
|
|
#define CONN_TYPE_OR_LISTENER 3
|
2005-06-11 08:07:22 +02:00
|
|
|
/** A bidirectional TLS connection transmitting a sequence of cells.
|
|
|
|
* May be from an OR to an OR, or from an OP to an OR. */
|
2002-06-27 00:45:49 +02:00
|
|
|
#define CONN_TYPE_OR 4
|
2005-06-11 08:07:22 +02:00
|
|
|
/** A TCP connection from an onion router to a stream's destination. */
|
2002-06-30 09:37:49 +02:00
|
|
|
#define CONN_TYPE_EXIT 5
|
2004-05-10 12:27:54 +02:00
|
|
|
/** Type for sockets listening for SOCKS connections. */
|
2002-06-30 09:37:49 +02:00
|
|
|
#define CONN_TYPE_AP_LISTENER 6
|
2005-06-11 08:07:22 +02:00
|
|
|
/** A SOCKS proxy connection from the user application to the onion
|
|
|
|
* proxy. */
|
2002-06-30 09:37:49 +02:00
|
|
|
#define CONN_TYPE_AP 7
|
2004-05-10 12:27:54 +02:00
|
|
|
/** Type for sockets listening for HTTP connections to the directory server. */
|
2002-09-26 14:09:10 +02:00
|
|
|
#define CONN_TYPE_DIR_LISTENER 8
|
2004-05-10 12:27:54 +02:00
|
|
|
/** Type for HTTP connections to the directory server. */
|
2002-09-26 14:09:10 +02:00
|
|
|
#define CONN_TYPE_DIR 9
|
2005-06-11 08:07:22 +02:00
|
|
|
/** Connection from the main process to a CPU worker process. */
|
2007-03-05 03:40:58 +01:00
|
|
|
#define CONN_TYPE_CPUWORKER 10
|
2006-03-18 10:29:05 +01:00
|
|
|
/** Type for listening for connections from user interface process. */
|
2007-03-05 03:40:58 +01:00
|
|
|
#define CONN_TYPE_CONTROL_LISTENER 11
|
2006-03-18 10:29:05 +01:00
|
|
|
/** Type for connections from user interface process. */
|
2007-03-05 03:40:58 +01:00
|
|
|
#define CONN_TYPE_CONTROL 12
|
2006-11-14 01:06:31 +01:00
|
|
|
/** Type for sockets listening for transparent connections redirected by pf or
|
|
|
|
* netfilter. */
|
2007-03-05 03:40:58 +01:00
|
|
|
#define CONN_TYPE_AP_TRANS_LISTENER 13
|
2006-11-14 01:06:31 +01:00
|
|
|
/** Type for sockets listening for transparent connections redirected by
|
|
|
|
* natd. */
|
2007-03-05 03:40:58 +01:00
|
|
|
#define CONN_TYPE_AP_NATD_LISTENER 14
|
2007-05-24 22:31:30 +02:00
|
|
|
/** Type for sockets listening for DNS requests. */
|
|
|
|
#define CONN_TYPE_AP_DNS_LISTENER 15
|
|
|
|
#define _CONN_TYPE_MAX 15
|
2007-08-14 22:19:51 +02:00
|
|
|
/* !!!! If _CONN_TYPE_MAX is ever over 15, we must grow the type field in
|
|
|
|
* connection_t. */
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2009-06-19 01:59:18 +02:00
|
|
|
/* Proxy client types */
|
|
|
|
#define PROXY_NONE 0
|
|
|
|
#define PROXY_CONNECT 1
|
|
|
|
#define PROXY_SOCKS4 2
|
|
|
|
#define PROXY_SOCKS5 3
|
|
|
|
|
|
|
|
/* Proxy client handshake states */
|
|
|
|
#define PROXY_HTTPS_WANT_CONNECT_OK 1
|
|
|
|
#define PROXY_SOCKS4_WANT_CONNECT_OK 2
|
|
|
|
#define PROXY_SOCKS5_WANT_AUTH_METHOD_NONE 3
|
|
|
|
#define PROXY_SOCKS5_WANT_AUTH_METHOD_RFC1929 4
|
|
|
|
#define PROXY_SOCKS5_WANT_AUTH_RFC1929_OK 5
|
|
|
|
#define PROXY_SOCKS5_WANT_CONNECT_OK 6
|
|
|
|
#define PROXY_CONNECTED 7
|
|
|
|
|
2008-12-17 15:59:28 +01:00
|
|
|
/** True iff <b>x</b> is an edge connection. */
|
2005-12-14 21:40:40 +01:00
|
|
|
#define CONN_IS_EDGE(x) \
|
|
|
|
((x)->type == CONN_TYPE_EXIT || (x)->type == CONN_TYPE_AP)
|
2004-11-21 08:43:12 +01:00
|
|
|
|
2004-05-10 12:27:54 +02:00
|
|
|
/** State for any listener connection. */
|
2002-06-27 00:45:49 +02:00
|
|
|
#define LISTENER_STATE_READY 0
|
|
|
|
|
2003-09-27 09:33:07 +02:00
|
|
|
#define _CPUWORKER_STATE_MIN 1
|
2004-05-10 12:27:54 +02:00
|
|
|
/** State for a connection to a cpuworker process that's idle. */
|
2003-09-27 09:33:07 +02:00
|
|
|
#define CPUWORKER_STATE_IDLE 1
|
2004-05-10 08:52:01 +02:00
|
|
|
/** State for a connection to a cpuworker process that's processing a
|
2004-05-10 12:27:54 +02:00
|
|
|
* handshake. */
|
2003-09-27 09:33:07 +02:00
|
|
|
#define CPUWORKER_STATE_BUSY_ONION 2
|
2004-05-10 08:52:01 +02:00
|
|
|
#define _CPUWORKER_STATE_MAX 2
|
2003-08-21 01:05:22 +02:00
|
|
|
|
|
|
|
#define CPUWORKER_TASK_ONION CPUWORKER_STATE_BUSY_ONION
|
|
|
|
|
2003-09-27 09:33:07 +02:00
|
|
|
#define _OR_CONN_STATE_MIN 1
|
2004-05-10 12:27:54 +02:00
|
|
|
/** State for a connection to an OR: waiting for connect() to finish. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define OR_CONN_STATE_CONNECTING 1
|
2009-06-19 01:59:18 +02:00
|
|
|
/** State for a connection to an OR: waiting for proxy handshake to complete */
|
|
|
|
#define OR_CONN_STATE_PROXY_HANDSHAKING 2
|
2008-02-08 22:13:15 +01:00
|
|
|
/** State for a connection to an OR or client: SSL is handshaking, not done
|
|
|
|
* yet. */
|
2009-06-19 01:59:18 +02:00
|
|
|
#define OR_CONN_STATE_TLS_HANDSHAKING 3
|
2008-02-08 22:13:15 +01:00
|
|
|
/** State for a connection to an OR: We're doing a second SSL handshake for
|
|
|
|
* renegotiation purposes. */
|
2009-06-19 01:59:18 +02:00
|
|
|
#define OR_CONN_STATE_TLS_CLIENT_RENEGOTIATING 4
|
2008-02-08 22:13:15 +01:00
|
|
|
/** State for a connection at an OR: We're waiting for the client to
|
|
|
|
* renegotiate. */
|
2009-06-19 01:59:18 +02:00
|
|
|
#define OR_CONN_STATE_TLS_SERVER_RENEGOTIATING 5
|
2007-11-05 19:15:44 +01:00
|
|
|
/** State for a connection to an OR: We're done with our SSL handshake, but we
|
2008-02-08 22:13:15 +01:00
|
|
|
* haven't yet negotiated link protocol versions and sent a netinfo cell.
|
2007-10-30 22:46:02 +01:00
|
|
|
*/
|
2009-06-19 01:59:18 +02:00
|
|
|
#define OR_CONN_STATE_OR_HANDSHAKING 6
|
2004-05-10 08:52:01 +02:00
|
|
|
/** State for a connection to an OR: Ready to send/receive cells. */
|
2009-06-19 01:59:18 +02:00
|
|
|
#define OR_CONN_STATE_OPEN 7
|
|
|
|
#define _OR_CONN_STATE_MAX 7
|
2003-09-27 09:33:07 +02:00
|
|
|
|
|
|
|
#define _EXIT_CONN_STATE_MIN 1
|
2009-05-27 23:55:51 +02:00
|
|
|
/** State for an exit connection: waiting for response from DNS farm. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define EXIT_CONN_STATE_RESOLVING 1
|
2004-05-10 12:27:54 +02:00
|
|
|
/** State for an exit connection: waiting for connect() to finish. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define EXIT_CONN_STATE_CONNECTING 2
|
2004-05-10 12:27:54 +02:00
|
|
|
/** State for an exit connection: open and ready to transmit data. */
|
2003-09-27 09:33:07 +02:00
|
|
|
#define EXIT_CONN_STATE_OPEN 3
|
2004-05-10 12:27:54 +02:00
|
|
|
/** State for an exit connection: waiting to be removed. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define EXIT_CONN_STATE_RESOLVEFAILED 4
|
2004-03-02 08:24:11 +01:00
|
|
|
#define _EXIT_CONN_STATE_MAX 4
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2007-02-24 08:50:38 +01:00
|
|
|
/* The AP state values must be disjoint from the EXIT state values. */
|
2004-03-02 08:24:11 +01:00
|
|
|
#define _AP_CONN_STATE_MIN 5
|
2004-05-10 12:27:54 +02:00
|
|
|
/** State for a SOCKS connection: waiting for SOCKS request. */
|
2004-03-02 08:24:11 +01:00
|
|
|
#define AP_CONN_STATE_SOCKS_WAIT 5
|
2004-05-10 08:52:01 +02:00
|
|
|
/** State for a SOCKS connection: got a y.onion URL; waiting to receive
|
2006-03-18 10:29:05 +01:00
|
|
|
* rendezvous descriptor. */
|
2004-04-05 02:47:48 +02:00
|
|
|
#define AP_CONN_STATE_RENDDESC_WAIT 6
|
2005-03-12 05:22:01 +01:00
|
|
|
/** The controller will attach this connection to a circuit; it isn't our
|
|
|
|
* job to do so. */
|
|
|
|
#define AP_CONN_STATE_CONTROLLER_WAIT 7
|
2004-05-10 12:27:54 +02:00
|
|
|
/** State for a SOCKS connection: waiting for a completed circuit. */
|
2005-03-12 05:22:01 +01:00
|
|
|
#define AP_CONN_STATE_CIRCUIT_WAIT 8
|
2004-05-10 12:27:54 +02:00
|
|
|
/** State for a SOCKS connection: sent BEGIN, waiting for CONNECTED. */
|
2005-03-12 05:22:01 +01:00
|
|
|
#define AP_CONN_STATE_CONNECT_WAIT 9
|
2007-01-15 10:09:03 +01:00
|
|
|
/** State for a SOCKS connection: sent RESOLVE, waiting for RESOLVED. */
|
2005-03-12 05:22:01 +01:00
|
|
|
#define AP_CONN_STATE_RESOLVE_WAIT 10
|
2004-05-10 12:27:54 +02:00
|
|
|
/** State for a SOCKS connection: ready to send and receive. */
|
2005-03-12 05:22:01 +01:00
|
|
|
#define AP_CONN_STATE_OPEN 11
|
2006-11-14 01:06:31 +01:00
|
|
|
/** State for a transparent natd connection: waiting for original
|
|
|
|
* destination. */
|
|
|
|
#define AP_CONN_STATE_NATD_WAIT 12
|
|
|
|
#define _AP_CONN_STATE_MAX 12
|
2004-04-01 23:32:01 +02:00
|
|
|
|
2007-02-16 21:00:50 +01:00
|
|
|
/** True iff the AP_CONN_STATE_* value <b>s</b> means that the corresponding
|
|
|
|
* edge connection is not attached to any circuit. */
|
2007-01-15 10:09:03 +01:00
|
|
|
#define AP_CONN_STATE_IS_UNATTACHED(s) \
|
|
|
|
((s) <= AP_CONN_STATE_CIRCUIT_WAIT || (s) == AP_CONN_STATE_NATD_WAIT)
|
|
|
|
|
2003-09-27 09:33:07 +02:00
|
|
|
#define _DIR_CONN_STATE_MIN 1
|
2004-05-10 12:27:54 +02:00
|
|
|
/** State for connection to directory server: waiting for connect(). */
|
2004-03-31 00:57:49 +02:00
|
|
|
#define DIR_CONN_STATE_CONNECTING 1
|
2004-05-10 12:27:54 +02:00
|
|
|
/** State for connection to directory server: sending HTTP request. */
|
2004-03-31 00:57:49 +02:00
|
|
|
#define DIR_CONN_STATE_CLIENT_SENDING 2
|
2004-05-10 12:27:54 +02:00
|
|
|
/** State for connection to directory server: reading HTTP response. */
|
2004-03-31 00:57:49 +02:00
|
|
|
#define DIR_CONN_STATE_CLIENT_READING 3
|
2005-09-12 09:36:26 +02:00
|
|
|
/** State for connection to directory server: happy and finished. */
|
|
|
|
#define DIR_CONN_STATE_CLIENT_FINISHED 4
|
2004-05-10 12:27:54 +02:00
|
|
|
/** State for connection at directory server: waiting for HTTP request. */
|
2005-09-12 09:36:26 +02:00
|
|
|
#define DIR_CONN_STATE_SERVER_COMMAND_WAIT 5
|
2004-05-10 12:27:54 +02:00
|
|
|
/** State for connection at directory server: sending HTTP response. */
|
2005-09-12 09:36:26 +02:00
|
|
|
#define DIR_CONN_STATE_SERVER_WRITING 6
|
|
|
|
#define _DIR_CONN_STATE_MAX 6
|
2004-03-31 00:57:49 +02:00
|
|
|
|
2007-02-16 21:00:50 +01:00
|
|
|
/** True iff the purpose of <b>conn</b> means that it's a server-side
|
|
|
|
* directory connection. */
|
2006-08-28 20:51:36 +02:00
|
|
|
#define DIR_CONN_IS_SERVER(conn) ((conn)->purpose == DIR_PURPOSE_SERVER)
|
|
|
|
|
2004-11-03 02:32:26 +01:00
|
|
|
#define _CONTROL_CONN_STATE_MIN 1
|
2007-02-16 21:00:50 +01:00
|
|
|
/** State for a control connection: Authenticated and accepting v1 commands. */
|
2007-03-04 22:08:28 +01:00
|
|
|
#define CONTROL_CONN_STATE_OPEN 1
|
2007-02-16 21:00:50 +01:00
|
|
|
/** State for a control connection: Waiting for authentication; speaking
|
|
|
|
* protocol v1. */
|
2007-03-04 22:08:28 +01:00
|
|
|
#define CONTROL_CONN_STATE_NEEDAUTH 2
|
|
|
|
#define _CONTROL_CONN_STATE_MAX 2
|
2004-11-03 02:32:26 +01:00
|
|
|
|
2008-12-08 00:53:39 +01:00
|
|
|
#define _DIR_PURPOSE_MIN 3
|
2005-11-19 11:12:10 +01:00
|
|
|
/** A connection to a directory server: download a rendezvous
|
2004-05-10 08:52:01 +02:00
|
|
|
* descriptor. */
|
2004-06-16 23:08:29 +02:00
|
|
|
#define DIR_PURPOSE_FETCH_RENDDESC 3
|
2005-11-19 11:12:10 +01:00
|
|
|
/** A connection to a directory server: set after a rendezvous
|
2004-05-10 08:52:01 +02:00
|
|
|
* descriptor is downloaded. */
|
2004-06-16 23:08:29 +02:00
|
|
|
#define DIR_PURPOSE_HAS_FETCHED_RENDDESC 4
|
2008-06-07 07:01:22 +02:00
|
|
|
/** A connection to a directory server: download one or more v2
|
|
|
|
* network-status objects */
|
2008-12-17 18:20:48 +01:00
|
|
|
#define DIR_PURPOSE_FETCH_V2_NETWORKSTATUS 5
|
2005-11-19 11:12:10 +01:00
|
|
|
/** A connection to a directory server: download one or more server
|
2005-09-07 22:03:02 +02:00
|
|
|
* descriptors. */
|
|
|
|
#define DIR_PURPOSE_FETCH_SERVERDESC 6
|
2007-05-18 23:19:19 +02:00
|
|
|
/** A connection to a directory server: download one or more extra-info
|
|
|
|
* documents. */
|
|
|
|
#define DIR_PURPOSE_FETCH_EXTRAINFO 7
|
2005-11-19 11:12:10 +01:00
|
|
|
/** A connection to a directory server: upload a server descriptor. */
|
2007-05-18 23:19:19 +02:00
|
|
|
#define DIR_PURPOSE_UPLOAD_DIR 8
|
2005-11-19 11:12:10 +01:00
|
|
|
/** A connection to a directory server: upload a rendezvous
|
2004-05-10 12:27:54 +02:00
|
|
|
* descriptor. */
|
2007-05-18 23:19:19 +02:00
|
|
|
#define DIR_PURPOSE_UPLOAD_RENDDESC 9
|
2007-07-26 00:56:44 +02:00
|
|
|
/** A connection to a directory server: upload a v3 networkstatus vote. */
|
|
|
|
#define DIR_PURPOSE_UPLOAD_VOTE 10
|
2007-07-29 04:55:21 +02:00
|
|
|
/** A connection to a directory server: upload a v3 consensus signature */
|
2007-10-16 01:15:24 +02:00
|
|
|
#define DIR_PURPOSE_UPLOAD_SIGNATURES 11
|
2008-12-17 15:59:28 +01:00
|
|
|
/** A connection to a directory server: download one or more v3 networkstatus
|
|
|
|
* votes. */
|
2007-10-16 01:15:24 +02:00
|
|
|
#define DIR_PURPOSE_FETCH_STATUS_VOTE 12
|
2008-12-17 15:59:28 +01:00
|
|
|
/** A connection to a directory server: download a v3 detached signatures
|
|
|
|
* object for a consensus. */
|
2007-10-16 01:15:24 +02:00
|
|
|
#define DIR_PURPOSE_FETCH_DETACHED_SIGNATURES 13
|
2008-12-17 15:59:28 +01:00
|
|
|
/** A connection to a directory server: download a v3 networkstatus
|
2008-12-17 16:04:43 +01:00
|
|
|
* consensus. */
|
2007-10-16 01:15:24 +02:00
|
|
|
#define DIR_PURPOSE_FETCH_CONSENSUS 14
|
2008-12-17 15:59:28 +01:00
|
|
|
/** A connection to a directory server: download one or more directory
|
|
|
|
* authority certificates. */
|
2007-10-16 01:15:24 +02:00
|
|
|
#define DIR_PURPOSE_FETCH_CERTIFICATE 15
|
2007-07-26 00:56:44 +02:00
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Purpose for connection at a directory server. */
|
2007-10-16 01:15:24 +02:00
|
|
|
#define DIR_PURPOSE_SERVER 16
|
2007-10-29 20:10:42 +01:00
|
|
|
/** A connection to a hidden service directory server: upload a v2 rendezvous
|
|
|
|
* descriptor. */
|
|
|
|
#define DIR_PURPOSE_UPLOAD_RENDDESC_V2 17
|
|
|
|
/** A connection to a hidden service directory server: download a v2 rendezvous
|
|
|
|
* descriptor. */
|
|
|
|
#define DIR_PURPOSE_FETCH_RENDDESC_V2 18
|
|
|
|
#define _DIR_PURPOSE_MAX 18
|
2002-09-26 14:09:10 +02:00
|
|
|
|
2008-12-17 15:59:28 +01:00
|
|
|
/** True iff <b>p</b> is a purpose corresponding to uploading data to a
|
|
|
|
* directory server. */
|
2008-05-27 23:02:36 +02:00
|
|
|
#define DIR_PURPOSE_IS_UPLOAD(p) \
|
|
|
|
((p)==DIR_PURPOSE_UPLOAD_DIR || \
|
|
|
|
(p)==DIR_PURPOSE_UPLOAD_RENDDESC || \
|
|
|
|
(p)==DIR_PURPOSE_UPLOAD_VOTE || \
|
|
|
|
(p)==DIR_PURPOSE_UPLOAD_SIGNATURES)
|
|
|
|
|
2004-06-17 20:13:09 +02:00
|
|
|
#define _EXIT_PURPOSE_MIN 1
|
2006-09-25 07:59:13 +02:00
|
|
|
/** This exit stream wants to do an ordinary connect. */
|
2004-06-17 20:13:09 +02:00
|
|
|
#define EXIT_PURPOSE_CONNECT 1
|
2006-09-25 07:59:13 +02:00
|
|
|
/** This exit stream wants to do a resolve (either normal or reverse). */
|
2004-06-17 20:13:09 +02:00
|
|
|
#define EXIT_PURPOSE_RESOLVE 2
|
|
|
|
#define _EXIT_PURPOSE_MAX 2
|
|
|
|
|
2009-01-06 22:28:48 +01:00
|
|
|
/* !!!! If any connection purpose is ever over 31, we must grow the type
|
2007-08-14 22:19:51 +02:00
|
|
|
* field in connection_t. */
|
|
|
|
|
2005-11-17 02:17:53 +01:00
|
|
|
/** Circuit state: I'm the origin, still haven't done all my handshakes. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_STATE_BUILDING 0
|
2004-05-10 12:27:54 +02:00
|
|
|
/** Circuit state: Waiting to process the onionskin. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_STATE_ONIONSKIN_PENDING 1
|
2005-12-14 21:40:40 +01:00
|
|
|
/** Circuit state: I'd like to deliver a create, but my n_conn is still
|
|
|
|
* connecting. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_STATE_OR_WAIT 2
|
2004-05-10 12:27:54 +02:00
|
|
|
/** Circuit state: onionskin(s) processed, ready to send/receive cells. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_STATE_OPEN 3
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2004-03-30 00:14:19 +02:00
|
|
|
#define _CIRCUIT_PURPOSE_MIN 1
|
2004-04-05 02:47:48 +02:00
|
|
|
|
2004-03-30 00:14:19 +02:00
|
|
|
/* these circuits were initiated elsewhere */
|
2004-04-08 04:24:06 +02:00
|
|
|
#define _CIRCUIT_PURPOSE_OR_MIN 1
|
2004-05-10 08:52:01 +02:00
|
|
|
/** OR-side circuit purpose: normal circuit, at OR. */
|
|
|
|
#define CIRCUIT_PURPOSE_OR 1
|
2004-05-10 12:27:54 +02:00
|
|
|
/** OR-side circuit purpose: At OR, from Bob, waiting for intro from Alices. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_PURPOSE_INTRO_POINT 2
|
2004-05-10 12:27:54 +02:00
|
|
|
/** OR-side circuit purpose: At OR, from Alice, waiting for Bob. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_PURPOSE_REND_POINT_WAITING 3
|
2004-05-10 12:27:54 +02:00
|
|
|
/** OR-side circuit purpose: At OR, both circuits have this purpose. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_PURPOSE_REND_ESTABLISHED 4
|
2004-04-08 04:24:06 +02:00
|
|
|
#define _CIRCUIT_PURPOSE_OR_MAX 4
|
2004-04-05 02:47:48 +02:00
|
|
|
|
2004-03-30 21:52:42 +02:00
|
|
|
/* these circuits originate at this node */
|
2004-04-05 02:47:48 +02:00
|
|
|
|
|
|
|
/* here's how circ client-side purposes work:
|
|
|
|
* normal circuits are C_GENERAL.
|
|
|
|
* circuits that are c_introducing are either on their way to
|
2004-04-13 07:20:52 +02:00
|
|
|
* becoming open, or they are open and waiting for a
|
|
|
|
* suitable rendcirc before they send the intro.
|
|
|
|
* circuits that are c_introduce_ack_wait have sent the intro,
|
|
|
|
* but haven't gotten a response yet.
|
2004-04-05 02:47:48 +02:00
|
|
|
* circuits that are c_establish_rend are either on their way
|
|
|
|
* to becoming open, or they are open and have sent the
|
|
|
|
* establish_rendezvous cell but haven't received an ack.
|
2004-04-14 00:56:24 +02:00
|
|
|
* circuits that are c_rend_ready are open and have received a
|
|
|
|
* rend ack, but haven't heard from bob yet. if they have a
|
2004-04-05 02:47:48 +02:00
|
|
|
* buildstate->pending_final_cpath then they're expecting a
|
|
|
|
* cell from bob, else they're not.
|
2004-04-14 00:56:24 +02:00
|
|
|
* circuits that are c_rend_ready_intro_acked are open, and
|
|
|
|
* some intro circ has sent its intro and received an ack.
|
2004-04-05 02:47:48 +02:00
|
|
|
* circuits that are c_rend_joined are open, have heard from
|
|
|
|
* bob, and are talking to him.
|
|
|
|
*/
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Client-side circuit purpose: Normal circuit, with cpath. */
|
|
|
|
#define CIRCUIT_PURPOSE_C_GENERAL 5
|
2004-05-10 12:27:54 +02:00
|
|
|
/** Client-side circuit purpose: at Alice, connecting to intro point. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_PURPOSE_C_INTRODUCING 6
|
2005-12-14 21:40:40 +01:00
|
|
|
/** Client-side circuit purpose: at Alice, sent INTRODUCE1 to intro point,
|
|
|
|
* waiting for ACK/NAK. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_PURPOSE_C_INTRODUCE_ACK_WAIT 7
|
2004-05-10 12:27:54 +02:00
|
|
|
/** Client-side circuit purpose: at Alice, introduced and acked, closing. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_PURPOSE_C_INTRODUCE_ACKED 8
|
2004-05-10 12:27:54 +02:00
|
|
|
/** Client-side circuit purpose: at Alice, waiting for ack. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_PURPOSE_C_ESTABLISH_REND 9
|
2004-05-10 12:27:54 +02:00
|
|
|
/** Client-side circuit purpose: at Alice, waiting for Bob. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_PURPOSE_C_REND_READY 10
|
|
|
|
/** Client-side circuit purpose: at Alice, waiting for Bob, INTRODUCE
|
|
|
|
* has been acknowledged. */
|
|
|
|
#define CIRCUIT_PURPOSE_C_REND_READY_INTRO_ACKED 11
|
2004-05-10 12:27:54 +02:00
|
|
|
/** Client-side circuit purpose: at Alice, rendezvous established. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_PURPOSE_C_REND_JOINED 12
|
|
|
|
|
2008-12-12 21:30:42 +01:00
|
|
|
#define _CIRCUIT_PURPOSE_C_MAX 12
|
|
|
|
|
2004-05-10 12:27:54 +02:00
|
|
|
/** Hidden-service-side circuit purpose: at Bob, waiting for introductions. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_PURPOSE_S_ESTABLISH_INTRO 13
|
|
|
|
/** Hidden-service-side circuit purpose: at Bob, successfully established
|
2004-05-10 12:27:54 +02:00
|
|
|
* intro. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_PURPOSE_S_INTRO 14
|
2004-05-10 12:27:54 +02:00
|
|
|
/** Hidden-service-side circuit purpose: at Bob, connecting to rend point. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_PURPOSE_S_CONNECT_REND 15
|
2004-05-10 12:27:54 +02:00
|
|
|
/** Hidden-service-side circuit purpose: at Bob, rendezvous established. */
|
2004-05-10 08:52:01 +02:00
|
|
|
#define CIRCUIT_PURPOSE_S_REND_JOINED 16
|
2005-02-27 10:47:01 +01:00
|
|
|
/** A testing circuit; not meant to be used for actual traffic. */
|
|
|
|
#define CIRCUIT_PURPOSE_TESTING 17
|
2006-02-23 07:51:09 +01:00
|
|
|
/** A controller made this circuit and Tor should not use it. */
|
|
|
|
#define CIRCUIT_PURPOSE_CONTROLLER 18
|
|
|
|
#define _CIRCUIT_PURPOSE_MAX 18
|
2007-10-12 09:57:29 +02:00
|
|
|
/** A catch-all for unrecognized purposes. Currently we don't expect
|
|
|
|
* to make or see any circuits with this purpose. */
|
|
|
|
#define CIRCUIT_PURPOSE_UNKNOWN 255
|
2004-03-30 00:14:19 +02:00
|
|
|
|
2005-11-17 02:17:53 +01:00
|
|
|
/** True iff the circuit purpose <b>p</b> is for a circuit that
|
|
|
|
* originated at this node. */
|
2004-04-08 04:24:06 +02:00
|
|
|
#define CIRCUIT_PURPOSE_IS_ORIGIN(p) ((p)>_CIRCUIT_PURPOSE_OR_MAX)
|
2008-12-17 15:59:28 +01:00
|
|
|
/** True iff the circuit purpose <b>p</b> is for a circuit that originated
|
|
|
|
* here to serve as a client. (Hidden services don't count here.) */
|
2009-05-23 05:33:44 +02:00
|
|
|
#define CIRCUIT_PURPOSE_IS_CLIENT(p) \
|
2008-12-12 21:30:42 +01:00
|
|
|
((p)> _CIRCUIT_PURPOSE_OR_MAX && \
|
|
|
|
(p)<=_CIRCUIT_PURPOSE_C_MAX)
|
2008-12-17 15:59:28 +01:00
|
|
|
/** True iff the circuit_t <b>c</b> is actually an origin_circuit_t. */
|
2004-04-08 04:24:06 +02:00
|
|
|
#define CIRCUIT_IS_ORIGIN(c) (CIRCUIT_PURPOSE_IS_ORIGIN((c)->purpose))
|
2009-07-28 03:01:24 +02:00
|
|
|
/** True iff the circuit purpose <b>p</b> is for an established rendezvous
|
|
|
|
* circuit. */
|
|
|
|
#define CIRCUIT_PURPOSE_IS_ESTABLISHED_REND(p) \
|
|
|
|
((p) == CIRCUIT_PURPOSE_C_REND_JOINED || \
|
|
|
|
(p) == CIRCUIT_PURPOSE_S_REND_JOINED)
|
2004-04-08 04:24:06 +02:00
|
|
|
|
2006-12-10 09:04:50 +01:00
|
|
|
/** How many circuits do we want simultaneously in-progress to handle
|
|
|
|
* a given stream? */
|
|
|
|
#define MIN_CIRCUITS_HANDLING_STREAM 2
|
|
|
|
|
2008-12-17 15:59:28 +01:00
|
|
|
/* These RELAY_COMMAND constants define values for relay cell commands, and
|
|
|
|
* must match those defined in tor-spec.txt. */
|
2003-05-01 08:42:29 +02:00
|
|
|
#define RELAY_COMMAND_BEGIN 1
|
|
|
|
#define RELAY_COMMAND_DATA 2
|
|
|
|
#define RELAY_COMMAND_END 3
|
|
|
|
#define RELAY_COMMAND_CONNECTED 4
|
|
|
|
#define RELAY_COMMAND_SENDME 5
|
2003-05-06 01:24:46 +02:00
|
|
|
#define RELAY_COMMAND_EXTEND 6
|
|
|
|
#define RELAY_COMMAND_EXTENDED 7
|
2003-06-12 12:16:33 +02:00
|
|
|
#define RELAY_COMMAND_TRUNCATE 8
|
|
|
|
#define RELAY_COMMAND_TRUNCATED 9
|
2003-11-17 01:57:56 +01:00
|
|
|
#define RELAY_COMMAND_DROP 10
|
2004-03-08 00:50:15 +01:00
|
|
|
#define RELAY_COMMAND_RESOLVE 11
|
|
|
|
#define RELAY_COMMAND_RESOLVED 12
|
2006-09-29 05:50:11 +02:00
|
|
|
#define RELAY_COMMAND_BEGIN_DIR 13
|
major overhaul: dns slave subsystem, topics
on startup, it forks off a master dns handler, which forks off dns
slaves (like the apache model). slaves as spawned as load increases,
and then reused. excess slaves are not ever killed, currently.
implemented topics. each topic has a receive window in each direction
at each edge of the circuit, and sends sendme's at the data level, as
per before. each circuit also has receive windows in each direction at
each hop; an edge sends a circuit-level sendme as soon as enough data
cells have arrived (regardless of whether the data cells were flushed
to the exit conns). removed the 'connected' cell type, since it's now
a topic command within data cells.
at the edge of the circuit, there can be multiple connections associated
with a single circuit. you find them via the linked list conn->next_topic.
currently each new ap connection starts its own circuit, so we ought
to see comparable performance to what we had before. but that's only
because i haven't written the code to reattach to old circuits. please
try to break it as-is, and then i'll make it reuse the same circuit and
we'll try to break that.
svn:r152
2003-01-26 10:02:24 +01:00
|
|
|
|
2004-04-01 03:11:28 +02:00
|
|
|
#define RELAY_COMMAND_ESTABLISH_INTRO 32
|
|
|
|
#define RELAY_COMMAND_ESTABLISH_RENDEZVOUS 33
|
|
|
|
#define RELAY_COMMAND_INTRODUCE1 34
|
|
|
|
#define RELAY_COMMAND_INTRODUCE2 35
|
2004-04-13 02:38:16 +02:00
|
|
|
#define RELAY_COMMAND_RENDEZVOUS1 36
|
|
|
|
#define RELAY_COMMAND_RENDEZVOUS2 37
|
|
|
|
#define RELAY_COMMAND_INTRO_ESTABLISHED 38
|
|
|
|
#define RELAY_COMMAND_RENDEZVOUS_ESTABLISHED 39
|
|
|
|
#define RELAY_COMMAND_INTRODUCE_ACK 40
|
2004-04-01 03:11:28 +02:00
|
|
|
|
2008-12-17 15:59:28 +01:00
|
|
|
/* Reasons why an OR connection is closed. */
|
2008-06-11 03:14:23 +02:00
|
|
|
#define END_OR_CONN_REASON_DONE 1
|
|
|
|
#define END_OR_CONN_REASON_REFUSED 2 /* connection refused */
|
|
|
|
#define END_OR_CONN_REASON_OR_IDENTITY 3
|
|
|
|
#define END_OR_CONN_REASON_CONNRESET 4 /* connection reset by peer */
|
|
|
|
#define END_OR_CONN_REASON_TIMEOUT 5
|
|
|
|
#define END_OR_CONN_REASON_NO_ROUTE 6 /* no route to host/net */
|
|
|
|
#define END_OR_CONN_REASON_IO_ERROR 7 /* read/write error */
|
|
|
|
#define END_OR_CONN_REASON_RESOURCE_LIMIT 8 /* sockets, buffers, etc */
|
|
|
|
#define END_OR_CONN_REASON_MISC 9
|
2007-01-15 22:13:37 +01:00
|
|
|
|
2006-11-17 04:34:58 +01:00
|
|
|
/* Reasons why we (or a remote OR) might close a stream. See tor-spec.txt for
|
2008-12-17 15:59:28 +01:00
|
|
|
* documentation of these. The values must match. */
|
2003-10-22 09:55:44 +02:00
|
|
|
#define END_STREAM_REASON_MISC 1
|
|
|
|
#define END_STREAM_REASON_RESOLVEFAILED 2
|
2005-03-01 23:16:15 +01:00
|
|
|
#define END_STREAM_REASON_CONNECTREFUSED 3
|
2003-10-22 09:55:44 +02:00
|
|
|
#define END_STREAM_REASON_EXITPOLICY 4
|
|
|
|
#define END_STREAM_REASON_DESTROY 5
|
|
|
|
#define END_STREAM_REASON_DONE 6
|
2004-02-29 00:56:50 +01:00
|
|
|
#define END_STREAM_REASON_TIMEOUT 7
|
2007-02-16 21:00:50 +01:00
|
|
|
/* 8 is unallocated for historical reasons. */
|
2005-03-01 23:16:15 +01:00
|
|
|
#define END_STREAM_REASON_HIBERNATING 9
|
|
|
|
#define END_STREAM_REASON_INTERNAL 10
|
|
|
|
#define END_STREAM_REASON_RESOURCELIMIT 11
|
|
|
|
#define END_STREAM_REASON_CONNRESET 12
|
2005-03-01 23:42:31 +01:00
|
|
|
#define END_STREAM_REASON_TORPROTOCOL 13
|
2006-09-29 05:50:11 +02:00
|
|
|
#define END_STREAM_REASON_NOTDIRECTORY 14
|
2008-01-20 06:54:15 +01:00
|
|
|
#define END_STREAM_REASON_ENTRYPOLICY 15
|
2003-10-22 09:55:44 +02:00
|
|
|
|
2005-03-27 08:37:56 +02:00
|
|
|
/* These high-numbered end reasons are not part of the official spec,
|
|
|
|
* and are not intended to be put in relay end cells. They are here
|
|
|
|
* to be more informative when sending back socks replies to the
|
|
|
|
* application. */
|
2007-02-07 07:54:27 +01:00
|
|
|
/* XXXX 256 is no longer used; feel free to reuse it. */
|
2007-02-16 21:00:50 +01:00
|
|
|
/** We were unable to attach the connection to any circuit at all. */
|
|
|
|
/* XXXX the ways we use this one don't make a lot of sense. */
|
2005-03-27 08:37:56 +02:00
|
|
|
#define END_STREAM_REASON_CANT_ATTACH 257
|
2007-02-16 21:00:50 +01:00
|
|
|
/** We can't connect to any directories at all, so we killed our streams
|
|
|
|
* before they can time out. */
|
2005-03-27 08:37:56 +02:00
|
|
|
#define END_STREAM_REASON_NET_UNREACHABLE 258
|
2007-02-16 21:00:50 +01:00
|
|
|
/** This is a SOCKS connection, and the client used (or misused) the SOCKS
|
|
|
|
* protocol in a way we couldn't handle. */
|
2006-10-20 19:54:43 +02:00
|
|
|
#define END_STREAM_REASON_SOCKSPROTOCOL 259
|
2007-02-16 21:00:50 +01:00
|
|
|
/** This is a transparent proxy connection, but we can't extract the original
|
|
|
|
* target address:port. */
|
2006-11-14 01:06:31 +01:00
|
|
|
#define END_STREAM_REASON_CANT_FETCH_ORIG_DEST 260
|
2007-02-16 21:00:50 +01:00
|
|
|
/** This is a connection on the NATD port, and the destination IP:Port was
|
2007-02-24 08:50:38 +01:00
|
|
|
* either ill-formed or out-of-range. */
|
2006-11-14 01:06:31 +01:00
|
|
|
#define END_STREAM_REASON_INVALID_NATD_DEST 261
|
2006-10-20 19:54:43 +02:00
|
|
|
|
2007-02-07 07:54:22 +01:00
|
|
|
/** Bitwise-and this value with endreason to mask out all flags. */
|
|
|
|
#define END_STREAM_REASON_MASK 511
|
|
|
|
|
2007-01-15 10:09:03 +01:00
|
|
|
/** Bitwise-or this with the argument to control_event_stream_status
|
|
|
|
* to indicate that the reason came from an END cell. */
|
2007-02-07 07:54:22 +01:00
|
|
|
#define END_STREAM_REASON_FLAG_REMOTE 512
|
|
|
|
/** Bitwise-or this with the argument to control_event_stream_status
|
|
|
|
* to indicate that we already sent a CLOSED stream event. */
|
|
|
|
#define END_STREAM_REASON_FLAG_ALREADY_SENT_CLOSED 1024
|
2007-02-07 07:54:27 +01:00
|
|
|
/** Bitwise-or this with endreason to indicate that we already sent
|
|
|
|
* a socks reply, and no further reply needs to be sent from
|
|
|
|
* connection_mark_unattached_ap(). */
|
|
|
|
#define END_STREAM_REASON_FLAG_ALREADY_SOCKS_REPLIED 2048
|
2005-03-27 08:37:56 +02:00
|
|
|
|
2007-02-23 21:13:02 +01:00
|
|
|
/** Reason for remapping an AP connection's address: we have a cached
|
|
|
|
* answer. */
|
|
|
|
#define REMAP_STREAM_SOURCE_CACHE 1
|
|
|
|
/** Reason for remapping an AP connection's address: the exit node told us an
|
|
|
|
* answer. */
|
|
|
|
#define REMAP_STREAM_SOURCE_EXIT 2
|
|
|
|
|
2007-02-24 08:50:38 +01:00
|
|
|
/* 'type' values to use in RESOLVED cells. Specified in tor-spec.txt. */
|
2005-03-02 20:26:46 +01:00
|
|
|
#define RESOLVED_TYPE_HOSTNAME 0
|
2004-06-17 20:13:09 +02:00
|
|
|
#define RESOLVED_TYPE_IPV4 4
|
|
|
|
#define RESOLVED_TYPE_IPV6 6
|
|
|
|
#define RESOLVED_TYPE_ERROR_TRANSIENT 0xF0
|
|
|
|
#define RESOLVED_TYPE_ERROR 0xF1
|
|
|
|
|
2007-01-23 20:22:52 +01:00
|
|
|
/* Negative reasons are internal: we never send them in a DESTROY or TRUNCATE
|
|
|
|
* call; they only go to the controller for tracking */
|
|
|
|
/** We couldn't build a path for this circuit. */
|
2006-10-17 17:20:00 +02:00
|
|
|
#define END_CIRC_REASON_NOPATH -2
|
2007-01-23 20:22:52 +01:00
|
|
|
/** Catch-all "other" reason for closing origin circuits. */
|
2006-10-17 17:20:00 +02:00
|
|
|
#define END_CIRC_AT_ORIGIN -1
|
2006-10-20 01:04:49 +02:00
|
|
|
|
2006-11-17 04:34:58 +01:00
|
|
|
/* Reasons why we (or a remote OR) might close a circuit. See tor-spec.txt for
|
|
|
|
* documentation of these. */
|
2006-01-05 22:23:03 +01:00
|
|
|
#define _END_CIRC_REASON_MIN 0
|
|
|
|
#define END_CIRC_REASON_NONE 0
|
|
|
|
#define END_CIRC_REASON_TORPROTOCOL 1
|
|
|
|
#define END_CIRC_REASON_INTERNAL 2
|
|
|
|
#define END_CIRC_REASON_REQUESTED 3
|
|
|
|
#define END_CIRC_REASON_HIBERNATING 4
|
|
|
|
#define END_CIRC_REASON_RESOURCELIMIT 5
|
|
|
|
#define END_CIRC_REASON_CONNECTFAILED 6
|
|
|
|
#define END_CIRC_REASON_OR_IDENTITY 7
|
|
|
|
#define END_CIRC_REASON_OR_CONN_CLOSED 8
|
2006-10-17 17:20:00 +02:00
|
|
|
#define END_CIRC_REASON_FINISHED 9
|
|
|
|
#define END_CIRC_REASON_TIMEOUT 10
|
|
|
|
#define END_CIRC_REASON_DESTROYED 11
|
|
|
|
#define END_CIRC_REASON_NOSUCHSERVICE 12
|
|
|
|
#define _END_CIRC_REASON_MAX 12
|
2006-01-05 22:23:03 +01:00
|
|
|
|
2007-07-11 05:28:12 +02:00
|
|
|
/** Bitwise-OR this with the argument to circuit_mark_for_close() or
|
|
|
|
* control_event_circuit_status() to indicate that the reason was
|
|
|
|
* passed through from a destroy or truncate cell. */
|
2006-10-20 01:04:49 +02:00
|
|
|
#define END_CIRC_REASON_FLAG_REMOTE 512
|
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Length of 'y' portion of 'y.onion' URL. */
|
2007-11-29 16:25:04 +01:00
|
|
|
#define REND_SERVICE_ID_LEN_BASE32 16
|
|
|
|
|
2008-08-12 18:12:26 +02:00
|
|
|
/** Length of 'y.onion' including '.onion' URL. */
|
|
|
|
#define REND_SERVICE_ADDRESS_LEN (16+1+5)
|
|
|
|
|
2007-11-29 16:25:04 +01:00
|
|
|
/** Length of a binary-encoded rendezvous service ID. */
|
|
|
|
#define REND_SERVICE_ID_LEN 10
|
2004-04-01 23:32:01 +02:00
|
|
|
|
2007-10-28 20:48:14 +01:00
|
|
|
/** Time period for which a v2 descriptor will be valid. */
|
|
|
|
#define REND_TIME_PERIOD_V2_DESC_VALIDITY (24*60*60)
|
|
|
|
|
|
|
|
/** Time period within which two sets of v2 descriptors will be uploaded in
|
|
|
|
* parallel. */
|
|
|
|
#define REND_TIME_PERIOD_OVERLAPPING_V2_DESCS (60*60)
|
|
|
|
|
|
|
|
/** Number of non-consecutive replicas (i.e. distributed somewhere
|
|
|
|
* in the ring) for a descriptor. */
|
|
|
|
#define REND_NUMBER_OF_NON_CONSECUTIVE_REPLICAS 2
|
|
|
|
|
|
|
|
/** Number of consecutive replicas for a descriptor. */
|
|
|
|
#define REND_NUMBER_OF_CONSECUTIVE_REPLICAS 3
|
|
|
|
|
|
|
|
/** Length of v2 descriptor ID (32 base32 chars = 160 bits). */
|
2007-10-31 21:48:06 +01:00
|
|
|
#define REND_DESC_ID_V2_LEN_BASE32 32
|
2007-10-28 20:48:14 +01:00
|
|
|
|
2007-10-29 20:10:42 +01:00
|
|
|
/** Length of the base32-encoded secret ID part of versioned hidden service
|
|
|
|
* descriptors. */
|
|
|
|
#define REND_SECRET_ID_PART_LEN_BASE32 32
|
|
|
|
|
|
|
|
/** Length of the base32-encoded hash of an introduction point's
|
|
|
|
* identity key. */
|
|
|
|
#define REND_INTRO_POINT_ID_LEN_BASE32 32
|
|
|
|
|
2008-08-08 16:36:11 +02:00
|
|
|
/** Length of the descriptor cookie that is used for client authorization
|
|
|
|
* to hidden services. */
|
|
|
|
#define REND_DESC_COOKIE_LEN 16
|
|
|
|
|
|
|
|
/** Length of the base64-encoded descriptor cookie that is used for
|
|
|
|
* exchanging client authorization between hidden service and client. */
|
|
|
|
#define REND_DESC_COOKIE_LEN_BASE64 22
|
|
|
|
|
2008-08-19 17:41:28 +02:00
|
|
|
/** Length of client identifier in encrypted introduction points for hidden
|
|
|
|
* service authorization type 'basic'. */
|
|
|
|
#define REND_BASIC_AUTH_CLIENT_ID_LEN 4
|
|
|
|
|
|
|
|
/** Multiple of the number of clients to which the real number of clients
|
|
|
|
* is padded with fake clients for hidden service authorization type
|
|
|
|
* 'basic'. */
|
|
|
|
#define REND_BASIC_AUTH_CLIENT_MULTIPLE 16
|
|
|
|
|
|
|
|
/** Length of client entry consisting of client identifier and encrypted
|
|
|
|
* session key for hidden service authorization type 'basic'. */
|
|
|
|
#define REND_BASIC_AUTH_CLIENT_ENTRY_LEN (REND_BASIC_AUTH_CLIENT_ID_LEN \
|
|
|
|
+ CIPHER_KEY_LEN)
|
|
|
|
|
|
|
|
/** Maximum size of v2 hidden service descriptors. */
|
|
|
|
#define REND_DESC_MAX_SIZE (20 * 1024)
|
|
|
|
|
2008-08-08 16:36:11 +02:00
|
|
|
/** Legal characters for use in authorized client names for a hidden
|
|
|
|
* service. */
|
|
|
|
#define REND_LEGAL_CLIENTNAME_CHARACTERS \
|
|
|
|
"abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+-_"
|
|
|
|
|
2008-08-09 17:13:28 +02:00
|
|
|
/** Maximum length of authorized client names for a hidden service. */
|
|
|
|
#define REND_CLIENTNAME_MAX_LEN 16
|
|
|
|
|
2008-09-24 16:44:29 +02:00
|
|
|
/** Length of the rendezvous cookie that is used to connect circuits at the
|
|
|
|
* rendezvous point. */
|
|
|
|
#define REND_COOKIE_LEN DIGEST_LEN
|
|
|
|
|
|
|
|
/** Client authorization type that a hidden service performs. */
|
|
|
|
typedef enum rend_auth_type_t {
|
|
|
|
REND_NO_AUTH = 0,
|
|
|
|
REND_BASIC_AUTH = 1,
|
|
|
|
REND_STEALTH_AUTH = 2,
|
|
|
|
} rend_auth_type_t;
|
|
|
|
|
|
|
|
/** Client-side configuration of authorization for a hidden service. */
|
|
|
|
typedef struct rend_service_authorization_t {
|
|
|
|
char descriptor_cookie[REND_DESC_COOKIE_LEN];
|
|
|
|
char onion_address[REND_SERVICE_ADDRESS_LEN+1];
|
|
|
|
rend_auth_type_t auth_type;
|
|
|
|
} rend_service_authorization_t;
|
|
|
|
|
|
|
|
/** Client- and server-side data that is used for hidden service connection
|
|
|
|
* establishment. Not all fields contain data depending on where this struct
|
|
|
|
* is used. */
|
|
|
|
typedef struct rend_data_t {
|
|
|
|
/** Onion address (without the .onion part) that a client requests. */
|
|
|
|
char onion_address[REND_SERVICE_ID_LEN_BASE32+1];
|
|
|
|
|
|
|
|
/** (Optional) descriptor cookie that is used by a client. */
|
|
|
|
char descriptor_cookie[REND_DESC_COOKIE_LEN];
|
|
|
|
|
|
|
|
/** Authorization type for accessing a service used by a client. */
|
|
|
|
rend_auth_type_t auth_type;
|
|
|
|
|
|
|
|
/** Hash of the hidden service's PK used by a service. */
|
|
|
|
char rend_pk_digest[DIGEST_LEN];
|
|
|
|
|
|
|
|
/** Rendezvous cookie used by both, client and service. */
|
|
|
|
char rend_cookie[REND_COOKIE_LEN];
|
|
|
|
} rend_data_t;
|
|
|
|
|
|
|
|
/** Time interval for tracking possible replays of INTRODUCE2 cells.
|
|
|
|
* Incoming cells with timestamps half of this interval in the past or
|
|
|
|
* future are dropped immediately. */
|
|
|
|
#define REND_REPLAY_TIME_INTERVAL (60 * 60)
|
|
|
|
|
2008-12-17 18:20:19 +01:00
|
|
|
/** Used to indicate which way a cell is going on a circuit. */
|
|
|
|
typedef enum {
|
|
|
|
CELL_DIRECTION_IN=1, /**< The cell is moving towards the origin. */
|
|
|
|
CELL_DIRECTION_OUT=2, /**< The cell is moving away from the origin. */
|
|
|
|
} cell_direction_t;
|
major overhaul: dns slave subsystem, topics
on startup, it forks off a master dns handler, which forks off dns
slaves (like the apache model). slaves as spawned as load increases,
and then reused. excess slaves are not ever killed, currently.
implemented topics. each topic has a receive window in each direction
at each edge of the circuit, and sends sendme's at the data level, as
per before. each circuit also has receive windows in each direction at
each hop; an edge sends a circuit-level sendme as soon as enough data
cells have arrived (regardless of whether the data cells were flushed
to the exit conns). removed the 'connected' cell type, since it's now
a topic command within data cells.
at the edge of the circuit, there can be multiple connections associated
with a single circuit. you find them via the linked list conn->next_topic.
currently each new ap connection starts its own circuit, so we ought
to see comparable performance to what we had before. but that's only
because i haven't written the code to reattach to old circuits. please
try to break it as-is, and then i'll make it reuse the same circuit and
we'll try to break that.
svn:r152
2003-01-26 10:02:24 +01:00
|
|
|
|
2007-02-16 21:00:50 +01:00
|
|
|
/** Initial value for both sides of a circuit transmission window when the
|
|
|
|
* circuit is initialized. Measured in cells. */
|
major overhaul: dns slave subsystem, topics
on startup, it forks off a master dns handler, which forks off dns
slaves (like the apache model). slaves as spawned as load increases,
and then reused. excess slaves are not ever killed, currently.
implemented topics. each topic has a receive window in each direction
at each edge of the circuit, and sends sendme's at the data level, as
per before. each circuit also has receive windows in each direction at
each hop; an edge sends a circuit-level sendme as soon as enough data
cells have arrived (regardless of whether the data cells were flushed
to the exit conns). removed the 'connected' cell type, since it's now
a topic command within data cells.
at the edge of the circuit, there can be multiple connections associated
with a single circuit. you find them via the linked list conn->next_topic.
currently each new ap connection starts its own circuit, so we ought
to see comparable performance to what we had before. but that's only
because i haven't written the code to reattach to old circuits. please
try to break it as-is, and then i'll make it reuse the same circuit and
we'll try to break that.
svn:r152
2003-01-26 10:02:24 +01:00
|
|
|
#define CIRCWINDOW_START 1000
|
2007-02-16 21:00:50 +01:00
|
|
|
/** Amount to increment a circuit window when we get a circuit SENDME. */
|
major overhaul: dns slave subsystem, topics
on startup, it forks off a master dns handler, which forks off dns
slaves (like the apache model). slaves as spawned as load increases,
and then reused. excess slaves are not ever killed, currently.
implemented topics. each topic has a receive window in each direction
at each edge of the circuit, and sends sendme's at the data level, as
per before. each circuit also has receive windows in each direction at
each hop; an edge sends a circuit-level sendme as soon as enough data
cells have arrived (regardless of whether the data cells were flushed
to the exit conns). removed the 'connected' cell type, since it's now
a topic command within data cells.
at the edge of the circuit, there can be multiple connections associated
with a single circuit. you find them via the linked list conn->next_topic.
currently each new ap connection starts its own circuit, so we ought
to see comparable performance to what we had before. but that's only
because i haven't written the code to reattach to old circuits. please
try to break it as-is, and then i'll make it reuse the same circuit and
we'll try to break that.
svn:r152
2003-01-26 10:02:24 +01:00
|
|
|
#define CIRCWINDOW_INCREMENT 100
|
2007-02-16 21:00:50 +01:00
|
|
|
/** Initial value on both sides of a stream transmission window when the
|
|
|
|
* stream is initialized. Measured in cells. */
|
2003-05-01 08:42:29 +02:00
|
|
|
#define STREAMWINDOW_START 500
|
2007-02-16 21:00:50 +01:00
|
|
|
/** Amount to increment a stream window when we get a stream SENDME. */
|
2003-05-01 08:42:29 +02:00
|
|
|
#define STREAMWINDOW_INCREMENT 50
|
2002-07-18 08:37:58 +02:00
|
|
|
|
2008-12-17 18:20:31 +01:00
|
|
|
/* Cell commands. These values are defined in tor-spec.txt. */
|
2002-07-19 20:48:28 +02:00
|
|
|
#define CELL_PADDING 0
|
|
|
|
#define CELL_CREATE 1
|
2003-05-06 01:24:46 +02:00
|
|
|
#define CELL_CREATED 2
|
|
|
|
#define CELL_RELAY 3
|
|
|
|
#define CELL_DESTROY 4
|
2005-05-03 00:35:18 +02:00
|
|
|
#define CELL_CREATE_FAST 5
|
|
|
|
#define CELL_CREATED_FAST 6
|
2007-10-30 19:31:30 +01:00
|
|
|
#define CELL_VERSIONS 7
|
|
|
|
#define CELL_NETINFO 8
|
2008-01-13 01:20:47 +01:00
|
|
|
#define CELL_RELAY_EARLY 9
|
2002-07-19 20:48:28 +02:00
|
|
|
|
2008-12-17 18:20:31 +01:00
|
|
|
/** True iff the cell command <b>x</b> is one that implies a variable-length
|
|
|
|
* cell. */
|
2007-12-01 09:09:46 +01:00
|
|
|
#define CELL_COMMAND_IS_VAR_LENGTH(x) ((x) == CELL_VERSIONS)
|
2007-11-05 22:46:35 +01:00
|
|
|
|
2005-12-08 22:12:47 +01:00
|
|
|
/** How long to test reachability before complaining to the user. */
|
2006-03-12 23:48:18 +01:00
|
|
|
#define TIMEOUT_UNTIL_UNREACHABILITY_COMPLAINT (20*60)
|
2005-12-08 22:12:47 +01:00
|
|
|
|
2007-02-06 03:49:07 +01:00
|
|
|
/** Legal characters in a nickname. */
|
2005-12-14 21:40:40 +01:00
|
|
|
#define LEGAL_NICKNAME_CHARACTERS \
|
|
|
|
"abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"
|
2002-11-23 07:49:01 +01:00
|
|
|
|
2008-06-11 01:00:11 +02:00
|
|
|
/** Name to use in client TLS certificates if no nickname is given. Once
|
|
|
|
* Tor 0.1.2.x is obsolete, we can remove this. */
|
2004-11-09 19:22:17 +01:00
|
|
|
#define DEFAULT_CLIENT_NICKNAME "client"
|
|
|
|
|
2007-02-16 21:00:50 +01:00
|
|
|
/** Number of bytes in a SOCKS4 header. */
|
2003-09-21 08:15:43 +02:00
|
|
|
#define SOCKS4_NETWORK_LEN 8
|
|
|
|
|
2003-12-16 10:48:17 +01:00
|
|
|
/*
|
|
|
|
* Relay payload:
|
|
|
|
* Relay command [1 byte]
|
2003-12-19 06:09:51 +01:00
|
|
|
* Recognized [2 bytes]
|
|
|
|
* Stream ID [2 bytes]
|
2003-12-16 10:48:17 +01:00
|
|
|
* Partial SHA-1 [4 bytes]
|
|
|
|
* Length [2 bytes]
|
2003-12-19 06:09:51 +01:00
|
|
|
* Relay payload [498 bytes]
|
2003-12-16 10:48:17 +01:00
|
|
|
*/
|
2003-04-16 19:44:33 +02:00
|
|
|
|
2007-02-16 21:00:50 +01:00
|
|
|
/** Number of bytes in a cell, minus cell header. */
|
2003-12-16 10:48:17 +01:00
|
|
|
#define CELL_PAYLOAD_SIZE 509
|
2007-02-16 21:00:50 +01:00
|
|
|
/** Number of bytes in a cell transmitted over the network. */
|
2003-12-16 10:48:17 +01:00
|
|
|
#define CELL_NETWORK_SIZE 512
|
|
|
|
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Length of a header on a variable-length cell. */
|
2007-11-05 22:46:35 +01:00
|
|
|
#define VAR_CELL_HEADER_SIZE 5
|
|
|
|
|
2007-02-16 21:00:50 +01:00
|
|
|
/** Number of bytes in a relay cell's header (not including general cell
|
|
|
|
* header). */
|
2003-12-19 06:09:51 +01:00
|
|
|
#define RELAY_HEADER_SIZE (1+2+2+4+2)
|
2007-02-16 21:00:50 +01:00
|
|
|
/** Largest number of bytes that can fit in a relay cell payload. */
|
2003-12-19 06:09:51 +01:00
|
|
|
#define RELAY_PAYLOAD_SIZE (CELL_PAYLOAD_SIZE-RELAY_HEADER_SIZE)
|
|
|
|
|
2008-07-23 17:58:30 +02:00
|
|
|
/** Identifies a circuit on an or_connection */
|
|
|
|
typedef uint16_t circid_t;
|
|
|
|
/** Identifies a stream on a circuit */
|
|
|
|
typedef uint16_t streamid_t;
|
|
|
|
|
2005-11-17 02:17:53 +01:00
|
|
|
/** Parsed onion routing cell. All communication between nodes
|
|
|
|
* is via cells. */
|
2007-11-05 22:46:35 +01:00
|
|
|
typedef struct cell_t {
|
2008-07-23 17:58:30 +02:00
|
|
|
circid_t circ_id; /**< Circuit which received the cell. */
|
2007-11-05 22:46:35 +01:00
|
|
|
uint8_t command; /**< Type of the cell: one of CELL_PADDING, CELL_CREATE,
|
|
|
|
* CELL_DESTROY, etc */
|
2005-05-07 07:55:06 +02:00
|
|
|
char payload[CELL_PAYLOAD_SIZE]; /**< Cell body. */
|
2007-11-05 22:46:35 +01:00
|
|
|
} cell_t;
|
|
|
|
|
|
|
|
/** Parsed variable-length onion routing cell. */
|
|
|
|
typedef struct var_cell_t {
|
|
|
|
uint8_t command;
|
2008-07-23 17:58:30 +02:00
|
|
|
circid_t circ_id;
|
2007-11-05 22:46:35 +01:00
|
|
|
uint16_t payload_len;
|
|
|
|
char payload[1];
|
|
|
|
} var_cell_t;
|
2007-03-26 16:07:59 +02:00
|
|
|
|
2007-04-10 01:15:46 +02:00
|
|
|
/** A cell as packed for writing to the network. */
|
2007-11-05 22:46:35 +01:00
|
|
|
typedef struct packed_cell_t {
|
2007-04-25 08:05:46 +02:00
|
|
|
struct packed_cell_t *next; /**< Next cell queued on this circuit. */
|
2007-04-10 01:15:46 +02:00
|
|
|
char body[CELL_NETWORK_SIZE]; /**< Cell as packed for network. */
|
2007-11-05 22:46:35 +01:00
|
|
|
} packed_cell_t;
|
2007-04-10 01:15:46 +02:00
|
|
|
|
2009-08-17 13:07:56 +02:00
|
|
|
/** Number of cells added to a circuit queue including their insertion
|
|
|
|
* time on 10 millisecond detail; used for buffer statistics. */
|
|
|
|
typedef struct insertion_time_elem_t {
|
2009-08-18 15:53:08 +02:00
|
|
|
struct insertion_time_elem_t *next; /**< Next element in queue. */
|
2009-08-17 13:07:56 +02:00
|
|
|
uint32_t insertion_time; /**< When were cells inserted (in 10 ms steps
|
|
|
|
* starting at 0:00 of the current day)? */
|
|
|
|
unsigned counter; /**< How many cells were inserted? */
|
|
|
|
} insertion_time_elem_t;
|
|
|
|
|
|
|
|
/** Queue of insertion times. */
|
|
|
|
typedef struct insertion_time_queue_t {
|
2009-08-18 15:53:08 +02:00
|
|
|
struct insertion_time_elem_t *first; /**< First element in queue. */
|
|
|
|
struct insertion_time_elem_t *last; /**< Last element in queue. */
|
2009-08-17 13:07:56 +02:00
|
|
|
} insertion_time_queue_t;
|
|
|
|
|
2007-03-26 16:08:35 +02:00
|
|
|
/** A queue of cells on a circuit, waiting to be added to the
|
|
|
|
* or_connection_t's outbuf. */
|
2007-03-26 16:07:59 +02:00
|
|
|
typedef struct cell_queue_t {
|
2007-04-25 08:05:46 +02:00
|
|
|
packed_cell_t *head; /**< The first cell, or NULL if the queue is empty. */
|
|
|
|
packed_cell_t *tail; /**< The last cell, or NULL if the queue is empty. */
|
|
|
|
int n; /**< The number of cells in the queue. */
|
2009-08-18 15:53:08 +02:00
|
|
|
insertion_time_queue_t *insertion_times; /**< Insertion times of cells. */
|
2007-03-26 16:07:59 +02:00
|
|
|
} cell_queue_t;
|
2003-12-16 10:48:17 +01:00
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Beginning of a RELAY cell payload. */
|
2003-12-19 06:09:51 +01:00
|
|
|
typedef struct {
|
2004-05-10 08:52:01 +02:00
|
|
|
uint8_t command; /**< The end-to-end relay command. */
|
|
|
|
uint16_t recognized; /**< Used to tell whether cell is for us. */
|
2008-07-23 17:58:30 +02:00
|
|
|
streamid_t stream_id; /**< Which stream is this cell associated with? */
|
2004-05-10 08:52:01 +02:00
|
|
|
char integrity[4]; /**< Used to tell whether cell is corrupted. */
|
|
|
|
uint16_t length; /**< How long is the payload body? */
|
2003-12-19 06:09:51 +01:00
|
|
|
} relay_header_t;
|
2002-07-19 20:48:28 +02:00
|
|
|
|
2003-09-25 07:17:11 +02:00
|
|
|
typedef struct buf_t buf_t;
|
2003-11-11 03:41:31 +01:00
|
|
|
typedef struct socks_request_t socks_request_t;
|
2003-09-25 07:17:11 +02:00
|
|
|
|
2007-02-16 21:00:50 +01:00
|
|
|
/* Values for connection_t.magic: used to make sure that downcasts (casts from
|
|
|
|
* connection_t to foo_connection_t) are safe. */
|
2006-07-26 21:07:26 +02:00
|
|
|
#define BASE_CONNECTION_MAGIC 0x7C3C304Eu
|
|
|
|
#define OR_CONNECTION_MAGIC 0x7D31FF03u
|
|
|
|
#define EDGE_CONNECTION_MAGIC 0xF0374013u
|
|
|
|
#define DIR_CONNECTION_MAGIC 0x9988ffeeu
|
|
|
|
#define CONTROL_CONNECTION_MAGIC 0x8abc765du
|
2005-06-11 08:07:22 +02:00
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Description of a connection to another host or process, and associated
|
2005-06-11 08:07:22 +02:00
|
|
|
* data.
|
|
|
|
*
|
|
|
|
* A connection is named based on what it's connected to -- an "OR
|
2005-11-17 02:17:53 +01:00
|
|
|
* connection" has a Tor node on the other end, an "exit
|
2005-06-11 08:07:22 +02:00
|
|
|
* connection" has a website or other server on the other end, and an
|
|
|
|
* "AP connection" has an application proxy (and thus a user) on the
|
|
|
|
* other end.
|
|
|
|
*
|
|
|
|
* Every connection has a type and a state. Connections never change
|
|
|
|
* their type, but can go through many state changes in their lifetime.
|
|
|
|
*
|
|
|
|
* Every connection has two associated input and output buffers.
|
|
|
|
* Listeners don't use them. For non-listener connections, incoming
|
|
|
|
* data is appended to conn->inbuf, and outgoing data is taken from
|
|
|
|
* conn->outbuf. Connections differ primarily in the functions called
|
|
|
|
* to fill and drain these buffers.
|
|
|
|
*/
|
2006-07-27 07:03:57 +02:00
|
|
|
typedef struct connection_t {
|
|
|
|
uint32_t magic; /**< For memory debugging: must equal one of
|
|
|
|
* *_CONNECTION_MAGIC. */
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
uint8_t state; /**< Current state of this connection. */
|
2008-02-18 20:24:33 +01:00
|
|
|
unsigned int type:4; /**< What kind of connection is this? */
|
|
|
|
unsigned int purpose:5; /**< Only used for DIR and EXIT types currently. */
|
2007-08-14 22:19:51 +02:00
|
|
|
|
|
|
|
/* The next fields are all one-bit booleans. Some are only applicable to
|
|
|
|
* connection subtypes, but we hold them here anyway, to save space.
|
|
|
|
*/
|
2008-02-18 20:24:33 +01:00
|
|
|
unsigned int read_blocked_on_bw:1; /**< Boolean: should we start reading
|
|
|
|
* again once the bandwidth throttler allows it? */
|
|
|
|
unsigned int write_blocked_on_bw:1; /**< Boolean: should we start writing
|
|
|
|
* again once the bandwidth throttler allows
|
|
|
|
* reads? */
|
|
|
|
unsigned int hold_open_until_flushed:1; /**< Despite this connection's being
|
2005-09-30 00:59:17 +02:00
|
|
|
* marked for close, do we flush it
|
2006-07-16 07:57:11 +02:00
|
|
|
* before closing it? */
|
2006-07-28 17:11:28 +02:00
|
|
|
unsigned int inbuf_reached_eof:1; /**< Boolean: did read() return 0 on this
|
|
|
|
* conn? */
|
2007-10-11 22:45:26 +02:00
|
|
|
/** Set to 1 when we're inside connection_flushed_some to keep us from
|
|
|
|
* calling connection_handle_write() recursively. */
|
|
|
|
unsigned int in_flushed_some:1;
|
2005-09-30 00:59:17 +02:00
|
|
|
|
2007-08-14 22:19:51 +02:00
|
|
|
/* For linked connections:
|
|
|
|
*/
|
|
|
|
unsigned int linked:1; /**< True if there is, or has been, a linked_conn. */
|
|
|
|
/** True iff we'd like to be notified about read events from the
|
|
|
|
* linked conn. */
|
|
|
|
unsigned int reading_from_linked_conn:1;
|
|
|
|
/** True iff we're willing to write to the linked conn. */
|
|
|
|
unsigned int writing_to_linked_conn:1;
|
|
|
|
/** True iff we're currently able to read on the linked conn, and our
|
|
|
|
* read_event should be made active with libevent. */
|
|
|
|
unsigned int active_on_link:1;
|
2007-10-12 00:19:18 +02:00
|
|
|
/** True iff we've called connection_close_immediate() on this linked
|
|
|
|
* connection. */
|
2007-10-11 22:45:26 +02:00
|
|
|
unsigned int linked_conn_is_closed:1;
|
2007-08-14 22:19:51 +02:00
|
|
|
|
2009-08-26 17:27:19 +02:00
|
|
|
/** CONNECT/SOCKS proxy client handshake state (for outgoing connections). */
|
|
|
|
unsigned int proxy_state:4;
|
|
|
|
|
2009-06-04 07:05:23 +02:00
|
|
|
/** Our socket; -1 if this connection is closed, or has no socket. */
|
|
|
|
evutil_socket_t s;
|
2006-07-27 07:03:57 +02:00
|
|
|
int conn_array_index; /**< Index into the global connection array. */
|
2006-07-16 07:57:11 +02:00
|
|
|
struct event *read_event; /**< Libevent event structure. */
|
|
|
|
struct event *write_event; /**< Libevent event structure. */
|
2004-05-10 12:27:54 +02:00
|
|
|
buf_t *inbuf; /**< Buffer holding data read over this connection. */
|
|
|
|
buf_t *outbuf; /**< Buffer holding data to write over this connection. */
|
2004-10-14 05:13:08 +02:00
|
|
|
size_t outbuf_flushlen; /**< How much data should we try to flush from the
|
|
|
|
* outbuf? */
|
2006-07-28 17:11:20 +02:00
|
|
|
time_t timestamp_lastread; /**< When was the last time libevent said we could
|
|
|
|
* read? */
|
2006-07-28 17:11:11 +02:00
|
|
|
time_t timestamp_lastwritten; /**< When was the last time libevent said we
|
2005-12-14 21:40:40 +01:00
|
|
|
* could write? */
|
2004-05-10 10:56:42 +02:00
|
|
|
time_t timestamp_created; /**< When was this connection_t created? */
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2009-05-27 23:55:51 +02:00
|
|
|
/* XXXX_IP6 make this IPv6-capable */
|
2007-06-08 23:14:58 +02:00
|
|
|
int socket_family; /**< Address family of this connection's socket. Usually
|
|
|
|
* AF_INET, but it can also be AF_UNIX, or in the future
|
|
|
|
* AF_INET6 */
|
2008-08-05 22:08:19 +02:00
|
|
|
tor_addr_t addr; /**< IP of the other side of the connection; used to
|
|
|
|
* identify routers, along with port. */
|
2008-11-24 03:02:48 +01:00
|
|
|
uint16_t port; /**< If non-zero, port on the other end
|
2003-09-05 08:04:03 +02:00
|
|
|
* of the connection. */
|
2005-12-14 22:03:51 +01:00
|
|
|
uint16_t marked_for_close; /**< Should we close this conn on the next
|
|
|
|
* iteration of the main loop? (If true, holds
|
|
|
|
* the line number where this connection was
|
2006-07-16 07:57:11 +02:00
|
|
|
* marked.) */
|
2005-12-14 22:03:51 +01:00
|
|
|
const char *marked_for_close_file; /**< For debugging: in which file were
|
|
|
|
* we marked for close? */
|
2004-05-10 08:52:01 +02:00
|
|
|
char *address; /**< FQDN (or IP) of the guy on the other end.
|
2008-08-03 07:35:42 +02:00
|
|
|
* strdup into this, because free_connection() frees it. */
|
2008-02-21 10:00:54 +01:00
|
|
|
/** Another connection that's connected to this one in lieu of a socket. */
|
2007-04-21 19:26:12 +02:00
|
|
|
struct connection_t *linked_conn;
|
2007-06-05 22:54:23 +02:00
|
|
|
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Unique identifier for this connection on this Tor instance. */
|
2008-08-15 15:55:01 +02:00
|
|
|
uint64_t global_identifier;
|
|
|
|
|
2008-12-29 21:17:24 +01:00
|
|
|
/* XXXX022 move this field, and all the listener-only fields (just
|
|
|
|
socket_family, I think), into a new listener_connection_t subtype. */
|
2008-12-17 18:20:31 +01:00
|
|
|
/** If the connection is a CONN_TYPE_AP_DNS_LISTENER, this field points
|
|
|
|
* to the evdns_server_port is uses to listen to and answer connections. */
|
2007-05-24 22:31:30 +02:00
|
|
|
struct evdns_server_port *dns_server_port;
|
|
|
|
|
2009-07-12 16:33:31 +02:00
|
|
|
/** Unique ID for measuring tunneled network status requests. */
|
2009-07-14 22:24:50 +02:00
|
|
|
uint64_t dirreq_id;
|
2006-07-27 07:03:57 +02:00
|
|
|
} connection_t;
|
2006-07-26 21:07:26 +02:00
|
|
|
|
2008-02-11 02:09:24 +01:00
|
|
|
/** Stores flags and information related to the portion of a v2 Tor OR
|
|
|
|
* connection handshake that happens after the TLS handshake is finished.
|
|
|
|
*/
|
2007-11-05 19:15:44 +01:00
|
|
|
typedef struct or_handshake_state_t {
|
2008-02-11 02:09:24 +01:00
|
|
|
/** When was the VERSIONS cell sent on this connection? Used to get
|
|
|
|
* an estimate of the skew in the returning NETINFO reply. */
|
2007-11-05 19:15:44 +01:00
|
|
|
time_t sent_versions_at;
|
2008-02-11 02:09:24 +01:00
|
|
|
/** True iff we originated this connection */
|
2007-11-05 19:15:47 +01:00
|
|
|
unsigned int started_here : 1;
|
2008-02-11 02:09:24 +01:00
|
|
|
/** True iff we have received and processed a VERSIONS cell. */
|
2007-11-05 19:15:44 +01:00
|
|
|
unsigned int received_versions : 1;
|
|
|
|
} or_handshake_state_t;
|
|
|
|
|
2006-07-27 07:03:57 +02:00
|
|
|
/** Subtype of connection_t for an "OR connection" -- that is, one that speaks
|
|
|
|
* cells over TLS. */
|
2006-07-26 21:07:26 +02:00
|
|
|
typedef struct or_connection_t {
|
|
|
|
connection_t _base;
|
|
|
|
|
2007-02-24 02:12:53 +01:00
|
|
|
/** Hash of the public RSA key for the other side's identity key, or zeroes
|
|
|
|
* if the other side hasn't shown us a valid identity key. */
|
2007-02-12 22:39:33 +01:00
|
|
|
char identity_digest[DIGEST_LEN];
|
2004-05-10 08:52:01 +02:00
|
|
|
char *nickname; /**< Nickname of OR on other side (if any). */
|
2003-09-05 08:04:03 +02:00
|
|
|
|
2007-03-20 04:21:51 +01:00
|
|
|
tor_tls_t *tls; /**< TLS connection state. */
|
|
|
|
int tls_error; /**< Last tor_tls error code. */
|
2007-07-30 00:13:44 +02:00
|
|
|
/** When we last used this conn for any client traffic. If not
|
|
|
|
* recent, we can rate limit it further. */
|
|
|
|
time_t client_used;
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2008-08-05 22:08:19 +02:00
|
|
|
tor_addr_t real_addr; /**< The actual address that this connection came from
|
2008-02-12 21:20:52 +01:00
|
|
|
* or went to. The <b>addr</b> field is prone to
|
|
|
|
* getting overridden by the address from the router
|
|
|
|
* descriptor matching <b>identity_digest</b>. */
|
2007-10-30 19:31:30 +01:00
|
|
|
|
2007-05-17 00:15:57 +02:00
|
|
|
circ_id_type_t circ_id_type:2; /**< When we send CREATE cells along this
|
|
|
|
* connection, which half of the space should
|
|
|
|
* we use? */
|
2008-02-12 21:20:52 +01:00
|
|
|
/** Should this connection be used for extending circuits to the server
|
|
|
|
* matching the <b>identity_digest</b> field? Set to true if we're pretty
|
|
|
|
* sure we aren't getting MITMed, either because we're connected to an
|
|
|
|
* address listed in a server descriptor, or because an authenticated
|
|
|
|
* NETINFO cell listed the address we're connected to as recognized. */
|
|
|
|
unsigned int is_canonical:1;
|
2008-12-17 15:59:19 +01:00
|
|
|
/** True iff this connection shouldn't get any new circs attached to it,
|
|
|
|
* because the connection is too old, or because there's a better one, etc.
|
|
|
|
*/
|
|
|
|
unsigned int is_bad_for_new_circs:1;
|
2007-10-30 19:31:30 +01:00
|
|
|
uint8_t link_proto; /**< What protocol version are we using? 0 for
|
|
|
|
* "none negotiated yet." */
|
2008-07-23 17:58:30 +02:00
|
|
|
circid_t next_circ_id; /**< Which circ_id do we try to use next on
|
2007-05-17 00:15:57 +02:00
|
|
|
* this connection? This is always in the
|
|
|
|
* range 0..1<<15-1. */
|
|
|
|
|
2008-02-11 02:09:24 +01:00
|
|
|
or_handshake_state_t *handshake_state; /**< If we are setting this connection
|
|
|
|
* up, state information to do so. */
|
2006-07-28 17:11:20 +02:00
|
|
|
time_t timestamp_lastempty; /**< When was the outbuf last completely empty?*/
|
2007-11-08 17:19:07 +01:00
|
|
|
time_t timestamp_last_added_nonpadding; /** When did we last add a
|
|
|
|
* non-padding cell to the outbuf? */
|
2006-07-28 17:11:20 +02:00
|
|
|
|
2006-12-13 08:08:36 +01:00
|
|
|
/* bandwidth* and read_bucket only used by ORs in OPEN state: */
|
2006-06-07 11:18:53 +02:00
|
|
|
int bandwidthrate; /**< Bytes/s added to the bucket. (OPEN ORs only.) */
|
|
|
|
int bandwidthburst; /**< Max bucket size for this conn. (OPEN ORs only.) */
|
2006-12-13 08:08:36 +01:00
|
|
|
int read_bucket; /**< When this hits 0, stop receiving. Every second we
|
|
|
|
* add 'bandwidthrate' to this, capping it at
|
|
|
|
* bandwidthburst. (OPEN ORs only) */
|
2005-11-26 02:43:57 +01:00
|
|
|
int n_circuits; /**< How many circuits use this connection as p_conn or
|
|
|
|
* n_conn ? */
|
2007-03-26 16:08:35 +02:00
|
|
|
|
|
|
|
/** Double-linked ring of circuits with queued cells waiting for room to
|
|
|
|
* free up on this connection's outbuf. Every time we pull cells from a
|
|
|
|
* circuit, we advance this pointer to the next circuit in the ring. */
|
|
|
|
struct circuit_t *active_circuits;
|
2006-07-26 21:07:26 +02:00
|
|
|
struct or_connection_t *next_with_same_id; /**< Next connection with same
|
2007-03-20 03:55:31 +01:00
|
|
|
* identity digest as this one. */
|
2006-07-26 21:07:26 +02:00
|
|
|
} or_connection_t;
|
|
|
|
|
2006-07-27 07:03:57 +02:00
|
|
|
/** Subtype of connection_t for an "edge connection" -- that is, a socks (ap)
|
|
|
|
* connection, or an exit. */
|
2006-07-26 21:07:26 +02:00
|
|
|
typedef struct edge_connection_t {
|
|
|
|
connection_t _base;
|
2004-04-01 23:32:01 +02:00
|
|
|
|
2006-07-26 21:07:26 +02:00
|
|
|
struct edge_connection_t *next_stream; /**< Points to the next stream at this
|
2006-07-27 07:03:57 +02:00
|
|
|
* edge, if any */
|
2004-05-10 10:56:42 +02:00
|
|
|
struct crypt_path_t *cpath_layer; /**< A pointer to which node in the circ
|
2006-07-27 07:03:57 +02:00
|
|
|
* this conn exits at. */
|
|
|
|
int package_window; /**< How many more relay cells can I send into the
|
|
|
|
* circuit? */
|
|
|
|
int deliver_window; /**< How many more relay cells can end at me? */
|
2004-05-10 08:52:01 +02:00
|
|
|
|
2006-07-26 21:07:26 +02:00
|
|
|
/** Nickname of planned exit node -- used with .exit support. */
|
|
|
|
char *chosen_exit_name;
|
|
|
|
|
|
|
|
socks_request_t *socks_request; /**< SOCKS structure describing request (AP
|
|
|
|
* only.) */
|
|
|
|
struct circuit_t *on_circuit; /**< The circuit (if any) that this edge
|
|
|
|
* connection is using. */
|
|
|
|
|
|
|
|
uint32_t address_ttl; /**< TTL for address-to-addr mapping on exit
|
|
|
|
* connection. Exit connections only. */
|
|
|
|
|
2008-07-23 17:58:30 +02:00
|
|
|
streamid_t stream_id; /**< The stream ID used for this edge connection on its
|
|
|
|
* circuit */
|
2006-07-27 07:03:57 +02:00
|
|
|
|
2006-10-20 19:54:48 +02:00
|
|
|
/** The reason why this connection is closing; passed to the controller. */
|
|
|
|
uint16_t end_reason;
|
|
|
|
|
2007-02-14 17:46:55 +01:00
|
|
|
/** Bytes read since last call to control_event_stream_bandwidth_used() */
|
2007-02-14 17:46:49 +01:00
|
|
|
uint32_t n_read;
|
|
|
|
|
2007-02-14 17:46:55 +01:00
|
|
|
/** Bytes written since last call to control_event_stream_bandwidth_used() */
|
2007-02-14 17:46:49 +01:00
|
|
|
uint32_t n_written;
|
|
|
|
|
2007-11-29 16:25:04 +01:00
|
|
|
/** What rendezvous service are we querying for? (AP only) */
|
2008-09-24 16:44:29 +02:00
|
|
|
rend_data_t *rend_data;
|
2006-08-14 08:03:26 +02:00
|
|
|
|
|
|
|
/** Number of times we've reassigned this application connection to
|
|
|
|
* a new circuit. We keep track because the timeout is longer if we've
|
|
|
|
* already retried several times. */
|
|
|
|
uint8_t num_socks_retries;
|
|
|
|
|
2009-05-27 23:55:51 +02:00
|
|
|
/** True iff this connection is for a DNS request only. */
|
2008-02-25 00:39:53 +01:00
|
|
|
unsigned int is_dns_request:1;
|
2007-07-10 19:14:51 +02:00
|
|
|
|
2007-10-28 19:29:29 +01:00
|
|
|
/** True iff this stream must attach to a one-hop circuit (e.g. for
|
|
|
|
* begin_dir). */
|
2008-02-25 00:39:53 +01:00
|
|
|
unsigned int want_onehop:1;
|
2007-10-28 19:29:29 +01:00
|
|
|
/** True iff this stream should use a BEGIN_DIR relay command to establish
|
|
|
|
* itself rather than BEGIN (either via onehop or via a whole circuit). */
|
2008-02-25 00:39:53 +01:00
|
|
|
unsigned int use_begindir:1;
|
2007-10-28 09:16:19 +01:00
|
|
|
|
2008-12-17 15:59:28 +01:00
|
|
|
unsigned int edge_has_sent_end:1; /**< For debugging; only used on edge
|
|
|
|
* connections. Set once we've set the stream end,
|
|
|
|
* and check in connection_about_to_close_connection().
|
|
|
|
*/
|
|
|
|
/** True iff we've blocked reading until the circuit has fewer queued
|
|
|
|
* cells. */
|
|
|
|
unsigned int edge_blocked_on_circ:1;
|
|
|
|
/** For AP connections only. If 1, and we fail to reach the chosen exit,
|
|
|
|
* stop requiring it. */
|
|
|
|
unsigned int chosen_exit_optional:1;
|
|
|
|
/** For AP connections only. If non-zero, this exit node was picked as
|
|
|
|
* a result of the TrackHostExit, and the value decrements every time
|
|
|
|
* we fail to complete a circuit to our chosen exit -- if it reaches
|
|
|
|
* zero, abandon the associated mapaddress. */
|
|
|
|
unsigned int chosen_exit_retries:3;
|
|
|
|
|
2007-05-29 19:31:13 +02:00
|
|
|
/** If this is a DNSPort connection, this field holds the pending DNS
|
|
|
|
* request that we're going to try to answer. */
|
2007-05-24 22:31:30 +02:00
|
|
|
struct evdns_server_request *dns_server_request;
|
|
|
|
|
2006-07-26 21:07:26 +02:00
|
|
|
} edge_connection_t;
|
|
|
|
|
2006-07-27 07:03:57 +02:00
|
|
|
/** Subtype of connection_t for an "directory connection" -- that is, an HTTP
|
|
|
|
* connection to retrieve or serve directory material. */
|
2006-07-26 21:07:26 +02:00
|
|
|
typedef struct dir_connection_t {
|
|
|
|
connection_t _base;
|
|
|
|
|
2005-12-14 21:40:40 +01:00
|
|
|
char *requested_resource; /**< Which 'resource' did we ask the directory
|
2006-07-16 07:57:11 +02:00
|
|
|
* for? */
|
2006-07-17 08:35:06 +02:00
|
|
|
unsigned int dirconn_direct:1; /**< Is this dirconn direct, or via Tor? */
|
2006-07-27 07:03:57 +02:00
|
|
|
|
|
|
|
/* Used only for server sides of some dir connections, to implement
|
|
|
|
* "spooling" of directory material to the outbuf. Otherwise, we'd have
|
|
|
|
* to append everything to the outbuf in one enormous chunk. */
|
2007-01-23 20:22:52 +01:00
|
|
|
/** What exactly are we spooling right now? */
|
2006-06-18 09:55:04 +02:00
|
|
|
enum {
|
2006-06-20 02:48:23 +02:00
|
|
|
DIR_SPOOL_NONE=0, DIR_SPOOL_SERVER_BY_DIGEST, DIR_SPOOL_SERVER_BY_FP,
|
2007-04-16 20:39:39 +02:00
|
|
|
DIR_SPOOL_EXTRA_BY_DIGEST, DIR_SPOOL_EXTRA_BY_FP,
|
2006-06-20 02:48:23 +02:00
|
|
|
DIR_SPOOL_CACHED_DIR, DIR_SPOOL_NETWORKSTATUS
|
2007-01-27 09:55:06 +01:00
|
|
|
} dir_spool_src : 3;
|
2007-06-10 09:34:21 +02:00
|
|
|
/** If we're fetching descriptors, what router purpose shall we assign
|
|
|
|
* to them? */
|
|
|
|
uint8_t router_purpose;
|
2009-05-27 23:55:51 +02:00
|
|
|
/** List of fingerprints for networkstatuses or descriptors to be spooled. */
|
2006-06-18 09:38:55 +02:00
|
|
|
smartlist_t *fingerprint_stack;
|
2007-01-23 20:22:52 +01:00
|
|
|
/** A cached_dir_t object that we're currently spooling out */
|
2006-06-18 09:38:55 +02:00
|
|
|
struct cached_dir_t *cached_dir;
|
2007-01-23 20:22:52 +01:00
|
|
|
/** The current offset into cached_dir. */
|
2006-06-18 09:38:55 +02:00
|
|
|
off_t cached_dir_offset;
|
2007-01-23 20:22:52 +01:00
|
|
|
/** The zlib object doing on-the-fly compression for spooled data. */
|
2006-06-18 09:38:55 +02:00
|
|
|
tor_zlib_state_t *zlib_state;
|
2005-09-08 22:18:15 +02:00
|
|
|
|
2007-11-29 16:25:04 +01:00
|
|
|
/** What rendezvous service are we querying for? */
|
2008-09-24 16:44:29 +02:00
|
|
|
rend_data_t *rend_data;
|
2004-11-03 02:32:26 +01:00
|
|
|
|
2006-07-26 21:07:26 +02:00
|
|
|
char identity_digest[DIGEST_LEN]; /**< Hash of the public RSA key for
|
|
|
|
* the directory server's signing key. */
|
2007-01-27 09:55:06 +01:00
|
|
|
|
2006-07-26 21:07:26 +02:00
|
|
|
} dir_connection_t;
|
|
|
|
|
2006-07-27 07:03:57 +02:00
|
|
|
/** Subtype of connection_t for an connection to a controller. */
|
2006-07-26 21:07:26 +02:00
|
|
|
typedef struct control_connection_t {
|
|
|
|
connection_t _base;
|
2005-03-01 02:15:01 +01:00
|
|
|
|
2006-07-27 07:03:57 +02:00
|
|
|
uint32_t event_mask; /**< Bitfield: which events does this controller
|
|
|
|
* care about? */
|
2006-10-03 20:58:56 +02:00
|
|
|
|
2007-08-16 19:31:23 +02:00
|
|
|
/** True if we have sent a protocolinfo reply on this connection. */
|
|
|
|
unsigned int have_sent_protocolinfo:1;
|
|
|
|
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Amount of space allocated in incoming_cmd. */
|
2005-04-28 00:01:34 +02:00
|
|
|
uint32_t incoming_cmd_len;
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Number of bytes currently stored in incoming_cmd. */
|
2005-04-28 00:01:34 +02:00
|
|
|
uint32_t incoming_cmd_cur_len;
|
2008-12-17 18:20:31 +01:00
|
|
|
/** A control command that we're reading from the inbuf, but which has not
|
2008-12-17 23:46:00 +01:00
|
|
|
* yet arrived completely. */
|
2005-04-28 00:01:34 +02:00
|
|
|
char *incoming_cmd;
|
2006-07-26 21:07:26 +02:00
|
|
|
} control_connection_t;
|
major overhaul: dns slave subsystem, topics
on startup, it forks off a master dns handler, which forks off dns
slaves (like the apache model). slaves as spawned as load increases,
and then reused. excess slaves are not ever killed, currently.
implemented topics. each topic has a receive window in each direction
at each edge of the circuit, and sends sendme's at the data level, as
per before. each circuit also has receive windows in each direction at
each hop; an edge sends a circuit-level sendme as soon as enough data
cells have arrived (regardless of whether the data cells were flushed
to the exit conns). removed the 'connected' cell type, since it's now
a topic command within data cells.
at the edge of the circuit, there can be multiple connections associated
with a single circuit. you find them via the linked list conn->next_topic.
currently each new ap connection starts its own circuit, so we ought
to see comparable performance to what we had before. but that's only
because i haven't written the code to reattach to old circuits. please
try to break it as-is, and then i'll make it reuse the same circuit and
we'll try to break that.
svn:r152
2003-01-26 10:02:24 +01:00
|
|
|
|
2006-07-27 07:03:57 +02:00
|
|
|
/** Cast a connection_t subtype pointer to a connection_t **/
|
2007-01-15 22:13:37 +01:00
|
|
|
#define TO_CONN(c) (&(((c)->_base)))
|
2006-07-27 07:03:57 +02:00
|
|
|
/** Helper macro: Given a pointer to to._base, of type from*, return &to. */
|
2007-02-16 21:00:43 +01:00
|
|
|
#define DOWNCAST(to, ptr) ((to*)SUBTYPE_P(ptr, to, _base))
|
2006-07-26 21:07:26 +02:00
|
|
|
|
2006-07-27 07:03:57 +02:00
|
|
|
/** Convert a connection_t* to an or_connection_t*; assert if the cast is
|
|
|
|
* invalid. */
|
2006-09-08 18:12:15 +02:00
|
|
|
static or_connection_t *TO_OR_CONN(connection_t *);
|
2006-07-27 07:03:57 +02:00
|
|
|
/** Convert a connection_t* to a dir_connection_t*; assert if the cast is
|
|
|
|
* invalid. */
|
2006-09-08 18:12:15 +02:00
|
|
|
static dir_connection_t *TO_DIR_CONN(connection_t *);
|
2006-07-27 07:03:57 +02:00
|
|
|
/** Convert a connection_t* to an edge_connection_t*; assert if the cast is
|
|
|
|
* invalid. */
|
2006-09-08 18:12:15 +02:00
|
|
|
static edge_connection_t *TO_EDGE_CONN(connection_t *);
|
2006-07-27 07:03:57 +02:00
|
|
|
/** Convert a connection_t* to an control_connection_t*; assert if the cast is
|
|
|
|
* invalid. */
|
2006-09-08 18:12:15 +02:00
|
|
|
static control_connection_t *TO_CONTROL_CONN(connection_t *);
|
2006-07-26 21:07:26 +02:00
|
|
|
|
2006-09-08 18:12:15 +02:00
|
|
|
static INLINE or_connection_t *TO_OR_CONN(connection_t *c)
|
2006-07-26 21:07:26 +02:00
|
|
|
{
|
|
|
|
tor_assert(c->magic == OR_CONNECTION_MAGIC);
|
2006-08-05 19:52:51 +02:00
|
|
|
return DOWNCAST(or_connection_t, c);
|
2006-07-26 21:07:26 +02:00
|
|
|
}
|
2006-09-08 18:12:15 +02:00
|
|
|
static INLINE dir_connection_t *TO_DIR_CONN(connection_t *c)
|
2006-07-26 21:07:26 +02:00
|
|
|
{
|
|
|
|
tor_assert(c->magic == DIR_CONNECTION_MAGIC);
|
2006-08-05 19:52:51 +02:00
|
|
|
return DOWNCAST(dir_connection_t, c);
|
2006-07-26 21:07:26 +02:00
|
|
|
}
|
2006-09-08 18:12:15 +02:00
|
|
|
static INLINE edge_connection_t *TO_EDGE_CONN(connection_t *c)
|
2006-07-26 21:07:26 +02:00
|
|
|
{
|
|
|
|
tor_assert(c->magic == EDGE_CONNECTION_MAGIC);
|
2006-08-05 19:52:51 +02:00
|
|
|
return DOWNCAST(edge_connection_t, c);
|
2006-07-26 21:07:26 +02:00
|
|
|
}
|
2006-09-08 18:12:15 +02:00
|
|
|
static INLINE control_connection_t *TO_CONTROL_CONN(connection_t *c)
|
2006-07-26 21:07:26 +02:00
|
|
|
{
|
|
|
|
tor_assert(c->magic == CONTROL_CONNECTION_MAGIC);
|
2006-08-05 19:52:51 +02:00
|
|
|
return DOWNCAST(control_connection_t, c);
|
2006-07-26 21:07:26 +02:00
|
|
|
}
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2008-12-17 18:20:31 +01:00
|
|
|
/** What action type does an address policy indicate: accept or reject? */
|
2005-08-09 07:22:23 +02:00
|
|
|
typedef enum {
|
|
|
|
ADDR_POLICY_ACCEPT=1,
|
|
|
|
ADDR_POLICY_REJECT=2,
|
|
|
|
} addr_policy_action_t;
|
2003-04-07 06:38:19 +02:00
|
|
|
|
2008-03-17 17:51:48 +01:00
|
|
|
/** A reference-counted address policy rule. */
|
2004-12-04 02:14:36 +01:00
|
|
|
typedef struct addr_policy_t {
|
2008-01-02 05:43:44 +01:00
|
|
|
int refcnt; /**< Reference count */
|
|
|
|
addr_policy_action_t policy_type:2;/**< What to do when the policy matches.*/
|
|
|
|
unsigned int is_private:1; /**< True iff this is the pseudo-address,
|
|
|
|
* "private". */
|
|
|
|
unsigned int is_canonical:1; /**< True iff this policy is the canonical
|
|
|
|
* copy (stored in a hash table to avoid
|
|
|
|
* duplication of common policies) */
|
2007-07-19 21:40:45 +02:00
|
|
|
maskbits_t maskbits; /**< Accept/reject all addresses <b>a</b> such that the
|
|
|
|
* first <b>maskbits</b> bits of <b>a</b> match
|
|
|
|
* <b>addr</b>. */
|
2008-07-24 15:44:04 +02:00
|
|
|
tor_addr_t addr; /**< Base address to accept or reject. */
|
2004-05-10 12:27:54 +02:00
|
|
|
uint16_t prt_min; /**< Lowest port number to accept/reject. */
|
|
|
|
uint16_t prt_max; /**< Highest port number to accept/reject. */
|
2004-12-04 02:14:36 +01:00
|
|
|
} addr_policy_t;
|
2003-04-07 06:38:19 +02:00
|
|
|
|
2005-09-07 18:42:53 +02:00
|
|
|
/** A cached_dir_t represents a cacheable directory object, along with its
|
|
|
|
* compressed form. */
|
|
|
|
typedef struct cached_dir_t {
|
2009-05-27 23:55:51 +02:00
|
|
|
char *dir; /**< Contents of this object, NUL-terminated. */
|
2005-09-07 18:42:53 +02:00
|
|
|
char *dir_z; /**< Compressed contents of this object. */
|
2009-05-27 23:55:51 +02:00
|
|
|
size_t dir_len; /**< Length of <b>dir</b> (not counting its NUL). */
|
2008-09-14 05:36:54 +02:00
|
|
|
size_t dir_z_len; /**< Length of <b>dir_z</b>. */
|
|
|
|
time_t published; /**< When was this object published. */
|
2006-06-18 09:38:55 +02:00
|
|
|
int refcnt; /**< Reference count for this cached_dir_t. */
|
2005-09-07 18:42:53 +02:00
|
|
|
} cached_dir_t;
|
|
|
|
|
2007-01-22 08:51:06 +01:00
|
|
|
/** Enum used to remember where a signed_descriptor_t is stored and how to
|
|
|
|
* manage the memory for signed_descriptor_body. */
|
2006-06-22 09:01:54 +02:00
|
|
|
typedef enum {
|
2007-01-22 08:51:06 +01:00
|
|
|
/** The descriptor isn't stored on disk at all: the copy in memory is
|
|
|
|
* canonical; the saved_offset field is meaningless. */
|
|
|
|
SAVED_NOWHERE=0,
|
|
|
|
/** The descriptor is stored in the cached_routers file: the
|
|
|
|
* signed_descriptor_body is meaningless; the signed_descriptor_len and
|
|
|
|
* saved_offset are used to index into the mmaped cache file. */
|
|
|
|
SAVED_IN_CACHE,
|
|
|
|
/** The descriptor is stored in the cached_routers.new file: the
|
|
|
|
* signed_descriptor_body and saved_offset fields are both set. */
|
|
|
|
/* FFFF (We could also mmap the file and grow the mmap as needed, or
|
|
|
|
* lazy-load the descriptor text by using seek and read. We don't, for
|
|
|
|
* now.)
|
|
|
|
*/
|
|
|
|
SAVED_IN_JOURNAL
|
2006-06-22 09:01:54 +02:00
|
|
|
} saved_location_t;
|
|
|
|
|
2008-12-17 15:59:28 +01:00
|
|
|
/** Enumeration: what kind of download schedule are we using for a given
|
2007-12-19 05:18:28 +01:00
|
|
|
* object? */
|
2007-10-24 21:53:08 +02:00
|
|
|
typedef enum {
|
|
|
|
DL_SCHED_GENERIC = 0,
|
|
|
|
DL_SCHED_CONSENSUS = 1,
|
2008-12-27 08:30:47 +01:00
|
|
|
DL_SCHED_BRIDGE = 2,
|
2007-10-24 21:53:08 +02:00
|
|
|
} download_schedule_t;
|
|
|
|
|
2007-05-29 19:31:13 +02:00
|
|
|
/** Information about our plans for retrying downloads for a downloadable
|
|
|
|
* object. */
|
2007-05-18 23:19:53 +02:00
|
|
|
typedef struct download_status_t {
|
|
|
|
time_t next_attempt_at; /**< When should we try downloading this descriptor
|
|
|
|
* again? */
|
|
|
|
uint8_t n_download_failures; /**< Number of failures trying to download the
|
|
|
|
* most recent descriptor. */
|
2007-12-19 05:18:28 +01:00
|
|
|
download_schedule_t schedule : 8;
|
2007-05-18 23:19:53 +02:00
|
|
|
} download_status_t;
|
|
|
|
|
2008-12-23 22:17:52 +01:00
|
|
|
/** If n_download_failures is this high, the download can never happen. */
|
|
|
|
#define IMPOSSIBLE_TO_DOWNLOAD 255
|
|
|
|
|
2007-12-02 05:39:56 +01:00
|
|
|
/** The max size we expect router descriptor annotations we create to
|
|
|
|
* be. We'll accept larger ones if we see them on disk, but we won't
|
|
|
|
* create any that are larger than this. */
|
|
|
|
#define ROUTER_ANNOTATION_BUF_LEN 256
|
|
|
|
|
2005-11-05 21:15:27 +01:00
|
|
|
/** Information need to cache an onion router's descriptor. */
|
|
|
|
typedef struct signed_descriptor_t {
|
2007-12-02 05:39:56 +01:00
|
|
|
/** Pointer to the raw server descriptor, preceded by annotations. Not
|
2007-09-26 18:19:44 +02:00
|
|
|
* necessarily NUL-terminated. If saved_location is SAVED_IN_CACHE, this
|
2007-12-02 05:39:56 +01:00
|
|
|
* pointer is null. */
|
2006-01-12 19:04:17 +01:00
|
|
|
char *signed_descriptor_body;
|
2009-05-27 23:55:51 +02:00
|
|
|
/** Length of the annotations preceding the server descriptor. */
|
2007-09-26 18:19:44 +02:00
|
|
|
size_t annotations_len;
|
2007-01-23 20:22:52 +01:00
|
|
|
/** Length of the server descriptor. */
|
2005-11-05 21:15:27 +01:00
|
|
|
size_t signed_descriptor_len;
|
2007-12-07 22:27:58 +01:00
|
|
|
/** Digest of the server descriptor, computed as specified in
|
|
|
|
* dir-spec.txt. */
|
2005-11-05 21:15:27 +01:00
|
|
|
char signed_descriptor_digest[DIGEST_LEN];
|
2007-01-23 20:22:52 +01:00
|
|
|
/** Identity digest of the router. */
|
2005-11-05 21:15:27 +01:00
|
|
|
char identity_digest[DIGEST_LEN];
|
2007-12-02 05:39:56 +01:00
|
|
|
/** Declared publication time of the descriptor. */
|
2005-11-05 21:15:27 +01:00
|
|
|
time_t published_on;
|
2007-05-29 19:31:13 +02:00
|
|
|
/** For routerdescs only: digest of the corresponding extrainfo. */
|
2007-04-16 23:37:21 +02:00
|
|
|
char extra_info_digest[DIGEST_LEN];
|
2007-05-29 19:31:13 +02:00
|
|
|
/** For routerdescs only: Status of downloading the corresponding
|
|
|
|
* extrainfo. */
|
2007-05-18 23:19:53 +02:00
|
|
|
download_status_t ei_dl_status;
|
2007-01-23 20:22:52 +01:00
|
|
|
/** Where is the descriptor saved? */
|
2007-09-26 18:19:44 +02:00
|
|
|
saved_location_t saved_location;
|
2007-01-23 20:22:52 +01:00
|
|
|
/** If saved_location is SAVED_IN_CACHE or SAVED_IN_JOURNAL, the offset of
|
|
|
|
* this descriptor in the corresponding file. */
|
2006-04-29 20:42:26 +02:00
|
|
|
off_t saved_offset;
|
2007-11-07 18:11:23 +01:00
|
|
|
/** What position is this descriptor within routerlist->routers or
|
|
|
|
* routerlist->old_routers? -1 for none. */
|
|
|
|
int routerlist_index;
|
2007-10-19 04:15:47 +02:00
|
|
|
/** The valid-until time of the most recent consensus that listed this
|
2008-04-04 23:18:56 +02:00
|
|
|
* descriptor, or a bit after the publication time of the most recent v2
|
|
|
|
* networkstatus that listed it. 0 for "never listed in a consensus or
|
|
|
|
* status, so far as we know." */
|
2007-10-19 04:15:47 +02:00
|
|
|
time_t last_listed_as_valid_until;
|
2008-04-04 23:18:56 +02:00
|
|
|
#ifdef TRACK_SERVED_TIME
|
2008-12-17 15:59:28 +01:00
|
|
|
/** The last time we served anybody this descriptor. Used for internal
|
|
|
|
* testing to see whether we're holding on to descriptors too long. */
|
2008-12-18 17:11:24 +01:00
|
|
|
time_t last_served_at; /*XXXX remove if not useful. */
|
2008-04-04 23:18:56 +02:00
|
|
|
#endif
|
2007-05-29 19:31:13 +02:00
|
|
|
/* If true, we do not ever try to save this object in the cache. */
|
2007-04-30 21:48:39 +02:00
|
|
|
unsigned int do_not_cache : 1;
|
2007-05-29 19:31:13 +02:00
|
|
|
/* If true, this item is meant to represent an extrainfo. */
|
2007-05-20 07:15:53 +02:00
|
|
|
unsigned int is_extrainfo : 1;
|
2007-10-21 06:41:00 +02:00
|
|
|
/* If true, we got an extrainfo for this item, and the digest was right,
|
|
|
|
* but it was incompatible. */
|
|
|
|
unsigned int extrainfo_is_bogus : 1;
|
2008-01-10 18:48:40 +01:00
|
|
|
/* If true, we are willing to transmit this item unencrypted. */
|
|
|
|
unsigned int send_unencrypted : 1;
|
2005-11-05 21:15:27 +01:00
|
|
|
} signed_descriptor_t;
|
|
|
|
|
2008-09-25 22:21:35 +02:00
|
|
|
/** A signed integer representing a country code. */
|
|
|
|
typedef int16_t country_t;
|
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Information about another onion router in the network. */
|
2002-12-03 23:18:23 +01:00
|
|
|
typedef struct {
|
2005-11-05 21:15:27 +01:00
|
|
|
signed_descriptor_t cache_info;
|
2004-05-10 08:52:01 +02:00
|
|
|
char *address; /**< Location of OR: either a hostname or an IP address. */
|
|
|
|
char *nickname; /**< Human-readable OR name. */
|
2003-12-17 22:09:31 +01:00
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
uint32_t addr; /**< IPv4 address of OR, in host order. */
|
2005-11-17 02:17:53 +01:00
|
|
|
uint16_t or_port; /**< Port for TLS connections. */
|
2004-05-10 12:27:54 +02:00
|
|
|
uint16_t dir_port; /**< Port for HTTP directory connections. */
|
2003-09-26 20:27:35 +02:00
|
|
|
|
2004-05-10 12:27:54 +02:00
|
|
|
crypto_pk_env_t *onion_pkey; /**< Public RSA key for onions. */
|
|
|
|
crypto_pk_env_t *identity_pkey; /**< Public RSA key for signing. */
|
2003-09-27 23:30:10 +02:00
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
char *platform; /**< What software/operating system is this OR using? */
|
2004-04-07 23:36:03 +02:00
|
|
|
|
2002-06-27 00:45:49 +02:00
|
|
|
/* link info */
|
2004-05-10 08:52:01 +02:00
|
|
|
uint32_t bandwidthrate; /**< How many bytes does this OR add to its token
|
|
|
|
* bucket per second? */
|
|
|
|
uint32_t bandwidthburst; /**< How large is this OR's token bucket? */
|
2004-07-12 20:02:54 +02:00
|
|
|
/** How many bytes/s is this router known to handle? */
|
2004-08-15 10:15:12 +02:00
|
|
|
uint32_t bandwidthcapacity;
|
2008-01-02 05:43:44 +01:00
|
|
|
smartlist_t *exit_policy; /**< What streams will this OR permit
|
|
|
|
* to exit? NULL for 'reject *:*'. */
|
2004-08-17 08:06:05 +02:00
|
|
|
long uptime; /**< How many seconds the router claims to have been up */
|
2004-10-15 03:58:11 +02:00
|
|
|
smartlist_t *declared_family; /**< Nicknames of router which this router
|
|
|
|
* claims are its family. */
|
2005-05-02 23:22:31 +02:00
|
|
|
char *contact_info; /**< Declared contact info for this router. */
|
2005-09-12 08:56:42 +02:00
|
|
|
unsigned int is_hibernating:1; /**< Whether the router claims to be
|
|
|
|
* hibernating */
|
2006-09-21 23:48:06 +02:00
|
|
|
unsigned int has_old_dnsworkers:1; /**< Whether the router is using
|
|
|
|
* dnsworker code. */
|
2007-05-29 19:31:13 +02:00
|
|
|
unsigned int caches_extra_info:1; /**< Whether the router caches and serves
|
|
|
|
* extrainfo documents. */
|
2008-09-26 20:58:45 +02:00
|
|
|
unsigned int allow_single_hop_exits:1; /**< Whether the router allows
|
|
|
|
* single hop exits. */
|
2005-08-26 22:22:32 +02:00
|
|
|
|
2005-08-26 22:59:04 +02:00
|
|
|
/* local info */
|
2005-09-12 08:56:42 +02:00
|
|
|
unsigned int is_running:1; /**< As far as we know, is this OR currently
|
|
|
|
* running? */
|
2006-03-19 02:21:59 +01:00
|
|
|
unsigned int is_valid:1; /**< Has a trusted dirserver validated this OR?
|
2005-09-12 08:56:42 +02:00
|
|
|
* (For Authdir: Have we validated this OR?)
|
|
|
|
*/
|
2005-10-05 00:23:31 +02:00
|
|
|
unsigned int is_named:1; /**< Do we believe the nickname that this OR gives
|
|
|
|
* us? */
|
2005-12-15 22:30:57 +01:00
|
|
|
unsigned int is_fast:1; /** Do we think this is a fast OR? */
|
|
|
|
unsigned int is_stable:1; /** Do we think this is a stable OR? */
|
2006-02-12 04:43:39 +01:00
|
|
|
unsigned int is_possible_guard:1; /**< Do we think this is an OK guard? */
|
2006-10-01 23:59:09 +02:00
|
|
|
unsigned int is_exit:1; /**< Do we think this is an OK exit? */
|
2006-10-12 00:06:01 +02:00
|
|
|
unsigned int is_bad_exit:1; /**< Do we think this exit is censored, borked,
|
|
|
|
* or otherwise nasty? */
|
2007-12-10 17:49:54 +01:00
|
|
|
unsigned int is_bad_directory:1; /**< Do we think this directory is junky,
|
|
|
|
* underpowered, or otherwise useless? */
|
2007-10-29 20:10:47 +01:00
|
|
|
unsigned int wants_to_be_hs_dir:1; /**< True iff this router claims to be
|
|
|
|
* a hidden service directory. */
|
2007-10-29 20:10:42 +01:00
|
|
|
unsigned int is_hs_dir:1; /**< True iff this router is a hidden service
|
2007-10-29 20:10:47 +01:00
|
|
|
* directory according to the authorities. */
|
2008-12-29 02:47:28 +01:00
|
|
|
unsigned int policy_is_reject_star:1; /**< True iff the exit policy for this
|
|
|
|
* router rejects everything. */
|
2005-09-12 08:56:42 +02:00
|
|
|
|
2007-05-08 12:11:53 +02:00
|
|
|
/** Tor can use this router for general positions in circuits. */
|
2006-03-17 23:08:59 +01:00
|
|
|
#define ROUTER_PURPOSE_GENERAL 0
|
2007-05-08 12:11:53 +02:00
|
|
|
/** Tor should avoid using this router for circuit-building. */
|
2006-03-17 23:08:59 +01:00
|
|
|
#define ROUTER_PURPOSE_CONTROLLER 1
|
2007-05-08 12:11:53 +02:00
|
|
|
/** Tor should use this router only for bridge positions in circuits. */
|
2007-08-19 17:20:11 +02:00
|
|
|
#define ROUTER_PURPOSE_BRIDGE 2
|
2007-10-04 18:21:58 +02:00
|
|
|
/** Tor should not use this router; it was marked in cached-descriptors with
|
|
|
|
* a purpose we didn't recognize. */
|
2007-09-27 22:46:30 +02:00
|
|
|
#define ROUTER_PURPOSE_UNKNOWN 255
|
2007-08-19 17:20:11 +02:00
|
|
|
|
2007-05-08 12:11:53 +02:00
|
|
|
uint8_t purpose; /** What positions in a circuit is this router good for? */
|
2006-03-17 23:08:59 +01:00
|
|
|
|
2005-08-30 08:48:24 +02:00
|
|
|
/* The below items are used only by authdirservers for
|
2005-08-26 22:22:32 +02:00
|
|
|
* reachability testing. */
|
2005-09-01 10:13:40 +02:00
|
|
|
/** When was the last time we could reach this OR? */
|
|
|
|
time_t last_reachable;
|
|
|
|
/** When did we start testing reachability for this OR? */
|
|
|
|
time_t testing_since;
|
2008-09-25 22:21:35 +02:00
|
|
|
/** According to the geoip db what country is this router in? */
|
|
|
|
country_t country;
|
2002-06-27 00:45:49 +02:00
|
|
|
} routerinfo_t;
|
|
|
|
|
2007-04-21 19:46:22 +02:00
|
|
|
/** Information needed to keep and cache a signed extra-info document. */
|
2007-04-16 06:17:58 +02:00
|
|
|
typedef struct extrainfo_t {
|
|
|
|
signed_descriptor_t cache_info;
|
2007-04-21 19:46:22 +02:00
|
|
|
/** The router's nickname. */
|
2007-04-16 06:17:58 +02:00
|
|
|
char nickname[MAX_NICKNAME_LEN+1];
|
2007-04-21 19:46:22 +02:00
|
|
|
/** True iff we found the right key for this extra-info, verified the
|
|
|
|
* signature, and found it to be bad. */
|
2007-04-16 23:37:21 +02:00
|
|
|
unsigned int bad_sig : 1;
|
2007-04-21 19:46:22 +02:00
|
|
|
/** If present, we didn't have the right key to verify this extra-info,
|
|
|
|
* so this is a copy of the signature in the document. */
|
2007-04-16 06:17:58 +02:00
|
|
|
char *pending_sig;
|
2007-05-29 19:31:13 +02:00
|
|
|
/** Length of pending_sig. */
|
2007-05-15 00:51:05 +02:00
|
|
|
size_t pending_sig_len;
|
2007-04-16 06:17:58 +02:00
|
|
|
} extrainfo_t;
|
|
|
|
|
2005-09-24 23:56:04 +02:00
|
|
|
/** Contents of a single router entry in a network status object.
|
2005-09-05 01:12:27 +02:00
|
|
|
*/
|
2005-09-02 22:37:31 +02:00
|
|
|
typedef struct routerstatus_t {
|
2005-09-05 01:12:27 +02:00
|
|
|
time_t published_on; /**< When was this router published? */
|
2005-12-14 21:40:40 +01:00
|
|
|
char nickname[MAX_NICKNAME_LEN+1]; /**< The nickname this router says it
|
|
|
|
* has. */
|
|
|
|
char identity_digest[DIGEST_LEN]; /**< Digest of the router's identity
|
|
|
|
* key. */
|
2005-09-05 01:12:27 +02:00
|
|
|
char descriptor_digest[DIGEST_LEN]; /**< Digest of the router's most recent
|
2005-09-08 09:10:12 +02:00
|
|
|
* descriptor. */
|
|
|
|
uint32_t addr; /**< IPv4 address for this router. */
|
|
|
|
uint16_t or_port; /**< OR port for this router. */
|
|
|
|
uint16_t dir_port; /**< Directory port for this router. */
|
2007-06-13 21:06:23 +02:00
|
|
|
unsigned int is_authority:1; /**< True iff this router is an authority. */
|
2005-09-08 09:10:12 +02:00
|
|
|
unsigned int is_exit:1; /**< True iff this router is a good exit. */
|
|
|
|
unsigned int is_stable:1; /**< True iff this router stays up a long time. */
|
|
|
|
unsigned int is_fast:1; /**< True iff this router has good bandwidth. */
|
|
|
|
unsigned int is_running:1; /**< True iff this router is up. */
|
|
|
|
unsigned int is_named:1; /**< True iff "nickname" belongs to this router. */
|
2007-10-19 20:56:24 +02:00
|
|
|
unsigned int is_unnamed:1; /**< True iff "nickname" belongs to another
|
|
|
|
* router. */
|
2007-11-16 08:29:01 +01:00
|
|
|
unsigned int is_valid:1; /**< True iff this router isn't invalid. */
|
2005-12-15 21:49:01 +01:00
|
|
|
unsigned int is_v2_dir:1; /**< True iff this router can serve directory
|
2005-12-12 02:03:28 +01:00
|
|
|
* information with v2 of the directory
|
2005-12-15 21:49:01 +01:00
|
|
|
* protocol. (All directory caches cache v1
|
|
|
|
* directories.) */
|
2006-01-24 01:31:16 +01:00
|
|
|
unsigned int is_possible_guard:1; /**< True iff this router would be a good
|
|
|
|
* choice as an entry guard. */
|
2006-10-12 00:06:01 +02:00
|
|
|
unsigned int is_bad_exit:1; /**< True iff this node is a bad choice for
|
|
|
|
* an exit node. */
|
2007-01-03 20:58:00 +01:00
|
|
|
unsigned int is_bad_directory:1; /**< Do we think this directory is junky,
|
|
|
|
* underpowered, or otherwise useless? */
|
2008-08-14 20:01:09 +02:00
|
|
|
unsigned int is_hs_dir:1; /**< True iff this router is a v2-or-later hidden
|
2007-11-16 08:29:01 +01:00
|
|
|
* service directory. */
|
2006-12-24 05:09:48 +01:00
|
|
|
/** True iff we know version info for this router. (i.e., a "v" entry was
|
2007-01-03 11:30:26 +01:00
|
|
|
* included.) We'll replace all these with a big tor_version_t or a char[]
|
2006-12-24 05:09:48 +01:00
|
|
|
* if the number of traits we care about ever becomes incredibly big. */
|
|
|
|
unsigned int version_known:1;
|
|
|
|
/** True iff this router is a version that supports BEGIN_DIR cells. */
|
|
|
|
unsigned int version_supports_begindir:1;
|
2008-04-24 17:43:25 +02:00
|
|
|
/** True iff this router is a version that supports conditional consensus
|
|
|
|
* downloads (signed by list of authorities). */
|
|
|
|
unsigned int version_supports_conditional_consensus:1;
|
2007-05-01 22:13:49 +02:00
|
|
|
/** True iff this router is a version that we can post extrainfo docs to. */
|
|
|
|
unsigned int version_supports_extrainfo_upload:1;
|
2007-10-08 19:44:09 +02:00
|
|
|
/** True iff this router is a version that, if it caches directory info,
|
|
|
|
* we can get v3 downloads from. */
|
|
|
|
unsigned int version_supports_v3_dir:1;
|
2006-12-24 05:09:48 +01:00
|
|
|
|
2008-08-15 01:00:57 +02:00
|
|
|
unsigned int has_bandwidth:1; /**< The vote/consensus had bw info */
|
|
|
|
unsigned int has_exitsummary:1; /**< The vote/consensus had exit summaries */
|
2009-07-31 06:33:53 +02:00
|
|
|
unsigned int has_measured_bw:1; /**< The vote/consensus had a measured bw */
|
|
|
|
|
|
|
|
uint32_t measured_bw; /**< Measured bandwidth (capacity) of the router */
|
2008-08-15 01:00:57 +02:00
|
|
|
|
2008-08-15 01:00:44 +02:00
|
|
|
uint32_t bandwidth; /**< Bandwidth (capacity) of the router as reported in
|
|
|
|
* the vote/consensus, in kilobytes/sec. */
|
|
|
|
char *exitsummary; /**< exit policy summary -
|
|
|
|
* XXX weasel: this probably should not stay a string. */
|
|
|
|
|
2007-10-09 17:27:15 +02:00
|
|
|
/* ---- The fields below aren't derived from the networkstatus; they
|
|
|
|
* hold local information only. */
|
|
|
|
|
2005-12-27 06:26:03 +01:00
|
|
|
/** True if we, as a directory mirror, want to download the corresponding
|
|
|
|
* routerinfo from the authority who gave us this routerstatus. (That is,
|
|
|
|
* if we don't have the routerinfo, and if we haven't already tried to get it
|
2007-10-19 20:56:21 +02:00
|
|
|
* from this authority.) Applies in v2 networkstatus document only.
|
2005-12-27 06:26:03 +01:00
|
|
|
*/
|
|
|
|
unsigned int need_to_mirror:1;
|
2005-10-07 21:25:01 +02:00
|
|
|
unsigned int name_lookup_warned:1; /**< Have we warned the user for referring
|
2005-10-05 00:23:31 +02:00
|
|
|
* to this (unnamed) router by nickname?
|
|
|
|
*/
|
2007-10-09 17:27:15 +02:00
|
|
|
time_t last_dir_503_at; /**< When did this router last tell us that it
|
|
|
|
* was too busy to serve directory info? */
|
|
|
|
download_status_t dl_status;
|
|
|
|
|
|
|
|
} routerstatus_t;
|
2005-09-22 03:51:14 +02:00
|
|
|
|
2006-04-18 05:07:24 +02:00
|
|
|
/** How many times will we try to download a router's descriptor before giving
|
|
|
|
* up? */
|
2005-09-18 06:15:39 +02:00
|
|
|
#define MAX_ROUTERDESC_DOWNLOAD_FAILURES 8
|
2005-09-18 04:51:12 +02:00
|
|
|
|
2007-05-31 21:03:44 +02:00
|
|
|
/** Contents of a v2 (non-consensus, non-vote) network status object. */
|
2007-10-16 01:15:24 +02:00
|
|
|
typedef struct networkstatus_v2_t {
|
2005-09-05 01:12:27 +02:00
|
|
|
/** When did we receive the network-status document? */
|
|
|
|
time_t received_on;
|
2005-09-18 04:24:42 +02:00
|
|
|
|
2005-09-07 18:42:53 +02:00
|
|
|
/** What was the digest of the document? */
|
|
|
|
char networkstatus_digest[DIGEST_LEN];
|
2005-09-05 01:12:27 +02:00
|
|
|
|
|
|
|
/* These fields come from the actual network-status document.*/
|
|
|
|
time_t published_on; /**< Declared publication date. */
|
2005-09-02 22:37:31 +02:00
|
|
|
|
2005-09-08 09:10:12 +02:00
|
|
|
char *source_address; /**< Canonical directory server hostname. */
|
|
|
|
uint32_t source_addr; /**< Canonical directory server IP. */
|
|
|
|
uint16_t source_dirport; /**< Canonical directory server dirport. */
|
2005-09-02 22:37:31 +02:00
|
|
|
|
2005-12-14 21:40:40 +01:00
|
|
|
unsigned int binds_names:1; /**< True iff this directory server binds
|
|
|
|
* names. */
|
2005-09-21 02:41:06 +02:00
|
|
|
unsigned int recommends_versions:1; /**< True iff this directory server
|
|
|
|
* recommends client and server software
|
|
|
|
* versions. */
|
2007-01-03 20:58:00 +01:00
|
|
|
unsigned int lists_bad_exits:1; /**< True iff this directory server marks
|
2006-10-19 17:45:48 +02:00
|
|
|
* malfunctioning exits as bad. */
|
2007-01-03 20:58:00 +01:00
|
|
|
/** True iff this directory server marks malfunctioning directories as
|
|
|
|
* bad. */
|
|
|
|
unsigned int lists_bad_directories:1;
|
2007-05-17 00:15:57 +02:00
|
|
|
|
|
|
|
char identity_digest[DIGEST_LEN]; /**< Digest of signing key. */
|
|
|
|
char *contact; /**< How to contact directory admin? (may be NULL). */
|
|
|
|
crypto_pk_env_t *signing_key; /**< Key used to sign this directory. */
|
|
|
|
char *client_versions; /**< comma-separated list of recommended client
|
|
|
|
* versions. */
|
|
|
|
char *server_versions; /**< comma-separated list of recommended server
|
|
|
|
* versions. */
|
|
|
|
|
2006-04-08 08:55:10 +02:00
|
|
|
smartlist_t *entries; /**< List of routerstatus_t*. This list is kept
|
2005-09-14 04:28:35 +02:00
|
|
|
* sorted by identity_digest. */
|
2007-10-16 01:15:24 +02:00
|
|
|
} networkstatus_v2_t;
|
2005-09-02 22:37:31 +02:00
|
|
|
|
2008-12-17 18:20:31 +01:00
|
|
|
/** The claim about a single router, made in a vote. */
|
2007-06-03 05:05:10 +02:00
|
|
|
typedef struct vote_routerstatus_t {
|
2007-10-04 18:21:58 +02:00
|
|
|
routerstatus_t status; /**< Underlying 'status' object for this router.
|
|
|
|
* Flags are redundant. */
|
|
|
|
uint64_t flags; /**< Bit-field for all recognized flags; index into
|
2008-02-05 22:39:29 +01:00
|
|
|
* networkstatus_t.known_flags. */
|
2007-10-04 18:21:58 +02:00
|
|
|
char *version; /**< The version that the authority says this router is
|
|
|
|
* running. */
|
2007-06-03 05:05:10 +02:00
|
|
|
} vote_routerstatus_t;
|
2007-05-31 21:03:44 +02:00
|
|
|
|
2008-02-12 21:20:52 +01:00
|
|
|
/** Information about a single voter in a vote or a consensus. */
|
2007-06-05 00:29:00 +02:00
|
|
|
typedef struct networkstatus_voter_info_t {
|
2007-10-04 18:21:58 +02:00
|
|
|
char *nickname; /**< Nickname of this voter */
|
|
|
|
char identity_digest[DIGEST_LEN]; /**< Digest of this voter's identity key */
|
|
|
|
char *address; /**< Address of this voter, in string format. */
|
|
|
|
uint32_t addr; /**< Address of this voter, in IPv4, in host order. */
|
|
|
|
uint16_t dir_port; /**< Directory port of this voter */
|
|
|
|
uint16_t or_port; /**< OR port of this voter */
|
|
|
|
char *contact; /**< Contact information for this voter. */
|
|
|
|
char vote_digest[DIGEST_LEN]; /**< Digest of this voter's vote, as signed. */
|
2008-12-17 15:59:28 +01:00
|
|
|
/** Digest of this voter's "legacy" identity key, if any. In vote only; for
|
|
|
|
* consensuses, we treat legacy keys as additional signers. */
|
|
|
|
char legacy_id_digest[DIGEST_LEN];
|
2007-10-04 18:21:58 +02:00
|
|
|
|
2007-12-19 05:18:28 +01:00
|
|
|
/* Nothing from here on is signed. */
|
|
|
|
char signing_key_digest[DIGEST_LEN]; /**< Declared digest of signing key
|
|
|
|
* used by this voter. */
|
|
|
|
char *signature; /**< Signature from this voter. */
|
|
|
|
int signature_len; /**< Length of <b>signature</b> */
|
2008-04-22 17:20:46 +02:00
|
|
|
unsigned int bad_signature : 1; /**< Set to true if we've tried to verify
|
|
|
|
* the sig, and we know it's bad. */
|
|
|
|
unsigned int good_signature : 1; /**< Set to true if we've verified the sig
|
|
|
|
* as good. */
|
2007-06-05 00:29:00 +02:00
|
|
|
} networkstatus_voter_info_t;
|
|
|
|
|
2008-07-24 11:22:27 +02:00
|
|
|
/** Enumerates the possible seriousness values of a networkstatus document. */
|
|
|
|
typedef enum {
|
|
|
|
NS_TYPE_VOTE,
|
|
|
|
NS_TYPE_CONSENSUS,
|
|
|
|
NS_TYPE_OPINION,
|
|
|
|
} networkstatus_type_t;
|
|
|
|
|
2008-02-05 22:39:29 +01:00
|
|
|
/** A common structure to hold a v3 network status vote, or a v3 network
|
2007-10-04 18:21:58 +02:00
|
|
|
* status consensus. */
|
2008-02-05 22:39:29 +01:00
|
|
|
typedef struct networkstatus_t {
|
2008-07-24 11:22:27 +02:00
|
|
|
networkstatus_type_t type; /**< Vote, consensus, or opinion? */
|
2009-05-27 23:55:51 +02:00
|
|
|
time_t published; /**< Vote only: Time when vote was written. */
|
2007-10-04 18:21:58 +02:00
|
|
|
time_t valid_after; /**< Time after which this vote or consensus applies. */
|
|
|
|
time_t fresh_until; /**< Time before which this is the most recent vote or
|
|
|
|
* consensus. */
|
|
|
|
time_t valid_until; /**< Time after which this vote or consensus should not
|
|
|
|
* be used. */
|
|
|
|
|
2007-10-19 20:56:24 +02:00
|
|
|
/** Consensus only: what method was used to produce this consensus? */
|
|
|
|
int consensus_method;
|
|
|
|
/** Vote only: what methods is this voter willing to use? */
|
|
|
|
smartlist_t *supported_methods;
|
|
|
|
|
2007-10-04 18:21:58 +02:00
|
|
|
/** How long does this vote/consensus claim that authorities take to
|
|
|
|
* distribute their votes to one another? */
|
2007-06-03 05:05:10 +02:00
|
|
|
int vote_seconds;
|
2009-05-27 23:55:51 +02:00
|
|
|
/** How long does this vote/consensus claim that authorities take to
|
2007-10-04 18:21:58 +02:00
|
|
|
* distribute their consensus signatures to one another? */
|
2007-06-03 05:05:10 +02:00
|
|
|
int dist_seconds;
|
|
|
|
|
2007-10-04 18:21:58 +02:00
|
|
|
/** Comma-separated list of recommended client software, or NULL if this
|
|
|
|
* voter has no opinion. */
|
2007-05-31 21:03:44 +02:00
|
|
|
char *client_versions;
|
|
|
|
char *server_versions;
|
2007-10-04 18:21:58 +02:00
|
|
|
/** List of flags that this vote/consensus applies to routers. If a flag is
|
|
|
|
* not listed here, the voter has no opinion on what its value should be. */
|
2007-06-08 20:41:09 +02:00
|
|
|
smartlist_t *known_flags;
|
2007-06-03 05:05:10 +02:00
|
|
|
|
2009-09-15 04:15:57 +02:00
|
|
|
/** List of key=value strings for the parameters in this vote or
|
|
|
|
* consensus, sorted by key. */
|
|
|
|
smartlist_t *net_params;
|
|
|
|
|
2007-10-04 18:21:58 +02:00
|
|
|
/** List of networkstatus_voter_info_t. For a vote, only one element
|
|
|
|
* is included. For a consensus, one element is included for every voter
|
|
|
|
* whose vote contributed to the consensus. */
|
|
|
|
smartlist_t *voters;
|
2007-06-03 05:05:10 +02:00
|
|
|
|
2007-10-04 18:21:58 +02:00
|
|
|
struct authority_cert_t *cert; /**< Vote only: the voter's certificate. */
|
2007-06-04 21:19:01 +02:00
|
|
|
|
2007-10-04 18:21:58 +02:00
|
|
|
/** Digest of this document, as signed. */
|
2007-06-05 00:57:23 +02:00
|
|
|
char networkstatus_digest[DIGEST_LEN];
|
|
|
|
|
2007-10-04 18:21:58 +02:00
|
|
|
/** List of router statuses, sorted by identity digest. For a vote,
|
|
|
|
* the elements are vote_routerstatus_t; for a consensus, the elements
|
|
|
|
* are routerstatus_t. */
|
|
|
|
smartlist_t *routerstatus_list;
|
2007-10-16 01:15:24 +02:00
|
|
|
|
|
|
|
/** If present, a map from descriptor digest to elements of
|
|
|
|
* routerstatus_list. */
|
|
|
|
digestmap_t *desc_digest_map;
|
2008-02-05 22:39:29 +01:00
|
|
|
} networkstatus_t;
|
2007-05-31 21:03:44 +02:00
|
|
|
|
2007-10-04 18:21:58 +02:00
|
|
|
/** A set of signatures for a networkstatus consensus. All fields are as for
|
2008-02-05 22:39:29 +01:00
|
|
|
* networkstatus_t. */
|
2007-07-27 20:33:28 +02:00
|
|
|
typedef struct ns_detached_signatures_t {
|
|
|
|
time_t valid_after;
|
|
|
|
time_t fresh_until;
|
|
|
|
time_t valid_until;
|
|
|
|
char networkstatus_digest[DIGEST_LEN];
|
|
|
|
smartlist_t *signatures; /* list of networkstatus_voter_info_t */
|
|
|
|
} ns_detached_signatures_t;
|
|
|
|
|
2007-10-04 18:21:58 +02:00
|
|
|
/** Allowable types of desc_store_t. */
|
2007-08-31 17:08:37 +02:00
|
|
|
typedef enum store_type_t {
|
2007-10-04 18:21:58 +02:00
|
|
|
ROUTER_STORE = 0,
|
|
|
|
EXTRAINFO_STORE = 1
|
2007-08-31 17:08:37 +02:00
|
|
|
} store_type_t;
|
|
|
|
|
2007-10-04 18:21:58 +02:00
|
|
|
/** A 'store' is a set of descriptors saved on disk, with accompanying
|
|
|
|
* journal, mmaped as needed, rebuilt as needed. */
|
2007-08-31 17:08:37 +02:00
|
|
|
typedef struct desc_store_t {
|
2007-10-04 18:21:58 +02:00
|
|
|
/** Filename (within DataDir) for the store. We append .tmp to this
|
|
|
|
* filename for a temporary file when rebuilding the store, and .new to this
|
|
|
|
* filename for the journal. */
|
2007-08-31 17:08:37 +02:00
|
|
|
const char *fname_base;
|
2007-10-04 18:21:58 +02:00
|
|
|
/** Alternative (obsolete) value for fname_base: if the file named by
|
|
|
|
* fname_base isn't present, we read from here instead, but we never write
|
|
|
|
* here. */
|
2007-09-27 22:46:24 +02:00
|
|
|
const char *fname_alt_base;
|
2007-10-04 18:21:58 +02:00
|
|
|
/** Human-readable description of what this store contains. */
|
2007-08-31 17:08:37 +02:00
|
|
|
const char *description;
|
|
|
|
|
2007-10-04 18:21:58 +02:00
|
|
|
tor_mmap_t *mmap; /**< A mmap for the main file in the store. */
|
2007-08-31 17:08:37 +02:00
|
|
|
|
2007-10-04 18:21:58 +02:00
|
|
|
store_type_t type; /**< What's stored in this store? */
|
2007-08-31 17:08:37 +02:00
|
|
|
|
|
|
|
/** The size of the router log, in bytes. */
|
|
|
|
size_t journal_len;
|
|
|
|
/** The size of the router store, in bytes. */
|
|
|
|
size_t store_len;
|
|
|
|
/** Total bytes dropped since last rebuild: this is space currently
|
|
|
|
* used in the cache and the journal that could be freed by a rebuild. */
|
|
|
|
size_t bytes_dropped;
|
|
|
|
} desc_store_t;
|
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Contents of a directory of onion routers. */
|
2003-05-06 19:38:16 +02:00
|
|
|
typedef struct {
|
2005-10-27 02:34:39 +02:00
|
|
|
/** Map from server identity digest to a member of routers. */
|
2007-06-12 00:19:40 +02:00
|
|
|
struct digest_ri_map_t *identity_map;
|
2005-11-23 06:47:51 +01:00
|
|
|
/** Map from server descriptor digest to a signed_descriptor_t from
|
2005-11-05 21:15:27 +01:00
|
|
|
* routers or old_routers. */
|
2007-06-12 00:19:40 +02:00
|
|
|
struct digest_sd_map_t *desc_digest_map;
|
2007-05-29 19:31:13 +02:00
|
|
|
/** Map from extra-info digest to an extrainfo_t. Only exists for
|
2007-04-16 23:37:21 +02:00
|
|
|
* routers in routers or old_routers. */
|
2007-06-12 00:19:40 +02:00
|
|
|
struct digest_ei_map_t *extra_info_map;
|
2007-05-29 19:31:13 +02:00
|
|
|
/** Map from extra-info digests to a signed_descriptor_t for a router
|
|
|
|
* descriptor having that extra-info digest. Only exists for
|
|
|
|
* routers in routers or old_routers. */
|
2007-06-12 00:19:40 +02:00
|
|
|
struct digest_sd_map_t *desc_by_eid_map;
|
2005-10-27 02:34:39 +02:00
|
|
|
/** List of routerinfo_t for all currently live routers we know. */
|
|
|
|
smartlist_t *routers;
|
2005-11-05 21:15:27 +01:00
|
|
|
/** List of signed_descriptor_t for older router descriptors we're
|
|
|
|
* caching. */
|
2005-10-27 02:34:39 +02:00
|
|
|
smartlist_t *old_routers;
|
2007-10-04 18:21:58 +02:00
|
|
|
/** Store holding server descriptors. If present, any router whose
|
|
|
|
* cache_info.saved_location == SAVED_IN_CACHE is stored in this file
|
2006-10-07 18:25:28 +02:00
|
|
|
* starting at cache_info.saved_offset */
|
2007-08-31 17:08:37 +02:00
|
|
|
desc_store_t desc_store;
|
2007-10-04 18:21:58 +02:00
|
|
|
/** Store holding extra-info documents. */
|
2007-08-31 17:08:37 +02:00
|
|
|
desc_store_t extrainfo_store;
|
2003-12-05 10:51:49 +01:00
|
|
|
} routerlist_t;
|
2003-05-06 19:38:16 +02:00
|
|
|
|
2007-01-27 20:29:16 +01:00
|
|
|
/** Information on router used when extending a circuit. We don't need a
|
2005-06-29 23:46:55 +02:00
|
|
|
* full routerinfo_t to extend: we only need addr:port:keyid to build an OR
|
2007-01-27 20:29:16 +01:00
|
|
|
* connection, and onion_key to create the onionskin. Note that for onehop
|
|
|
|
* general-purpose tunnels, the onion_key is NULL. */
|
2005-06-29 23:46:55 +02:00
|
|
|
typedef struct extend_info_t {
|
2005-12-14 21:40:40 +01:00
|
|
|
char nickname[MAX_HEX_NICKNAME_LEN+1]; /**< This router's nickname for
|
|
|
|
* display. */
|
2005-07-14 10:43:19 +02:00
|
|
|
char identity_digest[DIGEST_LEN]; /**< Hash of this router's identity key. */
|
|
|
|
uint16_t port; /**< OR port. */
|
2008-08-05 22:08:19 +02:00
|
|
|
tor_addr_t addr; /**< IP address. */
|
2005-07-14 10:43:19 +02:00
|
|
|
crypto_pk_env_t *onion_key; /**< Current onionskin key. */
|
2005-06-29 23:46:55 +02:00
|
|
|
} extend_info_t;
|
|
|
|
|
2007-05-29 19:31:13 +02:00
|
|
|
/** Certificate for v3 directory protocol: binds long-term authority identity
|
|
|
|
* keys to medium-term authority signing keys. */
|
2007-05-02 23:37:55 +02:00
|
|
|
typedef struct authority_cert_t {
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Information relating to caching this cert on disk and looking it up. */
|
2007-05-02 23:37:55 +02:00
|
|
|
signed_descriptor_t cache_info;
|
2008-12-17 18:20:31 +01:00
|
|
|
/** This authority's long-term authority identity key. */
|
2007-05-02 23:37:55 +02:00
|
|
|
crypto_pk_env_t *identity_key;
|
2008-12-17 18:20:31 +01:00
|
|
|
/** This authority's medium-term signing key. */
|
2007-05-02 23:37:55 +02:00
|
|
|
crypto_pk_env_t *signing_key;
|
2008-12-17 18:20:31 +01:00
|
|
|
/** The digest of <b>signing_key</b> */
|
2007-07-26 22:49:04 +02:00
|
|
|
char signing_key_digest[DIGEST_LEN];
|
2008-12-17 18:20:31 +01:00
|
|
|
/** The listed expiration time of this certificate. */
|
2007-05-02 23:37:55 +02:00
|
|
|
time_t expires;
|
2008-12-17 18:20:31 +01:00
|
|
|
/** This authority's IPv4 address, in host order. */
|
2007-10-19 18:28:10 +02:00
|
|
|
uint32_t addr;
|
2008-12-17 18:20:31 +01:00
|
|
|
/** This authority's directory port. */
|
2007-10-19 18:28:10 +02:00
|
|
|
uint16_t dir_port;
|
2008-12-17 18:20:31 +01:00
|
|
|
/** True iff this certificate was cross-certified by signing the identity
|
|
|
|
* key with the signing key. */
|
2008-12-12 19:31:39 +01:00
|
|
|
uint8_t is_cross_certified;
|
2007-05-02 23:37:55 +02:00
|
|
|
} authority_cert_t;
|
|
|
|
|
2007-05-29 19:31:13 +02:00
|
|
|
/** Bitfield enum type listing types of directory authority/directory
|
|
|
|
* server. */
|
2007-05-08 11:09:26 +02:00
|
|
|
typedef enum {
|
2007-05-09 06:15:46 +02:00
|
|
|
NO_AUTHORITY = 0,
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Serves/signs v1 directory information: Big lists of routers, and short
|
|
|
|
* routerstatus documents. */
|
2007-05-09 06:15:46 +02:00
|
|
|
V1_AUTHORITY = 1 << 0,
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Serves/signs v2 directory information: i.e. v2 networkstatus documents */
|
2007-05-09 06:15:46 +02:00
|
|
|
V2_AUTHORITY = 1 << 1,
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Serves/signs v3 directory information: votes, consensuses, certs */
|
2007-05-22 19:58:25 +02:00
|
|
|
V3_AUTHORITY = 1 << 2,
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Serves hidden service descriptors. */
|
2007-05-22 19:58:25 +02:00
|
|
|
HIDSERV_AUTHORITY = 1 << 3,
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Serves bridge descriptors. */
|
2007-05-22 19:58:25 +02:00
|
|
|
BRIDGE_AUTHORITY = 1 << 4,
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Serves extrainfo documents. (XXX Not precisely an authority type)*/
|
|
|
|
EXTRAINFO_CACHE = 1 << 5,
|
2007-05-08 11:09:26 +02:00
|
|
|
} authority_type_t;
|
|
|
|
|
2005-03-23 07:21:48 +01:00
|
|
|
#define CRYPT_PATH_MAGIC 0x70127012u
|
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Holds accounting information for a single step in the layered encryption
|
|
|
|
* performed by a circuit. Used only at the client edge of a circuit. */
|
2005-07-22 23:12:10 +02:00
|
|
|
typedef struct crypt_path_t {
|
2005-03-23 07:21:48 +01:00
|
|
|
uint32_t magic;
|
Integrated onion proxy into or/
The 'or' process can now be told (by the global_role variable) what
roles this server should play -- connect to all ORs, listen for ORs,
listen for OPs, listen for APs, or any combination.
* everything in /src/op/ is now obsolete.
* connection_ap.c now handles all interactions with application proxies
* "port" is now or_port, op_port, ap_port. But routers are still always
referenced (say, in conn_get_by_addr_port()) by addr / or_port. We
should make routers.c actually read these new ports (currently I've
kludged it so op_port = or_port+10, ap_port=or_port+20)
* circuits currently know if they're at the beginning of the path because
circ->cpath is set. They use this instead for crypts (both ways),
if it's set.
* I still obey the "send a 0 back to the AP when you're ready" protocol,
but I think we should phase it out. I can simply not read from the AP
socket until I'm ready.
I need to do a lot of cleanup work here, but the code appears to work, so
now's a good time for a checkin.
svn:r22
2002-07-02 11:36:58 +02:00
|
|
|
|
2002-08-22 09:30:03 +02:00
|
|
|
/* crypto environments */
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Encryption key and counter for cells heading towards the OR at this
|
|
|
|
* step. */
|
2002-08-22 09:30:03 +02:00
|
|
|
crypto_cipher_env_t *f_crypto;
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Encryption key and counter for cells heading back from the OR at this
|
|
|
|
* step. */
|
2002-08-22 09:30:03 +02:00
|
|
|
crypto_cipher_env_t *b_crypto;
|
2003-05-02 00:55:51 +02:00
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Digest state for cells heading towards the OR at this step. */
|
2003-12-16 09:21:58 +01:00
|
|
|
crypto_digest_env_t *f_digest; /* for integrity checking */
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Digest state for cells heading away from the OR at this step. */
|
2003-12-16 09:21:58 +01:00
|
|
|
crypto_digest_env_t *b_digest;
|
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Current state of Diffie-Hellman key negotiation with the OR at this
|
|
|
|
* step. */
|
2005-05-03 00:35:18 +02:00
|
|
|
crypto_dh_env_t *dh_handshake_state;
|
2005-12-08 18:38:32 +01:00
|
|
|
/** Current state of 'fast' (non-PK) key negotiation with the OR at this
|
|
|
|
* step. Used to save CPU when TLS is already providing all the
|
|
|
|
* authentication, secrecy, and integrity we need, and we're already
|
|
|
|
* distinguishable from an OR.
|
|
|
|
*/
|
2005-05-03 00:35:18 +02:00
|
|
|
char fast_handshake_state[DIGEST_LEN];
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Negotiated key material shared with the OR at this step. */
|
2004-04-03 04:40:30 +02:00
|
|
|
char handshake_digest[DIGEST_LEN];/* KH in tor-spec.txt */
|
2003-05-06 01:24:46 +02:00
|
|
|
|
2005-06-29 23:46:55 +02:00
|
|
|
/** Information to extend to the OR at this step. */
|
|
|
|
extend_info_t *extend_info;
|
2003-05-06 01:24:46 +02:00
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Is the circuit built to this step? Must be one of:
|
|
|
|
* - CPATH_STATE_CLOSED (The circuit has not been extended to this step)
|
|
|
|
* - CPATH_STATE_AWAITING_KEYS (We have sent an EXTEND/CREATE to this step
|
|
|
|
* and not received an EXTENDED/CREATED)
|
|
|
|
* - CPATH_STATE_OPEN (The circuit has been extended to this step) */
|
2003-09-05 08:04:03 +02:00
|
|
|
uint8_t state;
|
2003-05-02 00:55:51 +02:00
|
|
|
#define CPATH_STATE_CLOSED 0
|
2003-05-06 01:24:46 +02:00
|
|
|
#define CPATH_STATE_AWAITING_KEYS 1
|
2003-05-02 00:55:51 +02:00
|
|
|
#define CPATH_STATE_OPEN 2
|
2004-05-10 08:52:01 +02:00
|
|
|
struct crypt_path_t *next; /**< Link to next crypt_path_t in the circuit.
|
|
|
|
* (The list is circular, so the last node
|
|
|
|
* links to the first.) */
|
|
|
|
struct crypt_path_t *prev; /**< Link to previous crypt_path_t in the
|
2004-05-10 12:27:54 +02:00
|
|
|
* circuit. */
|
2004-05-10 08:52:01 +02:00
|
|
|
|
2009-09-15 12:33:33 +02:00
|
|
|
int package_window; /**< How many cells are we allowed to originate ending
|
2004-05-10 08:52:01 +02:00
|
|
|
* at this step? */
|
2009-09-15 12:33:33 +02:00
|
|
|
int deliver_window; /**< How many cells are we willing to deliver originating
|
2004-05-10 08:52:01 +02:00
|
|
|
* at this step? */
|
2005-07-22 23:12:10 +02:00
|
|
|
} crypt_path_t;
|
2003-05-02 00:55:51 +02:00
|
|
|
|
2004-05-13 09:24:49 +02:00
|
|
|
#define CPATH_KEY_MATERIAL_LEN (20*2+16*2)
|
|
|
|
|
2004-04-05 22:53:50 +02:00
|
|
|
#define DH_KEY_LEN DH_BYTES
|
2004-04-25 00:17:50 +02:00
|
|
|
#define ONIONSKIN_CHALLENGE_LEN (PKCS1_OAEP_PADDING_OVERHEAD+\
|
|
|
|
CIPHER_KEY_LEN+\
|
|
|
|
DH_KEY_LEN)
|
|
|
|
#define ONIONSKIN_REPLY_LEN (DH_KEY_LEN+DIGEST_LEN)
|
2003-05-06 07:54:42 +02:00
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
/** Information used to build a circuit. */
|
2003-11-16 18:00:02 +01:00
|
|
|
typedef struct {
|
2004-05-10 12:31:48 +02:00
|
|
|
/** Intended length of the final circuit. */
|
2003-11-16 18:00:02 +01:00
|
|
|
int desired_path_len;
|
2005-06-29 23:46:55 +02:00
|
|
|
/** How to extend to the planned exit node. */
|
|
|
|
extend_info_t *chosen_exit;
|
2005-01-12 05:58:23 +01:00
|
|
|
/** Whether every node in the circ must have adequate uptime. */
|
|
|
|
int need_uptime;
|
|
|
|
/** Whether every node in the circ must have adequate capacity. */
|
|
|
|
int need_capacity;
|
Introduce a notion of 'internal' circs, which are chosen without regard
to the exit policy of the last hop. Intro and rendezvous circs must
be internal circs, to avoid leaking information. Resolve and connect
streams can use internal circs if they want.
New circuit pooling algorithm: make sure to have enough circs around
to satisfy any predicted ports, and also make sure to have 2 internal
circs around if we've required internal circs lately (with high uptime
if we've seen that lately).
Split NewCircuitPeriod config option into NewCircuitPeriod (30 secs),
which describes how often we retry making new circuits if current ones
are dirty, and MaxCircuitDirtiness (10 mins), which describes how long
we're willing to make use of an already-dirty circuit.
Once rendezvous circuits are established, keep using the same circuit as
long as you attach a new stream to it at least every 10 minutes. (So web
browsing doesn't require you to build new rend circs every 30 seconds.)
Cannibalize GENERAL circs to be C_REND, C_INTRO, S_INTRO, and S_REND
circ as necessary, if there are any completed ones lying around when
we try to launch one.
Re-instate the ifdef's to use version-0 style introduce cells, since
there was yet another bug in handling version-1 style. We'll try switching
over again after 0.0.9 is obsolete.
Bugfix: when choosing an exit node for a new non-internal circ, don't take
into account whether it'll be useful for any pending x.onion addresses --
it won't.
Bugfix: we weren't actually publishing the hidden service descriptor when
it became dirty. So we only published it every 20 minutes or so, which
means when you first start your Tor, the hidden service will seem broken.
svn:r3360
2005-01-17 19:13:09 +01:00
|
|
|
/** Whether the last hop was picked with exiting in mind. */
|
|
|
|
int is_internal;
|
2006-12-13 23:42:52 +01:00
|
|
|
/** Did we pick this as a one-hop tunnel (not safe for other conns)?
|
|
|
|
* These are for encrypted connections that exit to this router, not
|
|
|
|
* for arbitrary exits from the circuit. */
|
2006-12-13 03:49:45 +01:00
|
|
|
int onehop_tunnel;
|
2004-05-10 12:31:48 +02:00
|
|
|
/** The crypt_path_t to append after rendezvous: used for rendezvous. */
|
2005-07-22 23:12:10 +02:00
|
|
|
crypt_path_t *pending_final_cpath;
|
2004-05-10 08:52:01 +02:00
|
|
|
/** How many times has building a circuit for this task failed? */
|
2004-04-14 23:40:50 +02:00
|
|
|
int failure_count;
|
2005-03-19 05:38:59 +01:00
|
|
|
/** At what time should we give up on this task? */
|
|
|
|
time_t expiry_time;
|
2003-11-16 18:00:02 +01:00
|
|
|
} cpath_build_state_t;
|
2003-11-14 21:45:47 +01:00
|
|
|
|
2006-07-23 09:37:35 +02:00
|
|
|
#define ORIGIN_CIRCUIT_MAGIC 0x35315243u
|
|
|
|
#define OR_CIRCUIT_MAGIC 0x98ABC04Fu
|
|
|
|
|
2005-06-11 08:07:22 +02:00
|
|
|
/**
|
|
|
|
* A circuit is a path over the onion routing
|
|
|
|
* network. Applications can connect to one end of the circuit, and can
|
|
|
|
* create exit connections at the other end of the circuit. AP and exit
|
|
|
|
* connections have only one circuit associated with them (and thus these
|
|
|
|
* connection types are closed when the circuit is closed), whereas
|
|
|
|
* OR connections multiplex many circuits at once, and stay standing even
|
|
|
|
* when there are no circuits running over them.
|
|
|
|
*
|
2006-12-24 07:32:24 +01:00
|
|
|
* A circuit_t structure can fill one of two roles. First, a or_circuit_t
|
2006-07-27 07:03:57 +02:00
|
|
|
* links two connections together: either an edge connection and an OR
|
|
|
|
* connection, or two OR connections. (When joined to an OR connection, a
|
|
|
|
* circuit_t affects only cells sent to a particular circID on that
|
|
|
|
* connection. When joined to an edge connection, a circuit_t affects all
|
|
|
|
* data.)
|
|
|
|
|
|
|
|
* Second, an origin_circuit_t holds the cipher keys and state for sending data
|
2005-06-11 08:07:22 +02:00
|
|
|
* along a given circuit. At the OP, it has a sequence of ciphers, each
|
|
|
|
* of which is shared with a single OR along the circuit. Separate
|
|
|
|
* ciphers are used for data going "forward" (away from the OP) and
|
|
|
|
* "backward" (towards the OP). At the OR, a circuit has only two stream
|
|
|
|
* ciphers: one for data going forward, and one for data going backward.
|
|
|
|
*/
|
2006-07-23 09:37:35 +02:00
|
|
|
typedef struct circuit_t {
|
|
|
|
uint32_t magic; /**< For memory and type debugging: must equal
|
|
|
|
* ORIGIN_CIRCUIT_MAGIC or OR_CIRCUIT_MAGIC. */
|
2004-02-25 08:31:46 +01:00
|
|
|
|
2007-03-26 16:08:35 +02:00
|
|
|
/** Queue of cells waiting to be transmitted on n_conn. */
|
2007-03-26 16:07:59 +02:00
|
|
|
cell_queue_t n_conn_cells;
|
2004-05-10 09:37:10 +02:00
|
|
|
/** The OR connection that is next in this circuit. */
|
2006-07-26 21:07:26 +02:00
|
|
|
or_connection_t *n_conn;
|
2006-07-23 09:37:35 +02:00
|
|
|
/** The circuit_id used in the next (forward) hop of this circuit. */
|
2008-07-23 17:58:30 +02:00
|
|
|
circid_t n_circ_id;
|
2008-07-30 15:04:32 +02:00
|
|
|
|
2009-05-27 23:55:51 +02:00
|
|
|
/** The hop to which we want to extend this circuit. Should be NULL if
|
2008-08-03 19:45:24 +02:00
|
|
|
* the circuit has attached to a connection. */
|
2008-07-30 15:04:32 +02:00
|
|
|
extend_info_t *n_hop;
|
2007-03-26 16:08:18 +02:00
|
|
|
|
2007-03-26 16:08:35 +02:00
|
|
|
/** True iff we are waiting for n_conn_cells to become less full before
|
|
|
|
* allowing p_streams to add any more cells. (Origin circuit only.) */
|
2007-03-26 16:08:18 +02:00
|
|
|
unsigned int streams_blocked_on_n_conn : 1;
|
2007-03-26 16:08:35 +02:00
|
|
|
/** True iff we are waiting for p_conn_cells to become less full before
|
|
|
|
* allowing n_streams to add any more cells. (OR circuit only.) */
|
2007-03-26 16:08:18 +02:00
|
|
|
unsigned int streams_blocked_on_p_conn : 1;
|
|
|
|
|
2007-05-17 00:15:57 +02:00
|
|
|
uint8_t state; /**< Current status of this circuit. */
|
|
|
|
uint8_t purpose; /**< Why are we creating this circuit? */
|
|
|
|
|
2004-05-10 09:37:10 +02:00
|
|
|
/** How many relay data cells can we package (read from edge streams)
|
|
|
|
* on this circuit before we receive a circuit-level sendme cell asking
|
|
|
|
* for more? */
|
2003-05-20 08:41:23 +02:00
|
|
|
int package_window;
|
2004-05-10 09:37:10 +02:00
|
|
|
/** How many relay data cells will we deliver (write to edge streams)
|
|
|
|
* on this circuit? When deliver_window gets low, we send some
|
|
|
|
* circuit-level sendme cells to indicate that we're willing to accept
|
|
|
|
* more. */
|
2003-05-20 08:41:23 +02:00
|
|
|
int deliver_window;
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2008-02-06 00:20:49 +01:00
|
|
|
/** For storage while n_conn is pending
|
2005-10-29 21:13:48 +02:00
|
|
|
* (state CIRCUIT_STATE_OR_WAIT). When defined, it is always
|
|
|
|
* length ONIONSKIN_CHALLENGE_LEN. */
|
2008-02-06 00:20:49 +01:00
|
|
|
char *n_conn_onionskin;
|
2004-07-02 11:29:01 +02:00
|
|
|
|
2004-05-10 08:52:01 +02:00
|
|
|
time_t timestamp_created; /**< When was this circuit created? */
|
|
|
|
time_t timestamp_dirty; /**< When the circuit was first used, or 0 if the
|
|
|
|
* circuit is clean. */
|
2009-08-27 10:46:06 +02:00
|
|
|
struct timeval highres_created; /**< When exactly was the circuit created? */
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2005-12-14 22:03:51 +01:00
|
|
|
uint16_t marked_for_close; /**< Should we close this circuit at the end of
|
|
|
|
* the main loop? (If true, holds the line number
|
|
|
|
* where this circuit was marked.) */
|
|
|
|
const char *marked_for_close_file; /**< For debugging: in which file was this
|
|
|
|
* circuit marked for close? */
|
|
|
|
|
2007-03-26 16:08:35 +02:00
|
|
|
/** Next circuit in the doubly-linked ring of circuits waiting to add
|
2007-04-10 18:24:50 +02:00
|
|
|
* cells to n_conn. NULL if we have no cells pending, or if we're not
|
|
|
|
* linked to an OR connection. */
|
2007-03-26 16:08:35 +02:00
|
|
|
struct circuit_t *next_active_on_n_conn;
|
|
|
|
/** Previous circuit in the doubly-linked ring of circuits waiting to add
|
2007-04-10 18:24:50 +02:00
|
|
|
* cells to n_conn. NULL if we have no cells pending, or if we're not
|
|
|
|
* linked to an OR connection. */
|
2007-03-26 16:08:35 +02:00
|
|
|
struct circuit_t *prev_active_on_n_conn;
|
|
|
|
struct circuit_t *next; /**< Next circuit in linked list of all circuits. */
|
2009-08-14 14:45:53 +02:00
|
|
|
|
2009-07-12 16:33:31 +02:00
|
|
|
/** Unique ID for measuring tunneled network status requests. */
|
2009-07-14 22:24:50 +02:00
|
|
|
uint64_t dirreq_id;
|
2006-07-23 09:37:35 +02:00
|
|
|
} circuit_t;
|
|
|
|
|
2008-07-23 17:58:38 +02:00
|
|
|
/** Largest number of relay_early cells that we can send on a given
|
|
|
|
* circuit. */
|
|
|
|
#define MAX_RELAY_EARLY_CELLS_PER_CIRCUIT 8
|
|
|
|
|
2006-07-27 07:03:57 +02:00
|
|
|
/** An origin_circuit_t holds data necessary to build and use a circuit.
|
|
|
|
*/
|
2006-07-23 09:37:35 +02:00
|
|
|
typedef struct origin_circuit_t {
|
|
|
|
circuit_t _base;
|
|
|
|
|
2006-07-30 06:54:13 +02:00
|
|
|
/** Linked list of AP streams (or EXIT streams if hidden service)
|
|
|
|
* associated with this circuit. */
|
2006-07-26 21:07:26 +02:00
|
|
|
edge_connection_t *p_streams;
|
2006-07-23 09:37:35 +02:00
|
|
|
/** Build state for this circuit. It includes the intended path
|
|
|
|
* length, the chosen exit router, rendezvous information, etc.
|
|
|
|
*/
|
|
|
|
cpath_build_state_t *build_state;
|
|
|
|
/** The doubly-linked list of crypt_path_t entries, one per hop,
|
|
|
|
* for this circuit. This includes ciphers for each hop,
|
|
|
|
* integrity-checking digests for each hop, and package/delivery
|
|
|
|
* windows for each hop.
|
|
|
|
*/
|
|
|
|
crypt_path_t *cpath;
|
2003-08-21 01:05:22 +02:00
|
|
|
|
2008-09-24 16:44:29 +02:00
|
|
|
/** Holds all rendezvous data on either client or service side. */
|
|
|
|
rend_data_t *rend_data;
|
2007-10-31 21:48:08 +01:00
|
|
|
|
2008-07-23 17:58:38 +02:00
|
|
|
/** How many more relay_early cells can we send on this circuit, according
|
|
|
|
* to the specification? */
|
|
|
|
unsigned int remaining_relay_early_cells : 4;
|
2007-10-31 21:48:06 +01:00
|
|
|
|
2008-12-30 12:43:50 +01:00
|
|
|
/** What commands were sent over this circuit that decremented the
|
|
|
|
* RELAY_EARLY counter? This is for debugging task 878. */
|
|
|
|
uint8_t relay_early_commands[MAX_RELAY_EARLY_CELLS_PER_CIRCUIT];
|
|
|
|
|
|
|
|
/** How many RELAY_EARLY cells have been sent over this circuit? This is
|
|
|
|
* for debugging task 878, too. */
|
|
|
|
int relay_early_cells_sent;
|
|
|
|
|
2006-07-26 21:07:23 +02:00
|
|
|
/** The next stream_id that will be tried when we're attempting to
|
|
|
|
* construct a new AP stream originating at this circuit. */
|
2008-07-23 17:58:30 +02:00
|
|
|
streamid_t next_stream_id;
|
2006-07-26 21:07:23 +02:00
|
|
|
|
2008-07-23 17:58:38 +02:00
|
|
|
/* The intro key replaces the hidden service's public key if purpose is
|
|
|
|
* S_ESTABLISH_INTRO or S_INTRO, provided that no unversioned rendezvous
|
|
|
|
* descriptor is used. */
|
|
|
|
crypto_pk_env_t *intro_key;
|
|
|
|
|
2006-07-28 17:11:11 +02:00
|
|
|
/** Quasi-global identifier for this circuit; used for control.c */
|
|
|
|
/* XXXX NM This can get re-used after 2**32 circuits. */
|
|
|
|
uint32_t global_identifier;
|
|
|
|
|
2006-07-23 09:37:35 +02:00
|
|
|
} origin_circuit_t;
|
|
|
|
|
2006-07-27 07:03:57 +02:00
|
|
|
/** An or_circuit_t holds information needed to implement a circuit at an
|
|
|
|
* OR. */
|
2006-07-23 09:37:35 +02:00
|
|
|
typedef struct or_circuit_t {
|
|
|
|
circuit_t _base;
|
|
|
|
|
2007-03-26 16:08:35 +02:00
|
|
|
/** Next circuit in the doubly-linked ring of circuits waiting to add
|
2007-04-10 18:24:50 +02:00
|
|
|
* cells to p_conn. NULL if we have no cells pending, or if we're not
|
|
|
|
* linked to an OR connection. */
|
2007-03-26 16:08:35 +02:00
|
|
|
struct circuit_t *next_active_on_p_conn;
|
|
|
|
/** Previous circuit in the doubly-linked ring of circuits waiting to add
|
2007-04-10 18:24:50 +02:00
|
|
|
* cells to p_conn. NULL if we have no cells pending, or if we're not
|
|
|
|
* linked to an OR connection. */
|
2007-03-26 16:08:35 +02:00
|
|
|
struct circuit_t *prev_active_on_p_conn;
|
2007-03-26 16:07:59 +02:00
|
|
|
|
2006-07-23 09:37:35 +02:00
|
|
|
/** The circuit_id used in the previous (backward) hop of this circuit. */
|
|
|
|
circid_t p_circ_id;
|
2007-03-26 16:08:35 +02:00
|
|
|
/** Queue of cells waiting to be transmitted on p_conn. */
|
2007-03-26 16:07:59 +02:00
|
|
|
cell_queue_t p_conn_cells;
|
2006-07-23 09:37:35 +02:00
|
|
|
/** The OR connection that is previous in this circuit. */
|
2006-07-26 21:07:26 +02:00
|
|
|
or_connection_t *p_conn;
|
2006-07-23 09:37:35 +02:00
|
|
|
/** Linked list of Exit streams associated with this circuit. */
|
2006-07-26 21:07:26 +02:00
|
|
|
edge_connection_t *n_streams;
|
2006-07-23 09:37:35 +02:00
|
|
|
/** Linked list of Exit streams associated with this circuit that are
|
|
|
|
* still being resolved. */
|
2006-07-26 21:07:26 +02:00
|
|
|
edge_connection_t *resolving_streams;
|
2008-12-17 18:20:31 +01:00
|
|
|
/** The cipher used by intermediate hops for cells heading toward the
|
2006-07-23 09:37:35 +02:00
|
|
|
* OP. */
|
|
|
|
crypto_cipher_env_t *p_crypto;
|
|
|
|
/** The cipher used by intermediate hops for cells heading away from
|
|
|
|
* the OP. */
|
|
|
|
crypto_cipher_env_t *n_crypto;
|
|
|
|
|
|
|
|
/** The integrity-checking digest used by intermediate hops, for
|
|
|
|
* cells packaged here and heading towards the OP.
|
|
|
|
*/
|
|
|
|
crypto_digest_env_t *p_digest;
|
|
|
|
/** The integrity-checking digest used by intermediate hops, for
|
|
|
|
* cells packaged at the OP and arriving here.
|
|
|
|
*/
|
|
|
|
crypto_digest_env_t *n_digest;
|
|
|
|
|
|
|
|
/** Points to spliced circuit if purpose is REND_ESTABLISHED, and circuit
|
|
|
|
* is not marked for close. */
|
|
|
|
struct or_circuit_t *rend_splice;
|
|
|
|
|
2006-07-26 21:05:41 +02:00
|
|
|
#if REND_COOKIE_LEN >= DIGEST_LEN
|
|
|
|
#define REND_TOKEN_LEN REND_COOKIE_LEN
|
|
|
|
#else
|
|
|
|
#define REND_TOKEN_LEN DIGEST_LEN
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/** A hash of location-hidden service's PK if purpose is INTRO_POINT, or a
|
2006-07-27 07:03:57 +02:00
|
|
|
* rendezvous cookie if purpose is REND_POINT_WAITING. Filled with zeroes
|
|
|
|
* otherwise.
|
2006-10-03 00:13:42 +02:00
|
|
|
* ???? move to a subtype or adjunct structure? Wastes 20 bytes. -NM
|
2006-07-26 21:05:41 +02:00
|
|
|
*/
|
|
|
|
char rend_token[REND_TOKEN_LEN];
|
|
|
|
|
2006-10-01 22:50:11 +02:00
|
|
|
/* ???? move to a subtype or adjunct structure? Wastes 20 bytes -NM */
|
2006-07-28 17:11:28 +02:00
|
|
|
char handshake_digest[DIGEST_LEN]; /**< Stores KH for the handshake. */
|
2006-10-01 22:50:11 +02:00
|
|
|
|
2008-07-23 17:58:38 +02:00
|
|
|
/** How many more relay_early cells can we send on this circuit, according
|
|
|
|
* to the specification? */
|
|
|
|
unsigned int remaining_relay_early_cells : 4;
|
|
|
|
|
2006-10-01 22:50:11 +02:00
|
|
|
/** True iff this circuit was made with a CREATE_FAST cell. */
|
|
|
|
unsigned int is_first_hop : 1;
|
2009-07-05 19:53:25 +02:00
|
|
|
|
|
|
|
/** Number of cells that were removed from circuit queue; reset every
|
|
|
|
* time when writing buffer stats to disk. */
|
|
|
|
uint32_t processed_cells;
|
|
|
|
|
|
|
|
/** Total time in milliseconds that cells spent in both app-ward and
|
|
|
|
* exit-ward queues of this circuit; reset every time when writing
|
|
|
|
* buffer stats to disk. */
|
|
|
|
uint64_t total_cell_waiting_time;
|
2006-07-23 09:37:35 +02:00
|
|
|
} or_circuit_t;
|
|
|
|
|
2006-07-27 07:03:57 +02:00
|
|
|
/** Convert a circuit subtype to a circuit_t.*/
|
2006-07-23 09:37:35 +02:00
|
|
|
#define TO_CIRCUIT(x) (&((x)->_base))
|
2006-07-27 07:03:57 +02:00
|
|
|
|
|
|
|
/** Convert a circuit_t* to a pointer to the enclosing or_circuit_t. Asserts
|
|
|
|
* if the cast is impossible. */
|
2006-09-08 18:12:15 +02:00
|
|
|
static or_circuit_t *TO_OR_CIRCUIT(circuit_t *);
|
2006-07-27 07:03:57 +02:00
|
|
|
/** Convert a circuit_t* to a pointer to the enclosing origin_circuit_t.
|
|
|
|
* Asserts if the cast is impossible. */
|
2006-09-08 18:12:15 +02:00
|
|
|
static origin_circuit_t *TO_ORIGIN_CIRCUIT(circuit_t *);
|
2006-07-27 07:03:57 +02:00
|
|
|
|
2006-09-08 18:12:15 +02:00
|
|
|
static INLINE or_circuit_t *TO_OR_CIRCUIT(circuit_t *x)
|
2006-07-23 09:37:35 +02:00
|
|
|
{
|
|
|
|
tor_assert(x->magic == OR_CIRCUIT_MAGIC);
|
2006-08-05 19:52:51 +02:00
|
|
|
return DOWNCAST(or_circuit_t, x);
|
2006-07-23 09:37:35 +02:00
|
|
|
}
|
2006-09-08 18:12:15 +02:00
|
|
|
static INLINE origin_circuit_t *TO_ORIGIN_CIRCUIT(circuit_t *x)
|
2006-07-23 09:37:35 +02:00
|
|
|
{
|
|
|
|
tor_assert(x->magic == ORIGIN_CIRCUIT_MAGIC);
|
2006-08-05 19:52:51 +02:00
|
|
|
return DOWNCAST(origin_circuit_t, x);
|
2006-07-23 09:37:35 +02:00
|
|
|
}
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2008-12-17 18:20:26 +01:00
|
|
|
/** Bitfield type: things that we're willing to use invalid routers for. */
|
|
|
|
typedef enum invalid_router_usage_t {
|
|
|
|
ALLOW_INVALID_ENTRY =1,
|
|
|
|
ALLOW_INVALID_EXIT =2,
|
|
|
|
ALLOW_INVALID_MIDDLE =4,
|
|
|
|
ALLOW_INVALID_RENDEZVOUS =8,
|
|
|
|
ALLOW_INVALID_INTRODUCTION=16,
|
|
|
|
} invalid_router_usage_t;
|
2004-08-17 07:13:58 +02:00
|
|
|
|
2007-07-16 18:23:34 +02:00
|
|
|
/* limits for TCP send and recv buffer size used for constrained sockets */
|
2007-07-16 18:23:36 +02:00
|
|
|
#define MIN_CONSTRAINED_TCP_BUFFER 2048
|
|
|
|
#define MAX_CONSTRAINED_TCP_BUFFER 262144 /* 256k */
|
2007-07-16 18:23:34 +02:00
|
|
|
|
2005-10-06 06:33:40 +02:00
|
|
|
/** A linked list of lines in a config file. */
|
2005-07-22 23:12:10 +02:00
|
|
|
typedef struct config_line_t {
|
|
|
|
char *key;
|
|
|
|
char *value;
|
|
|
|
struct config_line_t *next;
|
|
|
|
} config_line_t;
|
|
|
|
|
2008-09-25 22:21:35 +02:00
|
|
|
typedef struct routerset_t routerset_t;
|
|
|
|
|
2005-11-18 03:47:09 +01:00
|
|
|
/** Configuration options for a Tor process. */
|
2002-12-03 23:18:23 +01:00
|
|
|
typedef struct {
|
2005-07-22 22:37:42 +02:00
|
|
|
uint32_t _magic;
|
|
|
|
|
2004-10-30 21:18:37 +02:00
|
|
|
/** What should the tor process actually do? */
|
|
|
|
enum {
|
2004-11-03 20:49:03 +01:00
|
|
|
CMD_RUN_TOR=0, CMD_LIST_FINGERPRINT, CMD_HASH_PASSWORD,
|
2005-08-27 01:22:27 +02:00
|
|
|
CMD_VERIFY_CONFIG, CMD_RUN_UNITTESTS
|
2004-10-30 21:18:37 +02:00
|
|
|
} command;
|
2004-11-03 20:49:03 +01:00
|
|
|
const char *command_arg; /**< Argument for command-line option. */
|
|
|
|
|
2005-07-22 23:12:10 +02:00
|
|
|
config_line_t *Logs; /**< New-style list of configuration lines
|
2005-11-18 03:47:09 +01:00
|
|
|
* for logs */
|
2004-05-19 22:07:08 +02:00
|
|
|
|
2004-05-10 12:27:54 +02:00
|
|
|
char *DebugLogFile; /**< Where to send verbose log messages. */
|
|
|
|
char *DataDirectory; /**< OR only: where to store long-term data. */
|
|
|
|
char *Nickname; /**< OR only: nickname of this onion router. */
|
|
|
|
char *Address; /**< OR only: configured address for this onion router. */
|
|
|
|
char *PidFile; /**< Where to store PID of Tor process. */
|
2004-05-10 08:52:01 +02:00
|
|
|
|
2008-09-25 22:21:35 +02:00
|
|
|
routerset_t *ExitNodes; /**< Structure containing nicknames, digests,
|
|
|
|
* country codes and IP address patterns of ORs to
|
|
|
|
* consider as exits. */
|
|
|
|
routerset_t *EntryNodes;/**< Structure containing nicknames, digests,
|
|
|
|
* country codes and IP address patterns of ORs to
|
|
|
|
* consider as entry points. */
|
2004-08-15 22:14:44 +02:00
|
|
|
int StrictExitNodes; /**< Boolean: When none of our ExitNodes are up, do we
|
|
|
|
* stop building circuits? */
|
|
|
|
int StrictEntryNodes; /**< Boolean: When none of our EntryNodes are up, do we
|
|
|
|
* stop building circuits? */
|
2008-09-25 22:21:35 +02:00
|
|
|
routerset_t *ExcludeNodes;/**< Structure containing nicknames, digests,
|
|
|
|
* country codes and IP address patterns of ORs
|
|
|
|
* not to use in circuits. */
|
|
|
|
routerset_t *ExcludeExitNodes;/**< Structure containing nicknames, digests,
|
|
|
|
* country codes and IP address patterns of
|
|
|
|
* ORs not to consider as exits. */
|
2008-07-18 20:36:32 +02:00
|
|
|
|
|
|
|
/** Union of ExcludeNodes and ExcludeExitNodes */
|
|
|
|
struct routerset_t *_ExcludeExitNodesUnion;
|
2004-05-10 08:52:01 +02:00
|
|
|
|
2007-05-08 11:09:26 +02:00
|
|
|
/** List of "entry", "middle", "exit", "introduction", "rendezvous". */
|
|
|
|
smartlist_t *AllowInvalidNodes;
|
2008-12-17 18:20:26 +01:00
|
|
|
/** Bitmask; derived from AllowInvalidNodes. */
|
|
|
|
invalid_router_usage_t _AllowInvalid;
|
2005-07-22 23:12:10 +02:00
|
|
|
config_line_t *ExitPolicy; /**< Lists of exit policy components. */
|
2006-02-01 04:53:52 +01:00
|
|
|
int ExitPolicyRejectPrivate; /**< Should we not exit to local addresses? */
|
2005-07-22 23:12:10 +02:00
|
|
|
config_line_t *SocksPolicy; /**< Lists of socks policy components */
|
|
|
|
config_line_t *DirPolicy; /**< Lists of dir policy components */
|
2004-08-16 13:43:18 +02:00
|
|
|
/** Addresses to bind for listening for SOCKS connections. */
|
2005-10-17 05:17:29 +02:00
|
|
|
config_line_t *SocksListenAddress;
|
2009-05-27 23:55:51 +02:00
|
|
|
/** Addresses to bind for listening for transparent pf/netfilter
|
2006-11-14 01:06:31 +01:00
|
|
|
* connections. */
|
2006-08-10 11:01:37 +02:00
|
|
|
config_line_t *TransListenAddress;
|
2006-11-14 01:06:31 +01:00
|
|
|
/** Addresses to bind for listening for transparent natd connections */
|
|
|
|
config_line_t *NatdListenAddress;
|
2007-05-24 22:31:30 +02:00
|
|
|
/** Addresses to bind for listening for SOCKS connections. */
|
|
|
|
config_line_t *DNSListenAddress;
|
2004-08-16 13:43:18 +02:00
|
|
|
/** Addresses to bind for listening for OR connections. */
|
2005-10-17 05:17:29 +02:00
|
|
|
config_line_t *ORListenAddress;
|
2004-08-16 13:43:18 +02:00
|
|
|
/** Addresses to bind for listening for directory connections. */
|
2005-10-17 05:17:29 +02:00
|
|
|
config_line_t *DirListenAddress;
|
2006-02-13 07:25:16 +01:00
|
|
|
/** Addresses to bind for listening for control connections. */
|
|
|
|
config_line_t *ControlListenAddress;
|
2004-08-16 13:43:18 +02:00
|
|
|
/** Local address to bind outbound sockets */
|
|
|
|
char *OutboundBindAddress;
|
2005-01-06 22:03:27 +01:00
|
|
|
/** Directory server only: which versions of
|
|
|
|
* Tor should we tell users to run? */
|
2005-07-22 23:12:10 +02:00
|
|
|
config_line_t *RecommendedVersions;
|
2005-08-25 22:33:17 +02:00
|
|
|
config_line_t *RecommendedClientVersions;
|
|
|
|
config_line_t *RecommendedServerVersions;
|
2005-01-06 22:03:27 +01:00
|
|
|
/** Whether dirservers refuse router descriptors with private IPs. */
|
|
|
|
int DirAllowPrivateAddresses;
|
2004-05-10 08:52:01 +02:00
|
|
|
char *User; /**< Name of user to run Tor as. */
|
|
|
|
char *Group; /**< Name of group to run Tor as. */
|
2004-05-10 12:27:54 +02:00
|
|
|
int ORPort; /**< Port to listen on for OR connections. */
|
|
|
|
int SocksPort; /**< Port to listen on for SOCKS connections. */
|
2006-11-14 01:06:31 +01:00
|
|
|
/** Port to listen on for transparent pf/netfilter connections. */
|
|
|
|
int TransPort;
|
|
|
|
int NatdPort; /**< Port to listen on for transparent natd connections. */
|
2004-11-04 07:41:49 +01:00
|
|
|
int ControlPort; /**< Port to listen on for control connections. */
|
2007-06-05 22:54:53 +02:00
|
|
|
config_line_t *ControlSocket; /**< List of Unix Domain Sockets to listen on
|
|
|
|
* for control connections. */
|
2004-05-10 12:27:54 +02:00
|
|
|
int DirPort; /**< Port to listen on for directory connections. */
|
2007-05-24 22:31:30 +02:00
|
|
|
int DNSPort; /**< Port to listen on for DNS requests. */
|
2005-08-26 09:41:19 +02:00
|
|
|
int AssumeReachable; /**< Whether to publish our descriptor regardless. */
|
2004-06-21 06:37:27 +02:00
|
|
|
int AuthoritativeDir; /**< Boolean: is this an authoritative directory? */
|
2006-10-02 00:16:55 +02:00
|
|
|
int V1AuthoritativeDir; /**< Boolean: is this an authoritative directory
|
2005-09-15 16:39:05 +02:00
|
|
|
* for version 1 directories? */
|
2007-05-02 11:12:04 +02:00
|
|
|
int V2AuthoritativeDir; /**< Boolean: is this an authoritative directory
|
|
|
|
* for version 2 directories? */
|
2007-05-22 19:58:25 +02:00
|
|
|
int V3AuthoritativeDir; /**< Boolean: is this an authoritative directory
|
|
|
|
* for version 3 directories? */
|
2006-10-02 00:16:55 +02:00
|
|
|
int HSAuthoritativeDir; /**< Boolean: does this an authoritative directory
|
|
|
|
* handle hidden service requests? */
|
2007-04-30 19:46:13 +02:00
|
|
|
int HSAuthorityRecordStats; /**< Boolean: does this HS authoritative
|
|
|
|
* directory record statistics? */
|
2005-09-15 16:39:05 +02:00
|
|
|
int NamingAuthoritativeDir; /**< Boolean: is this an authoritative directory
|
|
|
|
* that's willing to bind names? */
|
2005-12-14 21:40:40 +01:00
|
|
|
int VersioningAuthoritativeDir; /**< Boolean: is this an authoritative
|
|
|
|
* directory that's willing to recommend
|
|
|
|
* versions? */
|
2007-05-04 10:04:27 +02:00
|
|
|
int BridgeAuthoritativeDir; /**< Boolean: is this an authoritative directory
|
|
|
|
* that aggregates bridge descriptors? */
|
2007-05-08 13:28:05 +02:00
|
|
|
|
2007-12-22 11:54:21 +01:00
|
|
|
/** If set on a bridge authority, it will answer requests on its dirport
|
|
|
|
* for bridge statuses -- but only if the requests use this password.
|
|
|
|
* If set on a bridge user, request bridge statuses, and use this password
|
|
|
|
* when doing so. */
|
|
|
|
char *BridgePassword;
|
|
|
|
|
2007-05-08 13:28:05 +02:00
|
|
|
int UseBridges; /**< Boolean: should we start all circuits with a bridge? */
|
|
|
|
config_line_t *Bridges; /**< List of bootstrap bridge addresses. */
|
|
|
|
|
2007-12-04 19:35:03 +01:00
|
|
|
int BridgeRelay; /**< Boolean: are we acting as a bridge relay? We make
|
|
|
|
* this explicit so we can change how we behave in the
|
|
|
|
* future. */
|
|
|
|
|
2007-06-10 09:34:21 +02:00
|
|
|
/** Boolean: if we know the bridge's digest, should we get new
|
|
|
|
* descriptors from the bridge authorities or from the bridge itself? */
|
|
|
|
int UpdateBridgesFromAuthority;
|
|
|
|
|
2006-09-07 02:30:29 +02:00
|
|
|
int AvoidDiskWrites; /**< Boolean: should we never cache things to disk?
|
|
|
|
* Not used yet. */
|
2004-07-13 09:42:20 +02:00
|
|
|
int ClientOnly; /**< Boolean: should we never evolve into a server role? */
|
2007-05-08 11:09:26 +02:00
|
|
|
/** Boolean: should we never publish a descriptor? Deprecated. */
|
|
|
|
int NoPublish;
|
|
|
|
/** To what authority types do we publish our descriptor? Choices are
|
2008-01-19 21:00:53 +01:00
|
|
|
* "v1", "v2", "v3", "bridge", or "". */
|
2007-05-09 06:15:46 +02:00
|
|
|
smartlist_t *PublishServerDescriptor;
|
2007-05-08 11:09:26 +02:00
|
|
|
/** An authority type, derived from PublishServerDescriptor. */
|
|
|
|
authority_type_t _PublishServerDescriptor;
|
|
|
|
/** Boolean: do we publish hidden service descriptors to the HS auths? */
|
|
|
|
int PublishHidServDescriptors;
|
2006-02-19 23:02:02 +01:00
|
|
|
int FetchServerDescriptors; /**< Do we fetch server descriptors as normal? */
|
|
|
|
int FetchHidServDescriptors; /** and hidden service descriptors? */
|
2008-01-19 21:00:53 +01:00
|
|
|
int HidServDirectoryV2; /**< Do we participate in the HS DHT? */
|
2007-10-29 20:10:47 +01:00
|
|
|
|
2007-11-29 16:25:04 +01:00
|
|
|
int MinUptimeHidServDirectoryV2; /**< As directory authority, accept hidden
|
|
|
|
* service directories after what time? */
|
2006-04-08 23:48:14 +02:00
|
|
|
int FetchUselessDescriptors; /**< Do we fetch non-running descriptors too? */
|
2006-02-19 23:02:02 +01:00
|
|
|
int AllDirActionsPrivate; /**< Should every directory action be sent
|
|
|
|
* through a Tor circuit? */
|
|
|
|
|
2006-02-09 03:59:26 +01:00
|
|
|
int ConnLimit; /**< Demanded minimum number of simultaneous connections. */
|
|
|
|
int _ConnLimit; /**< Maximum allowed number of simultaneous connections. */
|
2004-05-10 08:52:01 +02:00
|
|
|
int RunAsDaemon; /**< If true, run in the background. (Unix only) */
|
2004-08-16 22:47:00 +02:00
|
|
|
int FascistFirewall; /**< Whether to prefer ORs reachable on open ports. */
|
2005-12-14 21:40:40 +01:00
|
|
|
smartlist_t *FirewallPorts; /**< Which ports our firewall allows
|
|
|
|
* (strings). */
|
2006-02-19 09:31:47 +01:00
|
|
|
config_line_t *ReachableAddresses; /**< IP:ports our firewall allows. */
|
|
|
|
config_line_t *ReachableORAddresses; /**< IP:ports for OR conns. */
|
|
|
|
config_line_t *ReachableDirAddresses; /**< IP:ports for Dir conns. */
|
2005-08-08 23:58:48 +02:00
|
|
|
|
2007-07-16 18:23:34 +02:00
|
|
|
int ConstrainedSockets; /**< Shrink xmit and recv socket buffers. */
|
2007-07-16 18:23:36 +02:00
|
|
|
uint64_t ConstrainedSockSize; /**< Size of constrained buffers. */
|
2007-07-16 18:23:34 +02:00
|
|
|
|
2005-12-14 21:40:40 +01:00
|
|
|
/** Application ports that require all nodes in circ to have sufficient
|
|
|
|
* uptime. */
|
2005-01-12 05:58:23 +01:00
|
|
|
smartlist_t *LongLivedPorts;
|
2008-01-20 06:54:15 +01:00
|
|
|
/** Application ports that are likely to be unencrypted and
|
|
|
|
* unauthenticated; we reject requests for them to prevent the
|
|
|
|
* user from screwing up and leaking plaintext secrets to an
|
|
|
|
* observer somewhere on the Internet. */
|
|
|
|
smartlist_t *RejectPlaintextPorts;
|
|
|
|
/** Related to RejectPlaintextPorts above, except this config option
|
|
|
|
* controls whether we warn (in the log and via a controller status
|
|
|
|
* event) every time a risky connection is attempted. */
|
|
|
|
smartlist_t *WarnPlaintextPorts;
|
2005-02-22 01:53:08 +01:00
|
|
|
/** Should we try to reuse the same exit node for a given host */
|
|
|
|
smartlist_t *TrackHostExits;
|
2005-12-14 21:40:40 +01:00
|
|
|
int TrackHostExitsExpire; /**< Number of seconds until we expire an
|
|
|
|
* addressmap */
|
2005-07-22 23:12:10 +02:00
|
|
|
config_line_t *AddressMap; /**< List of address map directives. */
|
2007-05-29 19:31:13 +02:00
|
|
|
int AutomapHostsOnResolve; /**< If true, when we get a resolve request for a
|
|
|
|
* hostname ending with one of the suffixes in
|
|
|
|
* <b>AutomapHostsSuffixes</b>, map it to a
|
|
|
|
* virtual address. */
|
|
|
|
smartlist_t *AutomapHostsSuffixes; /**< List of suffixes for
|
|
|
|
* <b>AutomapHostsOnResolve</b>. */
|
2004-11-15 10:05:54 +01:00
|
|
|
int RendPostPeriod; /**< How often do we post each rendezvous service
|
|
|
|
* descriptor? Remember to publish them independently. */
|
2004-05-10 08:52:01 +02:00
|
|
|
int KeepalivePeriod; /**< How often do we send padding cells to keep
|
|
|
|
* connections alive? */
|
2006-03-22 00:27:43 +01:00
|
|
|
int SocksTimeout; /**< How long do we let a socks connection wait
|
|
|
|
* unattached before we fail it? */
|
2006-03-22 01:52:37 +01:00
|
|
|
int CircuitBuildTimeout; /**< Cull non-open circuits that were born
|
|
|
|
* at least this many seconds ago. */
|
|
|
|
int CircuitIdleTimeout; /**< Cull open clean circuits that were born
|
|
|
|
* at least this many seconds ago. */
|
2004-05-10 08:52:01 +02:00
|
|
|
int MaxOnionsPending; /**< How many circuit CREATE requests do we allow
|
|
|
|
* to wait simultaneously before we start dropping
|
|
|
|
* them? */
|
|
|
|
int NewCircuitPeriod; /**< How long do we use a circuit before building
|
|
|
|
* a new one? */
|
Introduce a notion of 'internal' circs, which are chosen without regard
to the exit policy of the last hop. Intro and rendezvous circs must
be internal circs, to avoid leaking information. Resolve and connect
streams can use internal circs if they want.
New circuit pooling algorithm: make sure to have enough circs around
to satisfy any predicted ports, and also make sure to have 2 internal
circs around if we've required internal circs lately (with high uptime
if we've seen that lately).
Split NewCircuitPeriod config option into NewCircuitPeriod (30 secs),
which describes how often we retry making new circuits if current ones
are dirty, and MaxCircuitDirtiness (10 mins), which describes how long
we're willing to make use of an already-dirty circuit.
Once rendezvous circuits are established, keep using the same circuit as
long as you attach a new stream to it at least every 10 minutes. (So web
browsing doesn't require you to build new rend circs every 30 seconds.)
Cannibalize GENERAL circs to be C_REND, C_INTRO, S_INTRO, and S_REND
circ as necessary, if there are any completed ones lying around when
we try to launch one.
Re-instate the ifdef's to use version-0 style introduce cells, since
there was yet another bug in handling version-1 style. We'll try switching
over again after 0.0.9 is obsolete.
Bugfix: when choosing an exit node for a new non-internal circ, don't take
into account whether it'll be useful for any pending x.onion addresses --
it won't.
Bugfix: we weren't actually publishing the hidden service descriptor when
it became dirty. So we only published it every 20 minutes or so, which
means when you first start your Tor, the hidden service will seem broken.
svn:r3360
2005-01-17 19:13:09 +01:00
|
|
|
int MaxCircuitDirtiness; /**< Never use circs that were first used more than
|
|
|
|
this interval ago. */
|
2005-12-14 21:40:40 +01:00
|
|
|
uint64_t BandwidthRate; /**< How much bandwidth, on average, are we willing
|
|
|
|
* to use in a second? */
|
|
|
|
uint64_t BandwidthBurst; /**< How much bandwidth, at maximum, are we willing
|
|
|
|
* to use in a second? */
|
2005-03-22 20:01:46 +01:00
|
|
|
uint64_t MaxAdvertisedBandwidth; /**< How much bandwidth are we willing to
|
|
|
|
* tell people we have? */
|
2007-03-20 03:55:31 +01:00
|
|
|
uint64_t RelayBandwidthRate; /**< How much bandwidth, on average, are we
|
|
|
|
* willing to use for all relayed conns? */
|
|
|
|
uint64_t RelayBandwidthBurst; /**< How much bandwidth, at maximum, will we
|
|
|
|
* use in a second for all relayed conns? */
|
2004-05-10 08:52:01 +02:00
|
|
|
int NumCpus; /**< How many CPUs should we try to use? */
|
|
|
|
int RunTesting; /**< If true, create testing circuits to measure how well the
|
|
|
|
* other ORs are running. */
|
2005-07-22 23:12:10 +02:00
|
|
|
config_line_t *RendConfigLines; /**< List of configuration lines
|
2004-05-10 08:52:01 +02:00
|
|
|
* for rendezvous services. */
|
2008-08-12 18:12:26 +02:00
|
|
|
config_line_t *HidServAuth; /**< List of configuration lines for client-side
|
|
|
|
* authorizations for hidden services */
|
2008-01-19 21:00:53 +01:00
|
|
|
char *ContactInfo; /**< Contact info to be published in the directory. */
|
2004-10-08 07:53:59 +02:00
|
|
|
|
2008-01-19 21:00:53 +01:00
|
|
|
char *HttpProxy; /**< hostname[:port] to use as http proxy, if any. */
|
2009-06-19 18:48:00 +02:00
|
|
|
tor_addr_t HttpProxyAddr; /**< Parsed IPv4 addr for http proxy, if any. */
|
2008-01-19 21:00:53 +01:00
|
|
|
uint16_t HttpProxyPort; /**< Parsed port for http proxy, if any. */
|
|
|
|
char *HttpProxyAuthenticator; /**< username:password string, if any. */
|
2004-10-08 07:53:59 +02:00
|
|
|
|
2008-01-19 21:00:53 +01:00
|
|
|
char *HttpsProxy; /**< hostname[:port] to use as https proxy, if any. */
|
2009-06-19 18:48:00 +02:00
|
|
|
tor_addr_t HttpsProxyAddr; /**< Parsed addr for https proxy, if any. */
|
2008-01-19 21:00:53 +01:00
|
|
|
uint16_t HttpsProxyPort; /**< Parsed port for https proxy, if any. */
|
|
|
|
char *HttpsProxyAuthenticator; /**< username:password string, if any. */
|
2005-02-24 11:56:55 +01:00
|
|
|
|
2009-08-26 17:34:45 +02:00
|
|
|
char *Socks4Proxy; /**< hostname:port to use as a SOCKS4 proxy, if any. */
|
|
|
|
tor_addr_t Socks4ProxyAddr; /**< Derived from Socks4Proxy. */
|
|
|
|
uint16_t Socks4ProxyPort; /**< Derived from Socks4Proxy. */
|
|
|
|
|
|
|
|
char *Socks5Proxy; /**< hostname:port to use as a SOCKS5 proxy, if any. */
|
|
|
|
tor_addr_t Socks5ProxyAddr; /**< Derived from Sock5Proxy. */
|
|
|
|
uint16_t Socks5ProxyPort; /**< Derived from Socks5Proxy. */
|
|
|
|
char *Socks5ProxyUsername; /**< Username for SOCKS5 authentication, if any */
|
|
|
|
char *Socks5ProxyPassword; /**< Password for SOCKS5 authentication, if any */
|
2009-06-19 01:59:18 +02:00
|
|
|
|
2007-12-12 05:38:54 +01:00
|
|
|
/** List of configuration lines for replacement directory authorities.
|
|
|
|
* If you just want to replace one class of authority at a time,
|
|
|
|
* use the "Alternate*Authority" options below instead. */
|
|
|
|
config_line_t *DirServers;
|
|
|
|
|
|
|
|
/** If set, use these main (currently v3) directory authorities and
|
|
|
|
* not the default ones. */
|
|
|
|
config_line_t *AlternateDirAuthority;
|
|
|
|
|
|
|
|
/** If set, use these bridge authorities and not the default one. */
|
|
|
|
config_line_t *AlternateBridgeAuthority;
|
|
|
|
|
|
|
|
/** If set, use these HS authorities and not the default ones. */
|
|
|
|
config_line_t *AlternateHSAuthority;
|
|
|
|
|
2004-10-15 03:58:11 +02:00
|
|
|
char *MyFamily; /**< Declared family for this OR. */
|
2005-07-22 23:12:10 +02:00
|
|
|
config_line_t *NodeFamilies; /**< List of config lines for
|
2004-10-15 22:52:09 +02:00
|
|
|
* node families */
|
2007-12-10 17:49:54 +01:00
|
|
|
config_line_t *AuthDirBadDir; /**< Address policy for descriptors to
|
|
|
|
* mark as bad dir mirrors. */
|
2006-10-23 05:48:52 +02:00
|
|
|
config_line_t *AuthDirBadExit; /**< Address policy for descriptors to
|
2007-12-10 17:49:54 +01:00
|
|
|
* mark as bad exits. */
|
2005-09-15 16:39:05 +02:00
|
|
|
config_line_t *AuthDirReject; /**< Address policy for descriptors to
|
|
|
|
* reject. */
|
|
|
|
config_line_t *AuthDirInvalid; /**< Address policy for descriptors to
|
|
|
|
* never mark as valid. */
|
2007-12-10 17:49:54 +01:00
|
|
|
int AuthDirListBadDirs; /**< True iff we should list bad dirs,
|
|
|
|
* and vote for all other dir mirrors as good. */
|
2006-10-23 05:48:52 +02:00
|
|
|
int AuthDirListBadExits; /**< True iff we should list bad exits,
|
|
|
|
* and vote for all other exits as good. */
|
2005-12-15 22:39:38 +01:00
|
|
|
int AuthDirRejectUnlisted; /**< Boolean: do we reject all routers that
|
2005-12-15 22:51:12 +01:00
|
|
|
* aren't named in our fingerprint file? */
|
2008-01-10 17:08:47 +01:00
|
|
|
int AuthDirMaxServersPerAddr; /**< Do not permit more than this
|
|
|
|
* number of servers per IP address. */
|
|
|
|
int AuthDirMaxServersPerAuthAddr; /**< Do not permit more than this
|
|
|
|
* number of servers per IP address shared
|
|
|
|
* with an authority. */
|
|
|
|
|
2005-05-20 10:51:45 +02:00
|
|
|
char *AccountingStart; /**< How long is the accounting interval, and when
|
2004-11-22 22:56:51 +01:00
|
|
|
* does it start? */
|
2004-11-20 01:37:00 +01:00
|
|
|
uint64_t AccountingMax; /**< How many bytes do we allow per accounting
|
|
|
|
* interval before hibernation? 0 for "never
|
|
|
|
* hibernate." */
|
|
|
|
|
2007-12-09 05:59:27 +01:00
|
|
|
/** Base64-encoded hash of accepted passwords for the control system. */
|
|
|
|
config_line_t *HashedControlPassword;
|
2008-02-17 19:45:07 +01:00
|
|
|
/** As HashedControlPassword, but not saved. */
|
|
|
|
config_line_t *HashedControlSessionPassword;
|
2007-12-09 05:59:27 +01:00
|
|
|
|
2004-11-12 17:39:03 +01:00
|
|
|
int CookieAuthentication; /**< Boolean: do we enable cookie-based auth for
|
|
|
|
* the control system? */
|
2007-08-16 19:46:01 +02:00
|
|
|
char *CookieAuthFile; /**< Location of a cookie authentication file. */
|
|
|
|
int CookieAuthFileGroupReadable; /**< Boolean: Is the CookieAuthFile g+r? */
|
2005-03-27 08:25:33 +02:00
|
|
|
int LeaveStreamsUnattached; /**< Boolean: Does Tor attach new streams to
|
|
|
|
* circuits itself (0), or does it expect a controller
|
|
|
|
* to cope? (1) */
|
2007-04-30 11:18:48 +02:00
|
|
|
int DisablePredictedCircuits; /**< Boolean: does Tor preemptively
|
|
|
|
* make circuits in the background (0),
|
|
|
|
* or not (1)? */
|
2005-03-12 21:13:38 +01:00
|
|
|
int ShutdownWaitLength; /**< When we get a SIGINT and we're a server, how
|
|
|
|
* long do we wait before exiting? */
|
2005-05-03 12:04:08 +02:00
|
|
|
int SafeLogging; /**< Boolean: are we allowed to log sensitive strings
|
|
|
|
* such as addresses (0), or do we scrub them first (1)? */
|
2006-03-19 02:44:53 +01:00
|
|
|
int SafeSocks; /**< Boolean: should we outright refuse application
|
|
|
|
* connections that use socks4 or socks5-with-local-dns? */
|
2005-12-14 21:40:40 +01:00
|
|
|
#define LOG_PROTOCOL_WARN (get_options()->ProtocolWarnings ? \
|
|
|
|
LOG_WARN : LOG_INFO)
|
2005-10-17 02:35:53 +02:00
|
|
|
int ProtocolWarnings; /**< Boolean: when other parties screw up the Tor
|
|
|
|
* protocol, is it a warn or an info in our logs? */
|
2005-11-17 00:37:35 +01:00
|
|
|
int TestSocks; /**< Boolean: when we get a socks connection, do we loudly
|
|
|
|
* log whether it was DNS-leaking or not? */
|
2005-06-20 20:56:35 +02:00
|
|
|
int HardwareAccel; /**< Boolean: Should we enable OpenSSL hardware
|
|
|
|
* acceleration where available? */
|
2009-05-24 01:42:44 +02:00
|
|
|
char *AccelName; /**< Optional hardware acceleration engine name. */
|
|
|
|
char *AccelDir; /**< Optional hardware acceleration engine search dir. */
|
2006-01-10 23:42:44 +01:00
|
|
|
int UseEntryGuards; /**< Boolean: Do we try to enter from a smallish number
|
|
|
|
* of fixed nodes? */
|
|
|
|
int NumEntryGuards; /**< How many entry guards do we try to establish? */
|
2005-07-25 12:29:21 +02:00
|
|
|
int RephistTrackTime; /**< How many seconds do we keep rephist info? */
|
2005-12-07 23:09:02 +01:00
|
|
|
int FastFirstHopPK; /**< If Tor believes it is safe, should we save a third
|
|
|
|
* of our PK time by sending CREATE_FAST cells? */
|
2007-12-21 07:08:00 +01:00
|
|
|
/** Should we always fetch our dir info on the mirror schedule (which
|
|
|
|
* means directly from the authorities) no matter our other config? */
|
|
|
|
int FetchDirInfoEarly;
|
2005-08-08 23:58:48 +02:00
|
|
|
|
2009-07-12 03:43:33 +02:00
|
|
|
/** Should we fetch our dir info at the start of the consensus period? */
|
|
|
|
int FetchDirInfoExtraEarly;
|
|
|
|
|
2006-04-18 05:36:28 +02:00
|
|
|
char *VirtualAddrNetwork; /**< Address and mask to hand out for virtual
|
|
|
|
* MAPADDRESS requests. */
|
2006-09-21 23:48:16 +02:00
|
|
|
int ServerDNSSearchDomains; /**< Boolean: If set, we don't force exit
|
|
|
|
* addresses to be FQDNs, but rather search for them in
|
|
|
|
* the local domains. */
|
2006-09-21 23:48:22 +02:00
|
|
|
int ServerDNSDetectHijacking; /**< Boolean: If true, check for DNS failure
|
2006-09-25 07:59:13 +02:00
|
|
|
* hijacking. */
|
2008-10-29 20:20:02 +01:00
|
|
|
int ServerDNSRandomizeCase; /**< Boolean: Use the 0x20-hack to prevent
|
|
|
|
* DNS poisoning attacks. */
|
2006-09-21 23:48:16 +02:00
|
|
|
char *ServerDNSResolvConfFile; /**< If provided, we configure our internal
|
|
|
|
* resolver from the file here rather than from
|
2006-09-25 07:59:13 +02:00
|
|
|
* /etc/resolv.conf (Unix) or the registry (Windows). */
|
2008-12-07 02:21:19 +01:00
|
|
|
char *DirPortFrontPage; /**< This is a full path to a file with an html
|
|
|
|
disclaimer. This allows a server administrator to show
|
|
|
|
that they're running Tor and anyone visiting their server
|
|
|
|
will know this without any specialized knowledge. */
|
2008-02-06 13:46:17 +01:00
|
|
|
/** Boolean: if set, we start even if our resolv.conf file is missing
|
|
|
|
* or broken. */
|
2008-12-17 23:58:14 +01:00
|
|
|
int ServerDNSAllowBrokenConfig;
|
2008-02-06 13:46:17 +01:00
|
|
|
|
2006-12-28 22:29:11 +01:00
|
|
|
smartlist_t *ServerDNSTestAddresses; /**< A list of addresses that definitely
|
2009-05-27 23:55:51 +02:00
|
|
|
* should be resolvable. Used for
|
2006-12-28 22:29:11 +01:00
|
|
|
* testing our DNS server. */
|
2006-12-13 01:28:56 +01:00
|
|
|
int EnforceDistinctSubnets; /**< If true, don't allow multiple routers in the
|
2006-09-26 00:12:54 +02:00
|
|
|
* same network zone in the same circuit. */
|
2006-12-13 01:28:56 +01:00
|
|
|
int TunnelDirConns; /**< If true, use BEGIN_DIR rather than BEGIN when
|
|
|
|
* possible. */
|
2007-01-03 07:33:03 +01:00
|
|
|
int PreferTunneledDirConns; /**< If true, avoid dirservers that don't
|
|
|
|
* support BEGIN_DIR, when possible. */
|
2006-12-20 10:25:58 +01:00
|
|
|
int AllowNonRFC953Hostnames; /**< If true, we allow connections to hostnames
|
|
|
|
* with weird characters. */
|
2007-08-13 20:09:38 +02:00
|
|
|
/** If true, we try resolving hostnames with weird characters. */
|
2007-01-11 17:02:39 +01:00
|
|
|
int ServerDNSAllowNonRFC953Hostnames;
|
2007-05-01 22:13:49 +02:00
|
|
|
|
2007-05-18 23:19:19 +02:00
|
|
|
/** If true, we try to download extra-info documents (and we serve them,
|
|
|
|
* if we are a cache). For authorities, this is always true. */
|
|
|
|
int DownloadExtraInfo;
|
|
|
|
|
2008-09-26 20:58:45 +02:00
|
|
|
/** If true, and we are acting as a relay, allow exit circuits even when
|
|
|
|
* we are the first hop of a circuit. */
|
|
|
|
int AllowSingleHopExits;
|
|
|
|
/** If true, don't allow relays with AllowSingleHopExits=1 to be used in
|
|
|
|
* circuits that we build. */
|
|
|
|
int ExcludeSingleHopRelays;
|
|
|
|
/** If true, and the controller tells us to use a one-hop circuit, and the
|
|
|
|
* exit allows it, we use it. */
|
|
|
|
int AllowSingleHopCircuits;
|
|
|
|
|
2009-08-08 01:26:41 +02:00
|
|
|
/** If true, we convert "www.google.com.foo.exit" addresses on the
|
|
|
|
* socks/trans/natd ports into "www.google.com" addresses that
|
|
|
|
* exit from the node "foo". Disabled by default since attacking
|
|
|
|
* websites and exit relays can use it to manipulate your path
|
|
|
|
* selection. */
|
|
|
|
int AllowDotExit;
|
|
|
|
|
2009-07-15 16:32:40 +02:00
|
|
|
/** If true, the user wants us to collect statistics on clients
|
|
|
|
* requesting network statuses from us as directory. */
|
|
|
|
int DirReqStatistics;
|
|
|
|
|
2009-06-24 19:51:45 +02:00
|
|
|
/** If true, the user wants us to collect statistics on port usage. */
|
|
|
|
int ExitPortStatistics;
|
|
|
|
|
2009-07-05 19:53:25 +02:00
|
|
|
/** If true, the user wants us to collect cell statistics. */
|
|
|
|
int CellStatistics;
|
|
|
|
|
2009-07-05 20:48:16 +02:00
|
|
|
/** If true, the user wants us to collect statistics as entry node. */
|
|
|
|
int EntryStatistics;
|
|
|
|
|
2009-08-14 15:30:24 +02:00
|
|
|
/** If true, include statistics file contents in extra-info documents. */
|
|
|
|
int ExtraInfoStatistics;
|
|
|
|
|
2007-08-27 17:33:58 +02:00
|
|
|
/** If true, do not believe anybody who tells us that a domain resolves
|
|
|
|
* to an internal address, or that an internal address has a PTR mapping.
|
|
|
|
* Helps avoid some cross-site attacks. */
|
|
|
|
int ClientDNSRejectInternalAddresses;
|
|
|
|
|
2007-08-14 22:19:40 +02:00
|
|
|
/** The length of time that we think a consensus should be fresh. */
|
2007-08-13 20:09:38 +02:00
|
|
|
int V3AuthVotingInterval;
|
2008-01-19 21:00:53 +01:00
|
|
|
/** The length of time we think it will take to distribute votes. */
|
2007-08-14 04:23:57 +02:00
|
|
|
int V3AuthVoteDelay;
|
2008-01-19 21:00:53 +01:00
|
|
|
/** The length of time we think it will take to distribute signatures. */
|
2007-08-14 04:23:57 +02:00
|
|
|
int V3AuthDistDelay;
|
2007-08-14 22:19:40 +02:00
|
|
|
/** The number of intervals we think a consensus should be valid. */
|
2007-08-14 04:23:57 +02:00
|
|
|
int V3AuthNIntervalsValid;
|
2007-10-29 00:44:53 +01:00
|
|
|
|
2008-05-12 04:14:01 +02:00
|
|
|
/** Should advertise and sign consensuses with a legacy key, for key
|
|
|
|
* migration purposes? */
|
|
|
|
int V3AuthUseLegacyKey;
|
|
|
|
|
2009-07-31 06:33:53 +02:00
|
|
|
/** Location of bandwidth measurement file */
|
|
|
|
char *V3BandwidthsFile;
|
|
|
|
|
2009-09-15 10:40:08 +02:00
|
|
|
/** Authority only: key=value pairs that we add to our networkstatus
|
|
|
|
* consensus vote on the 'params' line. */
|
|
|
|
char *ConsensusParams;
|
|
|
|
|
2008-06-14 18:11:37 +02:00
|
|
|
/** The length of time that we think an initial consensus should be fresh.
|
|
|
|
* Only altered on testing networks. */
|
2008-06-20 19:03:13 +02:00
|
|
|
int TestingV3AuthInitialVotingInterval;
|
2008-06-14 18:01:29 +02:00
|
|
|
|
2008-06-14 18:11:37 +02:00
|
|
|
/** The length of time we think it will take to distribute initial votes.
|
|
|
|
* Only altered on testing networks. */
|
2008-06-20 19:03:13 +02:00
|
|
|
int TestingV3AuthInitialVoteDelay;
|
2008-06-14 18:01:29 +02:00
|
|
|
|
|
|
|
/** The length of time we think it will take to distribute initial
|
2008-06-14 18:11:37 +02:00
|
|
|
* signatures. Only altered on testing networks.*/
|
2008-06-20 19:03:13 +02:00
|
|
|
int TestingV3AuthInitialDistDelay;
|
2008-06-14 18:01:29 +02:00
|
|
|
|
2008-06-14 18:11:37 +02:00
|
|
|
/** If an authority has been around for less than this amount of time, it
|
|
|
|
* does not believe its reachability information is accurate. Only
|
|
|
|
* altered on testing networks. */
|
2008-06-20 19:03:13 +02:00
|
|
|
int TestingAuthDirTimeToLearnReachability;
|
2008-06-14 18:01:29 +02:00
|
|
|
|
|
|
|
/** Clients don't download any descriptor this recent, since it will
|
2008-06-14 18:11:37 +02:00
|
|
|
* probably not have propagated to enough caches. Only altered on testing
|
|
|
|
* networks. */
|
2008-06-20 19:03:13 +02:00
|
|
|
int TestingEstimatedDescriptorPropagationTime;
|
2008-06-14 18:01:29 +02:00
|
|
|
|
|
|
|
/** If true, we take part in a testing network. Change the defaults of a
|
|
|
|
* couple of other configuration options and allow to change the values
|
|
|
|
* of certain configuration options. */
|
|
|
|
int TestingTorNetwork;
|
|
|
|
|
2007-12-19 05:18:28 +01:00
|
|
|
/** File to check for a consensus networkstatus, if we don't have one
|
|
|
|
* cached. */
|
2007-10-29 00:44:53 +01:00
|
|
|
char *FallbackNetworkstatusFile;
|
2007-11-01 05:14:23 +01:00
|
|
|
|
2008-02-12 21:20:52 +01:00
|
|
|
/** If true, and we have GeoIP data, and we're a bridge, keep a per-country
|
|
|
|
* count of how many client addresses have contacted us so that we can help
|
|
|
|
* the bridge authority guess which countries have blocked access to us. */
|
2007-12-17 23:44:11 +01:00
|
|
|
int BridgeRecordUsageByCountry;
|
2008-12-23 18:56:31 +01:00
|
|
|
|
2009-05-27 17:52:46 +02:00
|
|
|
#if 0
|
2009-07-15 16:32:40 +02:00
|
|
|
/** If true, and Tor is built with DIRREQ_STATS support, and we're a
|
2008-12-23 18:56:31 +01:00
|
|
|
* directory, record how many directory requests we get from each country. */
|
2008-05-29 04:29:35 +02:00
|
|
|
int DirRecordUsageByCountry;
|
2008-12-23 18:56:31 +01:00
|
|
|
/** Round all GeoIP results to the next multiple of this value, to avoid
|
|
|
|
* leaking information. */
|
2008-06-18 06:34:52 +02:00
|
|
|
int DirRecordUsageGranularity;
|
2008-12-23 18:56:31 +01:00
|
|
|
/** Time interval: purge geoip stats after this long. */
|
2008-06-18 06:34:52 +02:00
|
|
|
int DirRecordUsageRetainIPs;
|
2008-12-23 18:56:31 +01:00
|
|
|
/** Time interval: Flush geoip data to disk this often. */
|
2008-06-18 06:34:52 +02:00
|
|
|
int DirRecordUsageSaveInterval;
|
2008-05-29 04:29:35 +02:00
|
|
|
#endif
|
|
|
|
|
2008-02-12 21:20:52 +01:00
|
|
|
/** Optionally, a file with GeoIP data. */
|
2007-12-18 22:27:08 +01:00
|
|
|
char *GeoIPFile;
|
2007-12-17 23:44:11 +01:00
|
|
|
|
2008-12-10 23:17:02 +01:00
|
|
|
/** If true, SIGHUP should reload the torrc. Sometimes controllers want
|
|
|
|
* to make this false. */
|
|
|
|
int ReloadTorrcOnSIGHUP;
|
|
|
|
|
2002-07-03 18:31:22 +02:00
|
|
|
} or_options_t;
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2005-07-28 21:01:48 +02:00
|
|
|
/** Persistent state for an onion router, as saved to disk. */
|
|
|
|
typedef struct {
|
|
|
|
uint32_t _magic;
|
2006-12-07 21:11:30 +01:00
|
|
|
/** The time at which we next plan to write the state to the disk. Equal to
|
2009-05-27 23:55:51 +02:00
|
|
|
* TIME_MAX if there are no savable changes, 0 if there are changes that
|
2006-12-07 21:11:30 +01:00
|
|
|
* should be saved right away. */
|
|
|
|
time_t next_write;
|
2005-07-28 21:01:48 +02:00
|
|
|
|
2006-12-07 21:11:30 +01:00
|
|
|
/** When was the state last written to disk? */
|
2005-07-28 21:01:48 +02:00
|
|
|
time_t LastWritten;
|
2006-12-07 21:11:30 +01:00
|
|
|
|
2006-12-09 20:40:16 +01:00
|
|
|
/** Fields for accounting bandwidth use. */
|
2005-07-28 21:01:48 +02:00
|
|
|
time_t AccountingIntervalStart;
|
|
|
|
uint64_t AccountingBytesReadInInterval;
|
|
|
|
uint64_t AccountingBytesWrittenInInterval;
|
|
|
|
int AccountingSecondsActive;
|
|
|
|
uint64_t AccountingExpectedUsage;
|
|
|
|
|
2006-12-07 21:11:30 +01:00
|
|
|
/** A list of Entry Guard-related configuration lines. */
|
2006-01-10 23:42:44 +01:00
|
|
|
config_line_t *EntryGuards;
|
2005-12-24 00:56:42 +01:00
|
|
|
|
2006-12-07 21:11:30 +01:00
|
|
|
/** These fields hold information on the history of bandwidth usage for
|
|
|
|
* servers. The "Ends" fields hold the time when we last updated the
|
|
|
|
* bandwidth usage. The "Interval" fields hold the granularity, in seconds,
|
|
|
|
* of the entries of Values. The "Values" lists hold decimal string
|
|
|
|
* representations of the number of bytes read or written in each
|
|
|
|
* interval. */
|
2005-12-24 00:56:42 +01:00
|
|
|
time_t BWHistoryReadEnds;
|
|
|
|
int BWHistoryReadInterval;
|
|
|
|
smartlist_t *BWHistoryReadValues;
|
|
|
|
time_t BWHistoryWriteEnds;
|
|
|
|
int BWHistoryWriteInterval;
|
|
|
|
smartlist_t *BWHistoryWriteValues;
|
2005-12-31 09:16:07 +01:00
|
|
|
|
2009-08-26 02:13:12 +02:00
|
|
|
/** Build time histogram */
|
|
|
|
config_line_t * BuildtimeHistogram;
|
|
|
|
uint16_t TotalBuildTimes;
|
|
|
|
|
2006-12-09 20:40:16 +01:00
|
|
|
/** What version of Tor wrote this state file? */
|
2005-12-31 09:16:07 +01:00
|
|
|
char *TorVersion;
|
2006-02-12 23:28:30 +01:00
|
|
|
|
2006-12-09 20:40:16 +01:00
|
|
|
/** Holds any unrecognized values we found in the state file, in the order
|
2006-12-07 21:11:30 +01:00
|
|
|
* in which we found them. */
|
2006-02-12 23:28:30 +01:00
|
|
|
config_line_t *ExtraLines;
|
2006-12-15 08:04:37 +01:00
|
|
|
|
|
|
|
/** When did we last rotate our onion key? "0" for 'no idea'. */
|
|
|
|
time_t LastRotatedOnionKey;
|
2005-07-28 21:01:48 +02:00
|
|
|
} or_state_t;
|
|
|
|
|
2006-12-07 21:11:30 +01:00
|
|
|
/** Change the next_write time of <b>state</b> to <b>when</b>, unless the
|
|
|
|
* state is already scheduled to be written to disk earlier than <b>when</b>.
|
|
|
|
*/
|
|
|
|
static INLINE void or_state_mark_dirty(or_state_t *state, time_t when)
|
|
|
|
{
|
|
|
|
if (state->next_write > when)
|
|
|
|
state->next_write = when;
|
|
|
|
}
|
|
|
|
|
2004-02-26 23:02:22 +01:00
|
|
|
#define MAX_SOCKS_REPLY_LEN 1024
|
|
|
|
#define MAX_SOCKS_ADDR_LEN 256
|
2006-12-13 01:28:56 +01:00
|
|
|
|
2006-12-13 23:42:52 +01:00
|
|
|
/** Please open a TCP connection to this addr:port. */
|
|
|
|
#define SOCKS_COMMAND_CONNECT 0x01
|
|
|
|
/** Please turn this FQDN into an IP address, privately. */
|
|
|
|
#define SOCKS_COMMAND_RESOLVE 0xF0
|
|
|
|
/** Please turn this IP address into an FQDN, privately. */
|
|
|
|
#define SOCKS_COMMAND_RESOLVE_PTR 0xF1
|
2007-07-10 19:13:24 +02:00
|
|
|
|
2007-10-28 09:16:19 +01:00
|
|
|
#define SOCKS_COMMAND_IS_CONNECT(c) ((c)==SOCKS_COMMAND_CONNECT)
|
2006-12-12 21:23:17 +01:00
|
|
|
#define SOCKS_COMMAND_IS_RESOLVE(c) ((c)==SOCKS_COMMAND_RESOLVE || \
|
|
|
|
(c)==SOCKS_COMMAND_RESOLVE_PTR)
|
|
|
|
|
2007-05-29 19:31:13 +02:00
|
|
|
/** State of a SOCKS request from a user to an OP. Also used to encode other
|
|
|
|
* information for non-socks user request (such as those on TransPort and
|
|
|
|
* DNSPort) */
|
2003-11-11 03:41:31 +01:00
|
|
|
struct socks_request_t {
|
2006-12-13 23:42:52 +01:00
|
|
|
/** Which version of SOCKS did the client use? One of "0, 4, 5" -- where
|
|
|
|
* 0 means that no socks handshake ever took place, and this is just a
|
2007-06-09 07:17:33 +02:00
|
|
|
* stub connection (e.g. see connection_ap_make_link()). */
|
2006-12-13 23:42:52 +01:00
|
|
|
char socks_version;
|
|
|
|
int command; /**< What is this stream's goal? One from the above list. */
|
2004-10-14 04:47:09 +02:00
|
|
|
size_t replylen; /**< Length of <b>reply</b>. */
|
2004-05-10 09:37:10 +02:00
|
|
|
char reply[MAX_SOCKS_REPLY_LEN]; /**< Write an entry into this string if
|
|
|
|
* we want to specify our own socks reply,
|
|
|
|
* rather than using the default socks4 or
|
|
|
|
* socks5 socks reply. We use this for the
|
|
|
|
* two-stage socks5 handshake.
|
|
|
|
*/
|
2005-12-14 21:40:40 +01:00
|
|
|
char address[MAX_SOCKS_ADDR_LEN]; /**< What address did the client ask to
|
2007-05-29 19:31:13 +02:00
|
|
|
connect to/resolve? */
|
2004-05-10 09:37:10 +02:00
|
|
|
uint16_t port; /**< What port did the client ask to connect to? */
|
2008-02-18 20:24:33 +01:00
|
|
|
unsigned int has_finished : 1; /**< Has the SOCKS handshake finished? Used to
|
2007-05-29 19:31:13 +02:00
|
|
|
* make sure we send back a socks reply for
|
|
|
|
* every connection. */
|
2003-11-11 03:41:31 +01:00
|
|
|
};
|
|
|
|
|
2003-10-25 14:01:09 +02:00
|
|
|
/* all the function prototypes go here */
|
2002-06-27 00:45:49 +02:00
|
|
|
|
|
|
|
/********************************* buffers.c ***************************/
|
|
|
|
|
2004-10-27 20:16:37 +02:00
|
|
|
buf_t *buf_new(void);
|
2003-09-25 07:17:11 +02:00
|
|
|
buf_t *buf_new_with_capacity(size_t size);
|
|
|
|
void buf_free(buf_t *buf);
|
2004-02-28 20:14:11 +01:00
|
|
|
void buf_clear(buf_t *buf);
|
2005-05-03 01:17:08 +02:00
|
|
|
void buf_shrink(buf_t *buf);
|
2007-07-17 11:26:45 +02:00
|
|
|
void buf_shrink_freelists(int free_all);
|
2007-07-27 20:33:37 +02:00
|
|
|
void buf_dump_freelist_sizes(int severity);
|
2003-09-25 07:17:11 +02:00
|
|
|
|
|
|
|
size_t buf_datalen(const buf_t *buf);
|
2007-12-26 01:12:08 +01:00
|
|
|
size_t buf_allocation(const buf_t *buf);
|
|
|
|
size_t buf_slack(const buf_t *buf);
|
2003-09-25 07:17:11 +02:00
|
|
|
const char *_buf_peek_raw_buffer(const buf_t *buf);
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2008-09-14 10:35:41 +02:00
|
|
|
int read_to_buf(int s, size_t at_most, buf_t *buf, int *reached_eof,
|
|
|
|
int *socket_error);
|
2005-10-06 06:33:40 +02:00
|
|
|
int read_to_buf_tls(tor_tls_t *tls, size_t at_most, buf_t *buf);
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2005-10-29 20:19:37 +02:00
|
|
|
int flush_buf(int s, buf_t *buf, size_t sz, size_t *buf_flushlen);
|
|
|
|
int flush_buf_tls(tor_tls_t *tls, buf_t *buf, size_t sz, size_t *buf_flushlen);
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2004-10-14 04:47:09 +02:00
|
|
|
int write_to_buf(const char *string, size_t string_len, buf_t *buf);
|
2006-06-18 09:38:55 +02:00
|
|
|
int write_to_buf_zlib(buf_t *buf, tor_zlib_state_t *state,
|
|
|
|
const char *data, size_t data_len, int done);
|
2007-04-21 19:26:12 +02:00
|
|
|
int move_buf_to_buf(buf_t *buf_out, buf_t *buf_in, size_t *buf_flushlen);
|
2004-04-28 22:13:21 +02:00
|
|
|
int fetch_from_buf(char *string, size_t string_len, buf_t *buf);
|
2008-02-08 22:13:15 +01:00
|
|
|
int fetch_var_cell_from_buf(buf_t *buf, var_cell_t **out, int linkproto);
|
2003-09-25 07:17:11 +02:00
|
|
|
int fetch_from_buf_http(buf_t *buf,
|
2004-10-14 04:47:09 +02:00
|
|
|
char **headers_out, size_t max_headerlen,
|
2005-10-14 04:26:13 +02:00
|
|
|
char **body_out, size_t *body_used, size_t max_bodylen,
|
|
|
|
int force_complete);
|
2006-03-19 02:44:53 +01:00
|
|
|
int fetch_from_buf_socks(buf_t *buf, socks_request_t *req,
|
|
|
|
int log_sockstype, int safe_socks);
|
2009-06-19 01:59:18 +02:00
|
|
|
int fetch_from_buf_socks_client(buf_t *buf, int state, char **reason);
|
2005-06-17 20:49:55 +02:00
|
|
|
int fetch_from_buf_line(buf_t *buf, char *data_out, size_t *data_len);
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2007-03-04 22:08:28 +01:00
|
|
|
int peek_buf_has_control0_command(buf_t *buf);
|
|
|
|
|
2004-03-03 23:49:15 +01:00
|
|
|
void assert_buf_ok(buf_t *buf);
|
|
|
|
|
2008-02-21 00:20:36 +01:00
|
|
|
#ifdef BUFFERS_PRIVATE
|
|
|
|
int buf_find_string_offset(const buf_t *buf, const char *s, size_t n);
|
|
|
|
#endif
|
|
|
|
|
2004-05-13 09:24:49 +02:00
|
|
|
/********************************* circuitbuild.c **********************/
|
|
|
|
|
2006-07-23 09:37:35 +02:00
|
|
|
char *circuit_list_path(origin_circuit_t *circ, int verbose);
|
2006-10-03 20:58:40 +02:00
|
|
|
char *circuit_list_path_for_controller(origin_circuit_t *circ);
|
2006-07-23 09:37:35 +02:00
|
|
|
void circuit_log_path(int severity, unsigned int domain,
|
|
|
|
origin_circuit_t *circ);
|
|
|
|
void circuit_rep_hist_note_result(origin_circuit_t *circ);
|
2007-12-23 20:15:22 +01:00
|
|
|
origin_circuit_t *origin_circuit_init(uint8_t purpose, int flags);
|
2006-07-23 09:37:35 +02:00
|
|
|
origin_circuit_t *circuit_establish_circuit(uint8_t purpose,
|
2007-12-23 20:15:22 +01:00
|
|
|
extend_info_t *exit,
|
|
|
|
int flags);
|
2006-07-23 09:37:35 +02:00
|
|
|
int circuit_handle_first_hop(origin_circuit_t *circ);
|
2006-07-26 21:07:26 +02:00
|
|
|
void circuit_n_conn_done(or_connection_t *or_conn, int status);
|
2006-01-17 05:03:23 +01:00
|
|
|
int inform_testing_reachability(void);
|
2006-07-23 09:37:35 +02:00
|
|
|
int circuit_send_next_onion_skin(origin_circuit_t *circ);
|
2005-03-20 00:58:42 +01:00
|
|
|
void circuit_note_clock_jumped(int seconds_elapsed);
|
2004-05-13 09:24:49 +02:00
|
|
|
int circuit_extend(cell_t *cell, circuit_t *circ);
|
2007-01-30 23:19:41 +01:00
|
|
|
int circuit_init_cpath_crypto(crypt_path_t *cpath, const char *key_data,
|
2005-12-14 21:40:40 +01:00
|
|
|
int reverse);
|
2006-07-23 09:37:35 +02:00
|
|
|
int circuit_finish_handshake(origin_circuit_t *circ, uint8_t cell_type,
|
2007-01-30 23:19:41 +01:00
|
|
|
const char *reply);
|
2006-07-23 09:37:35 +02:00
|
|
|
int circuit_truncated(origin_circuit_t *circ, crypt_path_t *layer);
|
2007-01-30 23:19:41 +01:00
|
|
|
int onionskin_answer(or_circuit_t *circ, uint8_t cell_type,
|
|
|
|
const char *payload, const char *keys);
|
2005-01-12 05:58:23 +01:00
|
|
|
int circuit_all_predicted_ports_handled(time_t now, int *need_uptime,
|
|
|
|
int *need_capacity);
|
|
|
|
|
2006-07-23 09:37:35 +02:00
|
|
|
int circuit_append_new_exit(origin_circuit_t *circ, extend_info_t *info);
|
|
|
|
int circuit_extend_to_new_exit(origin_circuit_t *circ, extend_info_t *info);
|
2004-05-13 09:24:49 +02:00
|
|
|
void onion_append_to_cpath(crypt_path_t **head_ptr, crypt_path_t *new_hop);
|
2007-06-12 11:17:23 +02:00
|
|
|
extend_info_t *extend_info_alloc(const char *nickname, const char *digest,
|
|
|
|
crypto_pk_env_t *onion_key,
|
2008-08-05 22:08:19 +02:00
|
|
|
const tor_addr_t *addr, uint16_t port);
|
2005-06-29 23:46:55 +02:00
|
|
|
extend_info_t *extend_info_from_router(routerinfo_t *r);
|
|
|
|
extend_info_t *extend_info_dup(extend_info_t *info);
|
|
|
|
void extend_info_free(extend_info_t *info);
|
|
|
|
routerinfo_t *build_state_get_exit_router(cpath_build_state_t *state);
|
|
|
|
const char *build_state_get_exit_nickname(cpath_build_state_t *state);
|
2004-05-13 09:24:49 +02:00
|
|
|
|
2006-09-29 01:57:44 +02:00
|
|
|
void entry_guards_compute_status(void);
|
2006-10-07 01:37:07 +02:00
|
|
|
int entry_guard_register_connect_status(const char *digest, int succeeded,
|
2009-02-05 00:27:35 +01:00
|
|
|
int mark_relay_status, time_t now);
|
2005-12-31 07:32:57 +01:00
|
|
|
void entry_nodes_should_be_added(void);
|
2007-12-10 18:16:41 +01:00
|
|
|
int entry_list_can_grow(or_options_t *options);
|
2007-06-12 11:17:23 +02:00
|
|
|
routerinfo_t *choose_random_entry(cpath_build_state_t *state);
|
2006-03-26 08:51:26 +02:00
|
|
|
int entry_guards_parse_state(or_state_t *state, int set, char **msg);
|
2007-06-12 11:17:23 +02:00
|
|
|
void entry_guards_update_state(or_state_t *state);
|
2006-12-08 05:39:13 +01:00
|
|
|
int getinfo_helper_entry_guards(control_connection_t *conn,
|
|
|
|
const char *question, char **answer);
|
2005-07-22 19:32:25 +02:00
|
|
|
|
2007-06-10 09:34:21 +02:00
|
|
|
void clear_bridge_list(void);
|
2007-07-18 12:06:03 +02:00
|
|
|
int routerinfo_is_a_configured_bridge(routerinfo_t *ri);
|
2008-08-05 22:08:19 +02:00
|
|
|
void bridge_add_from_config(const tor_addr_t *addr, uint16_t port,
|
|
|
|
char *digest);
|
|
|
|
void retry_bridge_descriptor_fetch_directly(const char *digest);
|
2007-07-18 12:06:03 +02:00
|
|
|
void fetch_bridge_descriptors(time_t now);
|
2007-12-24 11:31:39 +01:00
|
|
|
void learned_bridge_descriptor(routerinfo_t *ri, int from_cache);
|
2007-06-12 11:17:23 +02:00
|
|
|
int any_bridge_descriptors_known(void);
|
2008-06-20 06:34:39 +02:00
|
|
|
int any_pending_bridge_descriptor_fetches(void);
|
2007-11-26 07:26:17 +01:00
|
|
|
int bridges_known_but_down(void);
|
2007-07-29 06:38:21 +02:00
|
|
|
void bridges_retry_all(void);
|
2007-06-10 09:34:21 +02:00
|
|
|
|
2007-07-18 12:06:03 +02:00
|
|
|
void entry_guards_free_all(void);
|
|
|
|
|
2009-09-01 03:10:27 +02:00
|
|
|
/* Circuit Build Timeout "public" functions and structures. */
|
2009-09-08 10:31:29 +02:00
|
|
|
|
|
|
|
/** How many circuits count as recent when deciding if the
|
|
|
|
* connection has changed. */
|
2009-09-01 03:10:27 +02:00
|
|
|
#define RECENT_CIRCUITS 20
|
2009-08-28 08:28:20 +02:00
|
|
|
|
2009-09-08 10:31:29 +02:00
|
|
|
/** Maximum fraction of timeouts to tolerate in the past
|
|
|
|
* RECENT_CIRCUITS before calculating a new timeout */
|
2009-09-02 05:27:43 +02:00
|
|
|
#define MAX_RECENT_TIMEOUT_RATE 0.7999999
|
2009-09-01 03:10:27 +02:00
|
|
|
|
2009-09-17 03:41:22 +02:00
|
|
|
/** Maximum quantile to use to generate synthetic timeouts.
|
|
|
|
* We want to stay a bit short of 1.0, because longtail is
|
|
|
|
* loooooooooooooooooooooooooooooooooooooooooooooooooooong. */
|
|
|
|
#define MAX_SYNTHETIC_QUANTILE 0.98
|
|
|
|
|
2009-09-08 10:31:29 +02:00
|
|
|
/** Minimum circuits before estimating a timeout */
|
|
|
|
#define MIN_CIRCUITS_TO_OBSERVE 500
|
|
|
|
|
|
|
|
/** Total size of the circuit timeout history to accumulate.
|
|
|
|
* 5000 is approx 1.5 weeks worth of continual-use circuits. */
|
|
|
|
#define NCIRCUITS_TO_OBSERVE 5000
|
|
|
|
|
|
|
|
/** Width of the histogram bins in milliseconds */
|
2009-09-16 03:00:48 +02:00
|
|
|
#define BUILDTIME_BIN_WIDTH ((build_time_t)50)
|
2009-09-08 10:31:29 +02:00
|
|
|
|
|
|
|
/** Cuttof point on the CDF for our timeout estimation.
|
|
|
|
* TODO: This should be moved to the consensus */
|
2009-08-28 08:28:20 +02:00
|
|
|
#define BUILDTIMEOUT_QUANTILE_CUTOFF 0.8
|
|
|
|
|
2009-09-16 03:00:48 +02:00
|
|
|
/** A build_time_t is milliseconds */
|
2009-08-28 08:28:20 +02:00
|
|
|
typedef uint32_t build_time_t;
|
|
|
|
#define BUILD_TIME_MAX ((build_time_t)(INT32_MAX))
|
|
|
|
|
2009-09-17 02:14:01 +02:00
|
|
|
/** Have we received a cell in the last N seconds? */
|
|
|
|
#define NETWORK_LIVE_MULTIPLIER (RECENT_CIRCUITS/2.5)
|
2009-09-01 03:10:27 +02:00
|
|
|
|
2009-09-14 13:03:57 +02:00
|
|
|
/** Lowest allowable value for CircuitBuildTimeout */
|
|
|
|
#define BUILD_TIMEOUT_MIN_VALUE 3
|
|
|
|
|
2009-09-08 10:31:29 +02:00
|
|
|
/** Initial circuit build timeout */
|
2009-09-02 05:27:43 +02:00
|
|
|
#define BUILD_TIMEOUT_INITIAL_VALUE 60
|
|
|
|
|
2009-09-08 10:31:29 +02:00
|
|
|
/** How often in seconds should we build a test circuit */
|
2009-09-01 03:10:27 +02:00
|
|
|
#define BUILD_TIMES_TEST_FREQUENCY 60
|
|
|
|
|
2009-09-08 10:31:29 +02:00
|
|
|
/** Save state every 10 circuits */
|
|
|
|
#define BUILD_TIMES_SAVE_STATE_EVERY 10
|
2009-09-01 08:09:54 +02:00
|
|
|
|
2009-08-27 10:46:06 +02:00
|
|
|
typedef struct {
|
2009-09-16 03:00:48 +02:00
|
|
|
/** The circular array of recorded build times in milliseconds */
|
2009-08-28 08:28:20 +02:00
|
|
|
build_time_t circuit_build_times[NCIRCUITS_TO_OBSERVE];
|
2009-09-16 03:00:48 +02:00
|
|
|
/** The timestamp we last completed a TLS handshake or received a cell */
|
2009-09-01 03:10:27 +02:00
|
|
|
time_t network_last_live;
|
2009-09-16 03:00:48 +02:00
|
|
|
/** Last time we built a circuit. Used to decide to build new test circs */
|
2009-09-01 03:10:27 +02:00
|
|
|
time_t last_circ_at;
|
2009-09-16 03:00:48 +02:00
|
|
|
/** Current index in the circuit_build_times circular array */
|
2009-08-27 10:46:06 +02:00
|
|
|
int build_times_idx;
|
2009-09-16 03:00:48 +02:00
|
|
|
/** Total number of build times accumulated. Maxes at NCIRCUITS_TO_OBSERVE */
|
2009-08-27 10:46:06 +02:00
|
|
|
int total_build_times;
|
2009-09-16 03:00:48 +02:00
|
|
|
/** Number of timeouts that have happened before estimating pareto
|
|
|
|
* parameters */
|
2009-08-27 10:46:06 +02:00
|
|
|
int pre_timeouts;
|
2009-09-16 03:00:48 +02:00
|
|
|
/** "Minimum" value of our pareto distribution (actually mode) */
|
2009-08-28 08:28:20 +02:00
|
|
|
build_time_t Xm;
|
2009-09-16 13:55:43 +02:00
|
|
|
/** alpha exponent for pareto dist. */
|
2009-08-27 10:46:06 +02:00
|
|
|
double alpha;
|
2009-09-16 03:00:48 +02:00
|
|
|
/** Have we computed a timeout? */
|
2009-09-08 10:31:29 +02:00
|
|
|
int have_computed_timeout;
|
2009-09-16 03:00:48 +02:00
|
|
|
/** The value for that timeout in seconds, not milliseconds */
|
2009-09-02 05:27:43 +02:00
|
|
|
int timeout;
|
2009-08-27 10:46:06 +02:00
|
|
|
} circuit_build_times_t;
|
|
|
|
|
|
|
|
extern circuit_build_times_t circ_times;
|
|
|
|
void circuit_build_times_update_state(circuit_build_times_t *cbt,
|
2009-09-02 05:27:43 +02:00
|
|
|
or_state_t *state);
|
2009-09-07 05:14:13 +02:00
|
|
|
int circuit_build_times_parse_state(circuit_build_times_t *cbt,
|
|
|
|
or_state_t *state, char **msg);
|
2009-08-27 10:46:06 +02:00
|
|
|
void circuit_build_times_add_timeout(circuit_build_times_t *cbt);
|
|
|
|
void circuit_build_times_set_timeout(circuit_build_times_t *cbt);
|
2009-08-28 08:28:20 +02:00
|
|
|
int circuit_build_times_add_time(circuit_build_times_t *cbt,
|
|
|
|
build_time_t time);
|
2009-09-01 03:10:27 +02:00
|
|
|
void circuit_build_times_network_is_live(circuit_build_times_t *cbt);
|
|
|
|
int circuit_build_times_is_network_live(circuit_build_times_t *cbt);
|
|
|
|
int circuit_build_times_needs_circuits(circuit_build_times_t *cbt);
|
|
|
|
int circuit_build_times_needs_circuits_now(circuit_build_times_t *cbt);
|
2009-09-02 05:27:43 +02:00
|
|
|
void circuit_build_times_init(circuit_build_times_t *cbt);
|
2009-08-28 08:28:20 +02:00
|
|
|
|
|
|
|
#ifdef CIRCUIT_PRIVATE
|
|
|
|
double circuit_build_times_calculate_timeout(circuit_build_times_t *cbt,
|
|
|
|
double quantile);
|
|
|
|
build_time_t circuit_build_times_generate_sample(circuit_build_times_t *cbt,
|
|
|
|
double q_lo, double q_hi);
|
|
|
|
void circuit_build_times_initial_alpha(circuit_build_times_t *cbt,
|
|
|
|
double quantile, build_time_t time);
|
|
|
|
void circuit_build_times_update_alpha(circuit_build_times_t *cbt);
|
|
|
|
double circuit_build_times_cdf(circuit_build_times_t *cbt, double x);
|
2009-09-01 03:10:27 +02:00
|
|
|
int circuit_build_times_check_too_many_timeouts(circuit_build_times_t *cbt);
|
2009-09-02 00:40:54 +02:00
|
|
|
void circuit_build_times_add_timeout_worker(circuit_build_times_t *cbt,
|
|
|
|
double quantile_cutoff);
|
2009-09-02 05:27:43 +02:00
|
|
|
void circuitbuild_running_unit_tests(void);
|
|
|
|
void circuit_build_times_reset(circuit_build_times_t *cbt);
|
2009-08-28 08:28:20 +02:00
|
|
|
#endif
|
2009-08-26 02:13:12 +02:00
|
|
|
|
2004-05-13 09:24:49 +02:00
|
|
|
/********************************* circuitlist.c ***********************/
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2005-06-19 22:40:41 +02:00
|
|
|
circuit_t * _circuit_get_global_list(void);
|
2005-04-07 23:07:19 +02:00
|
|
|
const char *circuit_state_to_string(int state);
|
2008-09-30 00:34:22 +02:00
|
|
|
const char *circuit_purpose_to_controller_string(uint8_t purpose);
|
2006-07-23 09:37:35 +02:00
|
|
|
void circuit_dump_by_conn(connection_t *conn, int severity);
|
2008-07-23 17:58:30 +02:00
|
|
|
void circuit_set_p_circid_orconn(or_circuit_t *circ, circid_t id,
|
2006-07-26 21:07:26 +02:00
|
|
|
or_connection_t *conn);
|
2008-07-23 17:58:30 +02:00
|
|
|
void circuit_set_n_circid_orconn(circuit_t *circ, circid_t id,
|
2006-07-26 21:07:26 +02:00
|
|
|
or_connection_t *conn);
|
2008-02-20 02:01:09 +01:00
|
|
|
void circuit_set_state(circuit_t *circ, uint8_t state);
|
2004-03-02 18:48:17 +01:00
|
|
|
void circuit_close_all_marked(void);
|
2009-09-15 12:33:33 +02:00
|
|
|
int32_t circuit_initial_package_window(void);
|
2006-07-23 09:37:35 +02:00
|
|
|
origin_circuit_t *origin_circuit_new(void);
|
2008-07-23 17:58:30 +02:00
|
|
|
or_circuit_t *or_circuit_new(circid_t p_circ_id, or_connection_t *p_conn);
|
|
|
|
circuit_t *circuit_get_by_circid_orconn(circid_t circ_id,
|
2006-07-26 21:07:26 +02:00
|
|
|
or_connection_t *conn);
|
2008-07-23 17:58:30 +02:00
|
|
|
int circuit_id_in_use_on_orconn(circid_t circ_id, or_connection_t *conn);
|
2006-07-26 21:07:26 +02:00
|
|
|
circuit_t *circuit_get_by_edge_conn(edge_connection_t *conn);
|
|
|
|
void circuit_unlink_all_from_or_conn(or_connection_t *conn, int reason);
|
2006-07-28 17:11:11 +02:00
|
|
|
origin_circuit_t *circuit_get_by_global_id(uint32_t id);
|
2006-07-26 21:05:34 +02:00
|
|
|
origin_circuit_t *circuit_get_by_rend_query_and_purpose(const char *rend_query,
|
|
|
|
uint8_t purpose);
|
2006-07-26 21:05:41 +02:00
|
|
|
origin_circuit_t *circuit_get_next_by_pk_and_purpose(origin_circuit_t *start,
|
2004-05-13 09:24:49 +02:00
|
|
|
const char *digest, uint8_t purpose);
|
2006-07-23 09:37:35 +02:00
|
|
|
or_circuit_t *circuit_get_rendezvous(const char *cookie);
|
2006-07-26 21:05:41 +02:00
|
|
|
or_circuit_t *circuit_get_intro_point(const char *digest);
|
2006-07-23 09:37:35 +02:00
|
|
|
origin_circuit_t *circuit_find_to_cannibalize(uint8_t purpose,
|
2007-12-23 20:15:22 +01:00
|
|
|
extend_info_t *info, int flags);
|
2005-03-20 00:58:42 +01:00
|
|
|
void circuit_mark_all_unused_circs(void);
|
2005-10-06 00:31:21 +02:00
|
|
|
void circuit_expire_all_dirty_circs(void);
|
2006-01-05 22:23:03 +01:00
|
|
|
void _circuit_mark_for_close(circuit_t *circ, int reason,
|
|
|
|
int line, const char *file);
|
2006-10-01 22:50:11 +02:00
|
|
|
int circuit_get_cpath_len(origin_circuit_t *circ);
|
2007-04-30 13:10:45 +02:00
|
|
|
crypt_path_t *circuit_get_cpath_hop(origin_circuit_t *circ, int hopnum);
|
2007-02-05 18:42:40 +01:00
|
|
|
void circuit_get_all_pending_on_or_conn(smartlist_t *out,
|
|
|
|
or_connection_t *or_conn);
|
|
|
|
int circuit_count_pending_on_or_conn(or_connection_t *or_conn);
|
2005-04-03 07:22:33 +02:00
|
|
|
|
2006-01-05 22:23:03 +01:00
|
|
|
#define circuit_mark_for_close(c, reason) \
|
|
|
|
_circuit_mark_for_close((c), (reason), __LINE__, _SHORT_FILE_)
|
2004-03-02 18:48:17 +01:00
|
|
|
|
2004-05-13 09:24:49 +02:00
|
|
|
void assert_cpath_layer_ok(const crypt_path_t *cp);
|
|
|
|
void assert_circuit_ok(const circuit_t *c);
|
2005-02-11 02:26:47 +01:00
|
|
|
void circuit_free_all(void);
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2004-05-13 09:24:49 +02:00
|
|
|
/********************************* circuituse.c ************************/
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2004-04-13 07:20:52 +02:00
|
|
|
void circuit_expire_building(time_t now);
|
2004-12-05 08:10:08 +01:00
|
|
|
void circuit_remove_handled_ports(smartlist_t *needed_ports);
|
2006-07-26 21:07:26 +02:00
|
|
|
int circuit_stream_is_being_handled(edge_connection_t *conn, uint16_t port,
|
2005-12-14 21:40:40 +01:00
|
|
|
int min);
|
2008-09-16 00:29:47 +02:00
|
|
|
int circuit_conforms_to_options(const origin_circuit_t *circ,
|
|
|
|
const or_options_t *options);
|
2004-04-13 00:47:12 +02:00
|
|
|
void circuit_build_needed_circs(time_t now);
|
2006-07-26 21:07:26 +02:00
|
|
|
void circuit_detach_stream(circuit_t *circ, edge_connection_t *conn);
|
2006-09-15 07:30:25 +02:00
|
|
|
|
|
|
|
void reset_bandwidth_test(void);
|
|
|
|
int circuit_enough_testing_circs(void);
|
|
|
|
|
2006-07-23 09:37:35 +02:00
|
|
|
void circuit_has_opened(origin_circuit_t *circ);
|
|
|
|
void circuit_build_failed(origin_circuit_t *circ);
|
2007-12-23 20:15:22 +01:00
|
|
|
|
|
|
|
/** Flag to set when a circuit should have only a single hop. */
|
|
|
|
#define CIRCLAUNCH_ONEHOP_TUNNEL (1<<0)
|
|
|
|
/** Flag to set when a circuit needs to be built of high-uptime nodes */
|
|
|
|
#define CIRCLAUNCH_NEED_UPTIME (1<<1)
|
2009-05-28 18:26:17 +02:00
|
|
|
/** Flag to set when a circuit needs to be built of high-capacity nodes */
|
2007-12-23 20:15:22 +01:00
|
|
|
#define CIRCLAUNCH_NEED_CAPACITY (1<<2)
|
|
|
|
/** Flag to set when the last hop of a circuit doesn't need to be an
|
|
|
|
* exit node. */
|
|
|
|
#define CIRCLAUNCH_IS_INTERNAL (1<<3)
|
2006-07-23 09:37:35 +02:00
|
|
|
origin_circuit_t *circuit_launch_by_extend_info(uint8_t purpose,
|
2007-12-23 20:15:22 +01:00
|
|
|
extend_info_t *info,
|
|
|
|
int flags);
|
2006-12-13 03:49:45 +01:00
|
|
|
origin_circuit_t *circuit_launch_by_router(uint8_t purpose,
|
2007-12-23 20:15:22 +01:00
|
|
|
routerinfo_t *exit, int flags);
|
2004-08-18 10:51:04 +02:00
|
|
|
void circuit_reset_failure_count(int timeout);
|
2006-07-26 21:07:26 +02:00
|
|
|
int connection_ap_handshake_attach_chosen_circuit(edge_connection_t *conn,
|
2007-04-30 13:10:45 +02:00
|
|
|
origin_circuit_t *circ,
|
|
|
|
crypt_path_t *cpath);
|
2006-07-26 21:07:26 +02:00
|
|
|
int connection_ap_handshake_attach_circuit(edge_connection_t *conn);
|
2004-05-13 09:24:49 +02:00
|
|
|
|
2002-06-27 00:45:49 +02:00
|
|
|
/********************************* command.c ***************************/
|
|
|
|
|
2006-07-26 21:07:26 +02:00
|
|
|
void command_process_cell(cell_t *cell, or_connection_t *conn);
|
2007-11-05 22:46:35 +01:00
|
|
|
void command_process_var_cell(var_cell_t *cell, or_connection_t *conn);
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2005-12-31 12:52:13 +01:00
|
|
|
extern uint64_t stats_n_padding_cells_processed;
|
|
|
|
extern uint64_t stats_n_create_cells_processed;
|
|
|
|
extern uint64_t stats_n_created_cells_processed;
|
|
|
|
extern uint64_t stats_n_relay_cells_processed;
|
|
|
|
extern uint64_t stats_n_destroy_cells_processed;
|
2003-10-02 22:00:38 +02:00
|
|
|
|
2002-06-27 00:45:49 +02:00
|
|
|
/********************************* config.c ***************************/
|
|
|
|
|
2008-03-18 03:39:34 +01:00
|
|
|
/** An error from options_trial_assign() or options_init_from_string(). */
|
2008-03-13 16:11:56 +01:00
|
|
|
typedef enum setopt_err_t {
|
|
|
|
SETOPT_OK = 0,
|
|
|
|
SETOPT_ERR_MISC = -1,
|
|
|
|
SETOPT_ERR_PARSE = -2,
|
|
|
|
SETOPT_ERR_TRANSITION = -3,
|
|
|
|
SETOPT_ERR_SETTING = -4,
|
|
|
|
} setopt_err_t;
|
|
|
|
|
2008-12-07 02:21:19 +01:00
|
|
|
const char *get_dirportfrontpage(void);
|
2004-11-06 06:18:11 +01:00
|
|
|
or_options_t *get_options(void);
|
2006-03-26 08:51:26 +02:00
|
|
|
int set_options(or_options_t *new_val, char **msg);
|
2005-02-11 02:26:47 +01:00
|
|
|
void config_free_all(void);
|
2005-05-03 12:04:08 +02:00
|
|
|
const char *safe_str(const char *address);
|
2006-03-05 10:50:26 +01:00
|
|
|
const char *escaped_safe_str(const char *address);
|
2007-05-22 17:48:46 +02:00
|
|
|
const char *get_version(void);
|
2004-11-06 06:18:11 +01:00
|
|
|
|
2008-01-02 07:59:12 +01:00
|
|
|
int config_get_lines(const char *string, config_line_t **result);
|
2005-07-22 23:12:10 +02:00
|
|
|
void config_free_lines(config_line_t *front);
|
2008-12-29 05:01:58 +01:00
|
|
|
setopt_err_t options_trial_assign(config_line_t *list, int use_defaults,
|
|
|
|
int clear_first, char **msg);
|
2006-07-15 22:26:05 +02:00
|
|
|
int resolve_my_address(int warn_severity, or_options_t *options,
|
|
|
|
uint32_t *addr, char **hostname_out);
|
2008-08-05 22:08:19 +02:00
|
|
|
int is_local_addr(const tor_addr_t *addr) ATTR_PURE;
|
2004-11-06 06:18:11 +01:00
|
|
|
void options_init(or_options_t *options);
|
2005-07-23 03:58:05 +02:00
|
|
|
int options_init_from_torrc(int argc, char **argv);
|
2008-03-13 16:11:56 +01:00
|
|
|
setopt_err_t options_init_from_string(const char *cf,
|
|
|
|
int command, const char *command_arg, char **msg);
|
2005-07-23 03:58:05 +02:00
|
|
|
int option_is_recognized(const char *key);
|
|
|
|
const char *option_get_canonical_name(const char *key);
|
|
|
|
config_line_t *option_get_assignment(or_options_t *options,
|
|
|
|
const char *key);
|
|
|
|
int options_save_current(void);
|
2005-08-10 20:05:20 +02:00
|
|
|
const char *get_torrc_fname(void);
|
2008-09-01 22:06:26 +02:00
|
|
|
char *options_get_datadir_fname2_suffix(or_options_t *options,
|
|
|
|
const char *sub1, const char *sub2,
|
|
|
|
const char *suffix);
|
|
|
|
#define get_datadir_fname2_suffix(sub1, sub2, suffix) \
|
|
|
|
options_get_datadir_fname2_suffix(get_options(), (sub1), (sub2), (suffix))
|
2007-12-19 05:18:28 +01:00
|
|
|
/** Return a newly allocated string containing datadir/sub1. See
|
|
|
|
* get_datadir_fname2_suffix. */
|
2007-10-17 18:55:44 +02:00
|
|
|
#define get_datadir_fname(sub1) get_datadir_fname2_suffix((sub1), NULL, NULL)
|
2007-12-19 05:18:28 +01:00
|
|
|
/** Return a newly allocated string containing datadir/sub1/sub2. See
|
|
|
|
* get_datadir_fname2_suffix. */
|
2007-10-17 18:55:44 +02:00
|
|
|
#define get_datadir_fname2(sub1,sub2) \
|
|
|
|
get_datadir_fname2_suffix((sub1), (sub2), NULL)
|
2007-12-19 05:18:28 +01:00
|
|
|
/** Return a newly allocated string containing datadir/sub1suffix. See
|
|
|
|
* get_datadir_fname2_suffix. */
|
2007-10-17 18:55:44 +02:00
|
|
|
#define get_datadir_fname_suffix(sub1, suffix) \
|
|
|
|
get_datadir_fname2_suffix((sub1), NULL, (suffix))
|
2002-07-03 18:31:22 +02:00
|
|
|
|
2005-07-28 21:01:48 +02:00
|
|
|
or_state_t *get_or_state(void);
|
2006-12-07 21:11:30 +01:00
|
|
|
int or_state_save(time_t now);
|
2005-07-28 21:01:48 +02:00
|
|
|
|
2008-09-25 23:06:32 +02:00
|
|
|
int options_need_geoip_info(or_options_t *options, const char **reason_out);
|
2006-12-08 05:39:13 +01:00
|
|
|
int getinfo_helper_config(control_connection_t *conn,
|
|
|
|
const char *question, char **answer);
|
2005-08-04 21:56:41 +02:00
|
|
|
|
2009-05-08 18:35:36 +02:00
|
|
|
const char *tor_get_digests(void);
|
2009-07-29 00:34:35 +02:00
|
|
|
uint32_t get_effective_bwrate(or_options_t *options);
|
|
|
|
uint32_t get_effective_bwburst(or_options_t *options);
|
2009-05-08 18:35:36 +02:00
|
|
|
|
2007-04-11 15:18:25 +02:00
|
|
|
#ifdef CONFIG_PRIVATE
|
|
|
|
/* Used only by config.c and test.c */
|
|
|
|
or_options_t *options_new(void);
|
|
|
|
#endif
|
|
|
|
|
2002-06-27 00:45:49 +02:00
|
|
|
/********************************* connection.c ***************************/
|
|
|
|
|
2005-04-07 22:25:22 +02:00
|
|
|
const char *conn_type_to_string(int type);
|
|
|
|
const char *conn_state_to_string(int type, int state);
|
2004-03-11 07:19:08 +01:00
|
|
|
|
2008-09-06 00:09:44 +02:00
|
|
|
dir_connection_t *dir_connection_new(int socket_family);
|
|
|
|
or_connection_t *or_connection_new(int socket_family);
|
|
|
|
edge_connection_t *edge_connection_new(int type, int socket_family);
|
|
|
|
control_connection_t *control_connection_new(int socket_family);
|
2007-06-08 23:14:58 +02:00
|
|
|
connection_t *connection_new(int type, int socket_family);
|
2008-09-06 00:09:44 +02:00
|
|
|
|
2007-04-21 19:26:12 +02:00
|
|
|
void connection_link_connections(connection_t *conn_a, connection_t *conn_b);
|
2002-06-27 00:45:49 +02:00
|
|
|
void connection_free(connection_t *conn);
|
2004-01-06 08:53:40 +01:00
|
|
|
void connection_free_all(void);
|
2004-05-12 22:36:44 +02:00
|
|
|
void connection_about_to_close_connection(connection_t *conn);
|
2004-02-28 20:14:11 +01:00
|
|
|
void connection_close_immediate(connection_t *conn);
|
2005-04-03 07:22:33 +02:00
|
|
|
void _connection_mark_for_close(connection_t *conn,int line, const char *file);
|
|
|
|
|
|
|
|
#define connection_mark_for_close(c) \
|
|
|
|
_connection_mark_for_close((c), __LINE__, _SHORT_FILE_)
|
2004-02-27 23:00:26 +01:00
|
|
|
|
2004-03-03 06:08:01 +01:00
|
|
|
void connection_expire_held_open(void);
|
|
|
|
|
2008-08-05 22:08:19 +02:00
|
|
|
int connection_connect(connection_t *conn, const char *address,
|
|
|
|
const tor_addr_t *addr,
|
2008-06-11 03:14:23 +02:00
|
|
|
uint16_t port, int *socket_error);
|
2009-06-19 01:59:18 +02:00
|
|
|
|
|
|
|
int connection_proxy_connect(connection_t *conn, int type);
|
|
|
|
int connection_read_proxy_handshake(connection_t *conn);
|
|
|
|
|
2007-06-04 18:54:42 +02:00
|
|
|
int retry_all_listeners(smartlist_t *replaced_conns,
|
2005-09-14 04:36:29 +02:00
|
|
|
smartlist_t *new_conns);
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2008-02-24 23:10:08 +01:00
|
|
|
ssize_t connection_bucket_write_limit(connection_t *conn, time_t now);
|
2007-01-26 09:01:29 +01:00
|
|
|
int global_write_bucket_low(connection_t *conn, size_t attempt, int priority);
|
2004-03-14 18:06:29 +01:00
|
|
|
void connection_bucket_init(void);
|
2007-07-30 03:32:12 +02:00
|
|
|
void connection_bucket_refill(int seconds_elapsed, time_t now);
|
2004-03-14 18:06:29 +01:00
|
|
|
|
2003-09-05 08:04:03 +02:00
|
|
|
int connection_handle_read(connection_t *conn);
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2004-10-14 04:47:09 +02:00
|
|
|
int connection_fetch_from_buf(char *string, size_t len, connection_t *conn);
|
2003-09-16 07:41:49 +02:00
|
|
|
|
2002-07-18 08:37:58 +02:00
|
|
|
int connection_wants_to_flush(connection_t *conn);
|
2003-09-16 07:41:49 +02:00
|
|
|
int connection_outbuf_too_full(connection_t *conn);
|
2006-12-29 06:06:47 +01:00
|
|
|
int connection_handle_write(connection_t *conn, int force);
|
2006-12-29 06:07:04 +01:00
|
|
|
void _connection_write_to_buf_impl(const char *string, size_t len,
|
|
|
|
connection_t *conn, int zlib);
|
|
|
|
static void connection_write_to_buf(const char *string, size_t len,
|
|
|
|
connection_t *conn);
|
|
|
|
static void connection_write_to_buf_zlib(const char *string, size_t len,
|
|
|
|
dir_connection_t *conn, int done);
|
|
|
|
static INLINE void
|
|
|
|
connection_write_to_buf(const char *string, size_t len, connection_t *conn)
|
|
|
|
{
|
|
|
|
_connection_write_to_buf_impl(string, len, conn, 0);
|
|
|
|
}
|
|
|
|
static INLINE void
|
|
|
|
connection_write_to_buf_zlib(const char *string, size_t len,
|
|
|
|
dir_connection_t *conn, int done)
|
|
|
|
{
|
|
|
|
_connection_write_to_buf_impl(string, len, TO_CONN(conn), done ? -1 : 1);
|
|
|
|
}
|
Implemented link padding and receiver token buckets
Each socket reads at most 'bandwidth' bytes per second sustained, but
can handle bursts of up to 10*bandwidth bytes.
Cells are now sent out at evenly-spaced intervals, with padding sent
out otherwise. Set Linkpadding=0 in the rc file to send cells as soon
as they're available (and to never send padding cells).
Added license/copyrights statements at the top of most files.
router->min and router->max have been merged into a single 'bandwidth'
value. We should make the routerinfo_t reflect this (want to do that,
Mat?)
As the bandwidth increases, and we want to stop sleeping more and more
frequently to send a single cell, cpu usage goes up. At 128kB/s we're
pretty much calling poll with a timeout of 1ms or even 0ms. The current
code takes a timeout of 0-9ms and makes it 10ms. prepare_for_poll()
handles everything that should have happened in the past, so as long as
our buffers don't get too full in that 10ms, we're ok.
Speaking of too full, if you run three servers at 100kB/s with -l debug,
it spends too much time printing debugging messages to be able to keep
up with the cells. The outbuf ultimately fills up and it kills that
connection. If you run with -l err, it works fine up through 500kB/s and
probably beyond. Down the road we'll want to teach it to recognize when
an outbuf is getting full, and back off.
svn:r50
2002-07-16 03:12:15 +02:00
|
|
|
|
2008-08-15 15:55:01 +02:00
|
|
|
connection_t *connection_get_by_global_id(uint64_t id);
|
2003-09-30 21:06:22 +02:00
|
|
|
|
|
|
|
connection_t *connection_get_by_type(int type);
|
2005-09-12 08:56:42 +02:00
|
|
|
connection_t *connection_get_by_type_purpose(int type, int purpose);
|
2008-08-05 22:08:19 +02:00
|
|
|
connection_t *connection_get_by_type_addr_port_purpose(int type,
|
|
|
|
const tor_addr_t *addr,
|
2005-12-14 21:40:40 +01:00
|
|
|
uint16_t port, int purpose);
|
2003-09-30 21:06:22 +02:00
|
|
|
connection_t *connection_get_by_type_state(int type, int state);
|
2005-12-14 21:40:40 +01:00
|
|
|
connection_t *connection_get_by_type_state_rendquery(int type, int state,
|
2009-05-03 01:04:25 +02:00
|
|
|
const char *rendquery);
|
2003-09-30 21:06:22 +02:00
|
|
|
|
2003-05-28 04:03:25 +02:00
|
|
|
#define connection_speaks_cells(conn) ((conn)->type == CONN_TYPE_OR)
|
2002-09-22 00:41:48 +02:00
|
|
|
int connection_is_listener(connection_t *conn);
|
Implemented link padding and receiver token buckets
Each socket reads at most 'bandwidth' bytes per second sustained, but
can handle bursts of up to 10*bandwidth bytes.
Cells are now sent out at evenly-spaced intervals, with padding sent
out otherwise. Set Linkpadding=0 in the rc file to send cells as soon
as they're available (and to never send padding cells).
Added license/copyrights statements at the top of most files.
router->min and router->max have been merged into a single 'bandwidth'
value. We should make the routerinfo_t reflect this (want to do that,
Mat?)
As the bandwidth increases, and we want to stop sleeping more and more
frequently to send a single cell, cpu usage goes up. At 128kB/s we're
pretty much calling poll with a timeout of 1ms or even 0ms. The current
code takes a timeout of 0-9ms and makes it 10ms. prepare_for_poll()
handles everything that should have happened in the past, so as long as
our buffers don't get too full in that 10ms, we're ok.
Speaking of too full, if you run three servers at 100kB/s with -l debug,
it spends too much time printing debugging messages to be able to keep
up with the cells. The outbuf ultimately fills up and it kills that
connection. If you run with -l err, it works fine up through 500kB/s and
probably beyond. Down the road we'll want to teach it to recognize when
an outbuf is getting full, and back off.
svn:r50
2002-07-16 03:12:15 +02:00
|
|
|
int connection_state_is_open(connection_t *conn);
|
2004-05-12 21:17:09 +02:00
|
|
|
int connection_state_is_connecting(connection_t *conn);
|
Implemented link padding and receiver token buckets
Each socket reads at most 'bandwidth' bytes per second sustained, but
can handle bursts of up to 10*bandwidth bytes.
Cells are now sent out at evenly-spaced intervals, with padding sent
out otherwise. Set Linkpadding=0 in the rc file to send cells as soon
as they're available (and to never send padding cells).
Added license/copyrights statements at the top of most files.
router->min and router->max have been merged into a single 'bandwidth'
value. We should make the routerinfo_t reflect this (want to do that,
Mat?)
As the bandwidth increases, and we want to stop sleeping more and more
frequently to send a single cell, cpu usage goes up. At 128kB/s we're
pretty much calling poll with a timeout of 1ms or even 0ms. The current
code takes a timeout of 0-9ms and makes it 10ms. prepare_for_poll()
handles everything that should have happened in the past, so as long as
our buffers don't get too full in that 10ms, we're ok.
Speaking of too full, if you run three servers at 100kB/s with -l debug,
it spends too much time printing debugging messages to be able to keep
up with the cells. The outbuf ultimately fills up and it kills that
connection. If you run with -l err, it works fine up through 500kB/s and
probably beyond. Down the road we'll want to teach it to recognize when
an outbuf is getting full, and back off.
svn:r50
2002-07-16 03:12:15 +02:00
|
|
|
|
2005-05-20 10:51:45 +02:00
|
|
|
char *alloc_http_authenticator(const char *authenticator);
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2003-09-16 21:36:19 +02:00
|
|
|
void assert_connection_ok(connection_t *conn, time_t now);
|
2006-07-26 21:07:26 +02:00
|
|
|
int connection_or_nonopen_was_started_here(or_connection_t *conn);
|
2007-04-23 05:04:46 +02:00
|
|
|
void connection_dump_buffer_mem_stats(int severity);
|
2007-10-14 02:13:06 +02:00
|
|
|
void remove_file_if_very_old(const char *fname, time_t now);
|
2003-09-16 21:36:19 +02:00
|
|
|
|
2005-12-14 21:40:40 +01:00
|
|
|
/********************************* connection_edge.c *************************/
|
2003-04-12 00:11:11 +02:00
|
|
|
|
2005-04-03 00:11:24 +02:00
|
|
|
#define connection_mark_unattached_ap(conn, endreason) \
|
2005-04-03 07:22:33 +02:00
|
|
|
_connection_mark_unattached_ap((conn), (endreason), __LINE__, _SHORT_FILE_)
|
2005-04-03 00:11:24 +02:00
|
|
|
|
2006-07-26 21:07:26 +02:00
|
|
|
void _connection_mark_unattached_ap(edge_connection_t *conn, int endreason,
|
2005-04-03 00:11:24 +02:00
|
|
|
int line, const char *file);
|
2006-07-26 21:07:26 +02:00
|
|
|
int connection_edge_reached_eof(edge_connection_t *conn);
|
2006-07-26 21:07:37 +02:00
|
|
|
int connection_edge_process_inbuf(edge_connection_t *conn,
|
|
|
|
int package_partial);
|
2008-07-23 17:58:30 +02:00
|
|
|
int connection_edge_destroy(circid_t circ_id, edge_connection_t *conn);
|
2008-12-12 21:30:42 +01:00
|
|
|
int connection_edge_end(edge_connection_t *conn, uint8_t reason);
|
2007-03-24 16:57:51 +01:00
|
|
|
int connection_edge_end_errno(edge_connection_t *conn);
|
2006-07-26 21:07:26 +02:00
|
|
|
int connection_edge_finished_flushing(edge_connection_t *conn);
|
|
|
|
int connection_edge_finished_connecting(edge_connection_t *conn);
|
2003-04-12 00:11:11 +02:00
|
|
|
|
2007-03-24 16:58:11 +01:00
|
|
|
int connection_ap_handshake_send_begin(edge_connection_t *ap_conn);
|
|
|
|
int connection_ap_handshake_send_resolve(edge_connection_t *ap_conn);
|
2004-04-03 01:54:48 +02:00
|
|
|
|
2007-06-09 07:17:33 +02:00
|
|
|
edge_connection_t *connection_ap_make_link(char *address, uint16_t port,
|
2007-10-28 09:16:19 +01:00
|
|
|
const char *digest,
|
|
|
|
int use_begindir, int want_onehop);
|
2006-07-26 21:07:26 +02:00
|
|
|
void connection_ap_handshake_socks_reply(edge_connection_t *conn, char *reply,
|
2005-03-17 13:38:37 +01:00
|
|
|
size_t replylen,
|
2006-10-20 19:54:43 +02:00
|
|
|
int endreason);
|
2006-07-26 21:07:26 +02:00
|
|
|
void connection_ap_handshake_socks_resolved(edge_connection_t *conn,
|
2004-06-17 20:13:09 +02:00
|
|
|
int answer_type,
|
2004-10-14 04:47:09 +02:00
|
|
|
size_t answer_len,
|
2005-09-02 22:37:31 +02:00
|
|
|
const char *answer,
|
2007-07-10 19:14:51 +02:00
|
|
|
int ttl,
|
|
|
|
time_t expires);
|
2004-03-27 06:45:52 +01:00
|
|
|
|
2004-05-13 09:24:49 +02:00
|
|
|
int connection_exit_begin_conn(cell_t *cell, circuit_t *circ);
|
2006-07-23 09:37:35 +02:00
|
|
|
int connection_exit_begin_resolve(cell_t *cell, or_circuit_t *circ);
|
2006-07-26 21:07:26 +02:00
|
|
|
void connection_exit_connect(edge_connection_t *conn);
|
|
|
|
int connection_edge_is_rendezvous_stream(edge_connection_t *conn);
|
|
|
|
int connection_ap_can_use_exit(edge_connection_t *conn, routerinfo_t *exit);
|
2004-01-20 10:21:46 +01:00
|
|
|
void connection_ap_expire_beginning(void);
|
2003-11-11 03:41:31 +01:00
|
|
|
void connection_ap_attach_pending(void);
|
2008-06-20 05:13:16 +02:00
|
|
|
void connection_ap_fail_onehop(const char *failed_digest,
|
|
|
|
cpath_build_state_t *build_state);
|
2006-10-01 08:41:13 +02:00
|
|
|
void circuit_discard_optional_exit_enclaves(extend_info_t *info);
|
2006-07-26 21:07:37 +02:00
|
|
|
int connection_ap_detach_retriable(edge_connection_t *conn,
|
2006-10-20 19:54:43 +02:00
|
|
|
origin_circuit_t *circ,
|
|
|
|
int reason);
|
2006-11-14 01:06:02 +01:00
|
|
|
int connection_ap_process_transparent(edge_connection_t *conn);
|
2003-11-11 03:41:31 +01:00
|
|
|
|
2007-01-11 17:02:39 +01:00
|
|
|
int address_is_invalid_destination(const char *address, int client);
|
2006-12-29 06:51:50 +01:00
|
|
|
|
2005-02-22 01:53:08 +01:00
|
|
|
void addressmap_init(void);
|
|
|
|
void addressmap_clean(time_t now);
|
2005-03-11 22:39:39 +01:00
|
|
|
void addressmap_clear_configured(void);
|
|
|
|
void addressmap_clear_transient(void);
|
2005-02-22 01:53:08 +01:00
|
|
|
void addressmap_free_all(void);
|
2007-07-10 19:14:51 +02:00
|
|
|
int addressmap_rewrite(char *address, size_t maxlen, time_t *expires_out);
|
2008-09-29 16:53:53 +02:00
|
|
|
int addressmap_have_mapping(const char *address, int update_timeout);
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Enumerates possible origins of a client-side address mapping. */
|
2008-02-21 19:45:11 +01:00
|
|
|
typedef enum {
|
2008-12-17 18:20:31 +01:00
|
|
|
/** We're remapping this address because the controller told us to. */
|
|
|
|
ADDRMAPSRC_CONTROLLER,
|
|
|
|
/** We're remapping this address because our configuration (via torrc, the
|
|
|
|
* command line, or a SETCONF command) told us to. */
|
|
|
|
ADDRMAPSRC_TORRC,
|
|
|
|
/** We're remapping this address because we have TrackHostExit configured,
|
|
|
|
* and we want to remember to use the same exit next time. */
|
|
|
|
ADDRMAPSRC_TRACKEXIT,
|
|
|
|
/** We're remapping this address because we got a DNS resolution from a
|
|
|
|
* Tor server that told us what its value was. */
|
2008-02-21 19:45:11 +01:00
|
|
|
ADDRMAPSRC_DNS,
|
|
|
|
} addressmap_entry_source_t;
|
2005-12-14 21:40:40 +01:00
|
|
|
void addressmap_register(const char *address, char *new_address,
|
2008-02-21 19:45:11 +01:00
|
|
|
time_t expires, addressmap_entry_source_t source);
|
2006-04-18 05:36:28 +02:00
|
|
|
int parse_virtual_addr_network(const char *val, int validate_only,
|
2006-04-18 05:51:18 +02:00
|
|
|
char **msg);
|
2005-02-22 01:53:08 +01:00
|
|
|
int client_dns_incr_failures(const char *address);
|
2005-08-15 05:35:15 +02:00
|
|
|
void client_dns_clear_failures(const char *address);
|
2005-12-14 21:40:40 +01:00
|
|
|
void client_dns_set_addressmap(const char *address, uint32_t val,
|
|
|
|
const char *exitname, int ttl);
|
2005-03-23 09:40:11 +01:00
|
|
|
const char *addressmap_register_virtual_address(int type, char *new_address);
|
2005-12-14 21:40:40 +01:00
|
|
|
void addressmap_get_mappings(smartlist_t *sl, time_t min_expires,
|
2007-07-16 18:58:11 +02:00
|
|
|
time_t max_expires, int want_expiry);
|
2006-07-26 21:07:26 +02:00
|
|
|
int connection_ap_handshake_rewrite_and_attach(edge_connection_t *conn,
|
2007-04-30 13:10:45 +02:00
|
|
|
origin_circuit_t *circ,
|
|
|
|
crypt_path_t *cpath);
|
2007-05-24 22:31:30 +02:00
|
|
|
int hostname_is_noconnect_address(const char *address);
|
2005-02-22 01:53:08 +01:00
|
|
|
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Possible return values for parse_extended_hostname. */
|
2004-11-30 04:44:10 +01:00
|
|
|
typedef enum hostname_type_t {
|
2005-06-07 20:01:46 +02:00
|
|
|
NORMAL_HOSTNAME, ONION_HOSTNAME, EXIT_HOSTNAME, BAD_HOSTNAME
|
2004-11-30 04:44:10 +01:00
|
|
|
} hostname_type_t;
|
2009-08-08 01:26:41 +02:00
|
|
|
hostname_type_t parse_extended_hostname(char *address, int allowdotexit);
|
2003-11-16 18:00:02 +01:00
|
|
|
|
2008-08-06 18:32:17 +02:00
|
|
|
#if defined(HAVE_NET_IF_H) && defined(HAVE_NET_PFVAR_H)
|
|
|
|
int get_pf_socket(void);
|
|
|
|
#endif
|
|
|
|
|
Integrated onion proxy into or/
The 'or' process can now be told (by the global_role variable) what
roles this server should play -- connect to all ORs, listen for ORs,
listen for OPs, listen for APs, or any combination.
* everything in /src/op/ is now obsolete.
* connection_ap.c now handles all interactions with application proxies
* "port" is now or_port, op_port, ap_port. But routers are still always
referenced (say, in conn_get_by_addr_port()) by addr / or_port. We
should make routers.c actually read these new ports (currently I've
kludged it so op_port = or_port+10, ap_port=or_port+20)
* circuits currently know if they're at the beginning of the path because
circ->cpath is set. They use this instead for crypts (both ways),
if it's set.
* I still obey the "send a 0 back to the AP when you're ready" protocol,
but I think we should phase it out. I can simply not read from the AP
socket until I'm ready.
I need to do a lot of cleanup work here, but the code appears to work, so
now's a good time for a checkin.
svn:r22
2002-07-02 11:36:58 +02:00
|
|
|
/********************************* connection_or.c ***************************/
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2006-07-26 21:07:26 +02:00
|
|
|
void connection_or_remove_from_identity_map(or_connection_t *conn);
|
2005-12-05 20:15:27 +01:00
|
|
|
void connection_or_clear_identity_map(void);
|
2008-12-24 03:38:04 +01:00
|
|
|
or_connection_t *connection_or_get_for_extend(const char *digest,
|
|
|
|
const tor_addr_t *target_addr,
|
|
|
|
const char **msg_out,
|
|
|
|
int *launch_out);
|
|
|
|
void connection_or_set_bad_connections(void);
|
2005-11-30 04:01:16 +01:00
|
|
|
|
2006-07-26 21:07:26 +02:00
|
|
|
int connection_or_reached_eof(or_connection_t *conn);
|
|
|
|
int connection_or_process_inbuf(or_connection_t *conn);
|
2007-01-27 09:55:06 +01:00
|
|
|
int connection_or_flushed_some(or_connection_t *conn);
|
2006-07-26 21:07:26 +02:00
|
|
|
int connection_or_finished_flushing(or_connection_t *conn);
|
|
|
|
int connection_or_finished_connecting(or_connection_t *conn);
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2008-09-09 08:25:39 +02:00
|
|
|
void connection_or_connect_failed(or_connection_t *conn,
|
|
|
|
int reason, const char *msg);
|
2008-08-05 22:08:19 +02:00
|
|
|
or_connection_t *connection_or_connect(const tor_addr_t *addr, uint16_t port,
|
|
|
|
const char *id_digest);
|
Integrated onion proxy into or/
The 'or' process can now be told (by the global_role variable) what
roles this server should play -- connect to all ORs, listen for ORs,
listen for OPs, listen for APs, or any combination.
* everything in /src/op/ is now obsolete.
* connection_ap.c now handles all interactions with application proxies
* "port" is now or_port, op_port, ap_port. But routers are still always
referenced (say, in conn_get_by_addr_port()) by addr / or_port. We
should make routers.c actually read these new ports (currently I've
kludged it so op_port = or_port+10, ap_port=or_port+20)
* circuits currently know if they're at the beginning of the path because
circ->cpath is set. They use this instead for crypts (both ways),
if it's set.
* I still obey the "send a 0 back to the AP when you're ready" protocol,
but I think we should phase it out. I can simply not read from the AP
socket until I'm ready.
I need to do a lot of cleanup work here, but the code appears to work, so
now's a good time for a checkin.
svn:r22
2002-07-02 11:36:58 +02:00
|
|
|
|
2006-07-26 21:07:26 +02:00
|
|
|
int connection_tls_start_handshake(or_connection_t *conn, int receiving);
|
|
|
|
int connection_tls_continue_handshake(or_connection_t *conn);
|
2003-09-30 20:45:55 +02:00
|
|
|
|
2007-11-05 19:15:44 +01:00
|
|
|
void or_handshake_state_free(or_handshake_state_t *state);
|
2007-10-30 22:46:02 +01:00
|
|
|
int connection_or_set_state_open(or_connection_t *conn);
|
2006-07-26 21:07:37 +02:00
|
|
|
void connection_or_write_cell_to_buf(const cell_t *cell,
|
|
|
|
or_connection_t *conn);
|
2007-11-06 00:34:39 +01:00
|
|
|
void connection_or_write_var_cell_to_buf(const var_cell_t *cell,
|
|
|
|
or_connection_t *conn);
|
2008-07-23 17:58:30 +02:00
|
|
|
int connection_or_send_destroy(circid_t circ_id, or_connection_t *conn,
|
2006-01-05 22:23:03 +01:00
|
|
|
int reason);
|
2007-10-30 22:46:02 +01:00
|
|
|
int connection_or_send_netinfo(or_connection_t *conn);
|
2007-11-05 20:19:46 +01:00
|
|
|
int connection_or_send_cert(or_connection_t *conn);
|
2007-11-05 19:15:56 +01:00
|
|
|
int connection_or_send_link_auth(or_connection_t *conn);
|
|
|
|
int connection_or_compute_link_auth_hmac(or_connection_t *conn,
|
|
|
|
char *hmac_out);
|
2008-01-13 01:20:47 +01:00
|
|
|
int is_or_protocol_version_known(uint16_t version);
|
2004-10-13 03:13:37 +02:00
|
|
|
|
2007-04-10 01:15:46 +02:00
|
|
|
void cell_pack(packed_cell_t *dest, const cell_t *src);
|
2007-11-06 00:34:39 +01:00
|
|
|
void var_cell_pack_header(const var_cell_t *cell, char *hdr_out);
|
|
|
|
var_cell_t *var_cell_new(uint16_t payload_len);
|
2007-11-05 22:46:35 +01:00
|
|
|
void var_cell_free(var_cell_t *cell);
|
2007-04-10 01:15:46 +02:00
|
|
|
|
2004-11-03 02:32:26 +01:00
|
|
|
/********************************* control.c ***************************/
|
|
|
|
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Used to indicate the type of a circuit event passed to the controller.
|
|
|
|
* The various types are defined in control-spec.txt */
|
2004-11-03 19:33:07 +01:00
|
|
|
typedef enum circuit_status_event_t {
|
|
|
|
CIRC_EVENT_LAUNCHED = 0,
|
|
|
|
CIRC_EVENT_BUILT = 1,
|
|
|
|
CIRC_EVENT_EXTENDED = 2,
|
|
|
|
CIRC_EVENT_FAILED = 3,
|
|
|
|
CIRC_EVENT_CLOSED = 4,
|
|
|
|
} circuit_status_event_t;
|
|
|
|
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Used to indicate the type of a stream event passed to the controller.
|
|
|
|
* The various types are defined in control-spec.txt */
|
2004-11-03 19:33:07 +01:00
|
|
|
typedef enum stream_status_event_t {
|
|
|
|
STREAM_EVENT_SENT_CONNECT = 0,
|
|
|
|
STREAM_EVENT_SENT_RESOLVE = 1,
|
|
|
|
STREAM_EVENT_SUCCEEDED = 2,
|
|
|
|
STREAM_EVENT_FAILED = 3,
|
2005-03-02 23:29:58 +01:00
|
|
|
STREAM_EVENT_CLOSED = 4,
|
2005-03-12 05:22:01 +01:00
|
|
|
STREAM_EVENT_NEW = 5,
|
2005-03-14 04:12:59 +01:00
|
|
|
STREAM_EVENT_NEW_RESOLVE = 6,
|
2007-02-05 20:15:13 +01:00
|
|
|
STREAM_EVENT_FAILED_RETRIABLE = 7,
|
|
|
|
STREAM_EVENT_REMAP = 8
|
2004-11-03 19:33:07 +01:00
|
|
|
} stream_status_event_t;
|
|
|
|
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Used to indicate the type of an OR connection event passed to the
|
|
|
|
* controller. The various types are defined in control-spec.txt */
|
2004-11-03 19:33:07 +01:00
|
|
|
typedef enum or_conn_status_event_t {
|
|
|
|
OR_CONN_EVENT_LAUNCHED = 0,
|
|
|
|
OR_CONN_EVENT_CONNECTED = 1,
|
|
|
|
OR_CONN_EVENT_FAILED = 2,
|
|
|
|
OR_CONN_EVENT_CLOSED = 3,
|
2006-03-08 23:29:08 +01:00
|
|
|
OR_CONN_EVENT_NEW = 4,
|
2004-11-03 19:33:07 +01:00
|
|
|
} or_conn_status_event_t;
|
|
|
|
|
2005-08-07 21:20:55 +02:00
|
|
|
void control_update_global_event_mask(void);
|
2005-07-13 07:14:42 +02:00
|
|
|
void control_adjust_event_log_severity(void);
|
|
|
|
|
2005-09-30 22:04:55 +02:00
|
|
|
/** Execute the statement <b>stmt</b>, which may log events concerning the
|
|
|
|
* connection <b>conn</b>. To prevent infinite loops, disable log messages
|
2006-03-18 10:29:05 +01:00
|
|
|
* being sent to controllers if <b>conn</b> is a control connection.
|
2005-09-30 22:04:55 +02:00
|
|
|
*
|
|
|
|
* Stmt must not contain any return or goto statements.
|
|
|
|
*/
|
2005-07-13 07:14:42 +02:00
|
|
|
#define CONN_LOG_PROTECT(conn, stmt) \
|
2007-06-17 20:22:39 +02:00
|
|
|
STMT_BEGIN \
|
2005-07-13 07:14:42 +02:00
|
|
|
int _log_conn_is_control = (conn && conn->type == CONN_TYPE_CONTROL); \
|
|
|
|
if (_log_conn_is_control) \
|
|
|
|
disable_control_logging(); \
|
2007-06-17 20:22:39 +02:00
|
|
|
STMT_BEGIN stmt; STMT_END; \
|
2005-07-13 07:14:42 +02:00
|
|
|
if (_log_conn_is_control) \
|
|
|
|
enable_control_logging(); \
|
2007-06-17 20:22:39 +02:00
|
|
|
STMT_END
|
2005-07-13 07:14:42 +02:00
|
|
|
|
2005-09-30 22:04:55 +02:00
|
|
|
/** Log information about the connection <b>conn</b>, protecting it as with
|
|
|
|
* CONN_LOG_PROTECT. Example:
|
|
|
|
*
|
|
|
|
* LOG_FN_CONN(conn, (LOG_DEBUG, "Socket %d wants to write", conn->s));
|
|
|
|
**/
|
2005-07-13 07:14:42 +02:00
|
|
|
#define LOG_FN_CONN(conn, args) \
|
|
|
|
CONN_LOG_PROTECT(conn, log_fn args)
|
|
|
|
|
2006-07-26 21:07:26 +02:00
|
|
|
int connection_control_finished_flushing(control_connection_t *conn);
|
|
|
|
int connection_control_reached_eof(control_connection_t *conn);
|
|
|
|
int connection_control_process_inbuf(control_connection_t *conn);
|
2004-11-03 02:32:26 +01:00
|
|
|
|
2007-05-31 20:48:28 +02:00
|
|
|
#define EVENT_AUTHDIR_NEWDESCS 0x000D
|
2007-12-31 22:12:16 +01:00
|
|
|
#define EVENT_NS 0x000F
|
2007-05-31 20:48:28 +02:00
|
|
|
int control_event_is_interesting(int event);
|
|
|
|
|
2006-07-23 09:37:35 +02:00
|
|
|
int control_event_circuit_status(origin_circuit_t *circ,
|
2006-10-09 17:47:50 +02:00
|
|
|
circuit_status_event_t e, int reason);
|
2006-07-26 21:07:37 +02:00
|
|
|
int control_event_stream_status(edge_connection_t *conn,
|
2006-10-20 19:54:36 +02:00
|
|
|
stream_status_event_t e,
|
|
|
|
int reason);
|
2006-07-26 21:07:37 +02:00
|
|
|
int control_event_or_conn_status(or_connection_t *conn,
|
2007-01-15 22:13:37 +01:00
|
|
|
or_conn_status_event_t e, int reason);
|
2004-11-03 02:32:26 +01:00
|
|
|
int control_event_bandwidth_used(uint32_t n_read, uint32_t n_written);
|
2009-05-14 14:20:27 +02:00
|
|
|
int control_event_stream_bandwidth(edge_connection_t *edge_conn);
|
2007-02-14 17:46:49 +01:00
|
|
|
int control_event_stream_bandwidth_used(void);
|
2005-10-25 09:05:03 +02:00
|
|
|
void control_event_logmsg(int severity, unsigned int domain, const char *msg);
|
2005-03-02 23:29:58 +01:00
|
|
|
int control_event_descriptors_changed(smartlist_t *routers);
|
2005-12-14 21:40:40 +01:00
|
|
|
int control_event_address_mapped(const char *from, const char *to,
|
2007-07-10 19:14:51 +02:00
|
|
|
time_t expires, const char *error);
|
2005-12-14 21:40:40 +01:00
|
|
|
int control_event_or_authdir_new_descriptor(const char *action,
|
2007-05-31 20:48:28 +02:00
|
|
|
const char *desc,
|
|
|
|
size_t desclen,
|
2005-12-14 21:40:40 +01:00
|
|
|
const char *msg);
|
2006-09-29 20:13:25 +02:00
|
|
|
int control_event_my_descriptor_changed(void);
|
2006-10-20 23:04:39 +02:00
|
|
|
int control_event_networkstatus_changed(smartlist_t *statuses);
|
2009-02-16 07:18:03 +01:00
|
|
|
int control_event_newconsensus(const networkstatus_t *consensus);
|
2007-10-09 17:27:15 +02:00
|
|
|
int control_event_networkstatus_changed_single(routerstatus_t *rs);
|
2006-10-23 07:24:57 +02:00
|
|
|
int control_event_general_status(int severity, const char *format, ...)
|
|
|
|
CHECK_PRINTF(2,3);
|
|
|
|
int control_event_client_status(int severity, const char *format, ...)
|
|
|
|
CHECK_PRINTF(2,3);
|
|
|
|
int control_event_server_status(int severity, const char *format, ...)
|
|
|
|
CHECK_PRINTF(2,3);
|
2006-12-15 23:40:20 +01:00
|
|
|
int control_event_guard(const char *nickname, const char *digest,
|
|
|
|
const char *status);
|
2003-09-13 00:45:31 +02:00
|
|
|
|
2004-11-12 17:39:03 +01:00
|
|
|
int init_cookie_authentication(int enabled);
|
2007-12-09 05:59:27 +01:00
|
|
|
smartlist_t *decode_hashed_passwords(config_line_t *passwords);
|
2005-11-30 07:38:41 +01:00
|
|
|
void disable_control_logging(void);
|
|
|
|
void enable_control_logging(void);
|
2004-11-03 20:49:03 +01:00
|
|
|
|
2008-06-07 07:27:34 +02:00
|
|
|
/** Enum describing various stages of bootstrapping, for use with controller
|
|
|
|
* bootstrap status events. The values range from 0 to 100. */
|
|
|
|
typedef enum {
|
2008-06-18 07:35:19 +02:00
|
|
|
BOOTSTRAP_STATUS_UNDEF=-1,
|
|
|
|
BOOTSTRAP_STATUS_STARTING=0,
|
2008-06-07 07:27:34 +02:00
|
|
|
BOOTSTRAP_STATUS_CONN_DIR=5,
|
2008-06-18 07:35:19 +02:00
|
|
|
BOOTSTRAP_STATUS_HANDSHAKE=-2,
|
2008-06-07 07:27:34 +02:00
|
|
|
BOOTSTRAP_STATUS_HANDSHAKE_DIR=10,
|
|
|
|
BOOTSTRAP_STATUS_ONEHOP_CREATE=15,
|
|
|
|
BOOTSTRAP_STATUS_REQUESTING_STATUS=20,
|
|
|
|
BOOTSTRAP_STATUS_LOADING_STATUS=25,
|
|
|
|
BOOTSTRAP_STATUS_LOADING_KEYS=40,
|
|
|
|
BOOTSTRAP_STATUS_REQUESTING_DESCRIPTORS=45,
|
|
|
|
BOOTSTRAP_STATUS_LOADING_DESCRIPTORS=50,
|
|
|
|
BOOTSTRAP_STATUS_CONN_OR=80,
|
|
|
|
BOOTSTRAP_STATUS_HANDSHAKE_OR=85,
|
|
|
|
BOOTSTRAP_STATUS_CIRCUIT_CREATE=90,
|
|
|
|
BOOTSTRAP_STATUS_DONE=100
|
|
|
|
} bootstrap_status_t;
|
|
|
|
|
2008-06-09 20:32:43 +02:00
|
|
|
void control_event_bootstrap(bootstrap_status_t status, int progress);
|
|
|
|
void control_event_bootstrap_problem(const char *warn, int reason);
|
2008-06-07 07:27:34 +02:00
|
|
|
|
2008-12-27 07:50:07 +01:00
|
|
|
void control_event_clients_seen(const char *timestarted,
|
|
|
|
const char *countries);
|
|
|
|
|
2007-04-11 15:18:25 +02:00
|
|
|
#ifdef CONTROL_PRIVATE
|
|
|
|
/* Used only by control.c and test.c */
|
2007-08-29 21:02:33 +02:00
|
|
|
size_t write_escaped_data(const char *data, size_t len, char **out);
|
|
|
|
size_t read_escaped_data(const char *data, size_t len, char **out);
|
2007-04-11 15:18:25 +02:00
|
|
|
#endif
|
|
|
|
|
2003-08-21 01:05:22 +02:00
|
|
|
/********************************* cpuworker.c *****************************/
|
|
|
|
|
|
|
|
void cpu_init(void);
|
2004-04-25 00:17:50 +02:00
|
|
|
void cpuworkers_rotate(void);
|
2003-08-21 01:05:22 +02:00
|
|
|
int connection_cpu_finished_flushing(connection_t *conn);
|
2004-11-21 11:14:57 +01:00
|
|
|
int connection_cpu_reached_eof(connection_t *conn);
|
2003-08-21 01:05:22 +02:00
|
|
|
int connection_cpu_process_inbuf(connection_t *conn);
|
2008-02-06 00:20:49 +01:00
|
|
|
int assign_onionskin_to_cpuworker(connection_t *cpuworker,
|
|
|
|
or_circuit_t *circ,
|
|
|
|
char *onionskin);
|
2003-08-21 01:05:22 +02:00
|
|
|
|
2002-09-26 14:09:10 +02:00
|
|
|
/********************************* directory.c ***************************/
|
|
|
|
|
2007-09-18 17:53:53 +02:00
|
|
|
int directories_have_accepted_server_descriptor(void);
|
2007-05-09 06:15:46 +02:00
|
|
|
char *authority_type_to_string(authority_type_t auth);
|
2007-07-22 02:16:48 +02:00
|
|
|
void directory_post_to_dirservers(uint8_t dir_purpose, uint8_t router_purpose,
|
|
|
|
authority_type_t type, const char *payload,
|
2007-05-01 22:13:49 +02:00
|
|
|
size_t payload_len, size_t extrainfo_len);
|
2007-07-22 02:16:48 +02:00
|
|
|
void directory_get_from_dirserver(uint8_t dir_purpose, uint8_t router_purpose,
|
|
|
|
const char *resource,
|
2008-12-11 20:12:45 +01:00
|
|
|
int pds_flags);
|
2007-09-22 08:06:05 +02:00
|
|
|
void directory_get_from_all_authorities(uint8_t dir_purpose,
|
|
|
|
uint8_t router_purpose,
|
|
|
|
const char *resource);
|
2005-12-14 23:00:58 +01:00
|
|
|
void directory_initiate_command_routerstatus(routerstatus_t *status,
|
2007-06-10 09:34:21 +02:00
|
|
|
uint8_t dir_purpose,
|
|
|
|
uint8_t router_purpose,
|
2007-05-25 20:25:33 +02:00
|
|
|
int anonymized_connection,
|
2005-12-14 23:00:58 +01:00
|
|
|
const char *resource,
|
|
|
|
const char *payload,
|
2007-10-28 21:30:21 +01:00
|
|
|
size_t payload_len,
|
|
|
|
time_t if_modified_since);
|
2008-09-24 16:44:29 +02:00
|
|
|
void directory_initiate_command_routerstatus_rend(routerstatus_t *status,
|
|
|
|
uint8_t dir_purpose,
|
|
|
|
uint8_t router_purpose,
|
|
|
|
int anonymized_connection,
|
|
|
|
const char *resource,
|
|
|
|
const char *payload,
|
|
|
|
size_t payload_len,
|
|
|
|
time_t if_modified_since,
|
|
|
|
const rend_data_t *rend_query);
|
2005-02-27 10:47:01 +01:00
|
|
|
|
2005-02-24 11:56:55 +01:00
|
|
|
int parse_http_response(const char *headers, int *code, time_t *date,
|
2006-10-09 05:39:06 +02:00
|
|
|
compress_method_t *compression, char **response);
|
2005-02-24 11:56:55 +01:00
|
|
|
|
2008-01-10 18:48:36 +01:00
|
|
|
int connection_dir_is_encrypted(dir_connection_t *conn);
|
2006-07-26 21:07:26 +02:00
|
|
|
int connection_dir_reached_eof(dir_connection_t *conn);
|
|
|
|
int connection_dir_process_inbuf(dir_connection_t *conn);
|
|
|
|
int connection_dir_finished_flushing(dir_connection_t *conn);
|
|
|
|
int connection_dir_finished_connecting(dir_connection_t *conn);
|
|
|
|
void connection_dir_request_failed(dir_connection_t *conn);
|
2008-08-05 22:08:19 +02:00
|
|
|
void directory_initiate_command(const char *address, const tor_addr_t *addr,
|
2007-04-27 12:26:09 +02:00
|
|
|
uint16_t or_port, uint16_t dir_port,
|
2008-04-24 17:43:25 +02:00
|
|
|
int supports_conditional_consensus,
|
2007-06-10 09:34:21 +02:00
|
|
|
int supports_begindir, const char *digest,
|
|
|
|
uint8_t dir_purpose, uint8_t router_purpose,
|
2007-05-25 20:25:33 +02:00
|
|
|
int anonymized_connection,
|
|
|
|
const char *resource,
|
2007-10-28 21:30:21 +01:00
|
|
|
const char *payload, size_t payload_len,
|
|
|
|
time_t if_modified_since);
|
2007-01-28 09:06:00 +01:00
|
|
|
|
2005-09-16 06:42:45 +02:00
|
|
|
int dir_split_resource_into_fingerprints(const char *resource,
|
2005-10-14 06:56:20 +02:00
|
|
|
smartlist_t *fp_out, int *compresseed_out,
|
2006-06-21 06:57:12 +02:00
|
|
|
int decode_hex, int sort_uniq);
|
2008-12-17 18:20:31 +01:00
|
|
|
/** A pair of digests created by dir_split_resource_info_fingerprint_pairs() */
|
2008-12-12 20:05:36 +01:00
|
|
|
typedef struct {
|
|
|
|
char first[DIGEST_LEN];
|
|
|
|
char second[DIGEST_LEN];
|
|
|
|
} fp_pair_t;
|
|
|
|
int dir_split_resource_into_fingerprint_pairs(const char *res,
|
|
|
|
smartlist_t *pairs_out);
|
2006-01-10 00:13:53 +01:00
|
|
|
char *directory_dump_request_log(void);
|
2008-06-02 17:09:29 +02:00
|
|
|
void note_request(const char *key, size_t bytes);
|
2007-05-18 23:19:19 +02:00
|
|
|
int router_supports_extrainfo(const char *identity_digest, int is_authority);
|
2002-09-26 14:09:10 +02:00
|
|
|
|
2007-10-09 17:27:45 +02:00
|
|
|
time_t download_status_increment_failure(download_status_t *dls,
|
|
|
|
int status_code, const char *item,
|
|
|
|
int server, time_t now);
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Increment the failure count of the download_status_t <b>dls</b>, with
|
|
|
|
* the optional status code <b>sc</b>. */
|
2007-10-09 17:27:45 +02:00
|
|
|
#define download_status_failed(dls, sc) \
|
|
|
|
download_status_increment_failure((dls), (sc), NULL, \
|
|
|
|
get_options()->DirPort, time(NULL))
|
|
|
|
|
|
|
|
void download_status_reset(download_status_t *dls);
|
|
|
|
static int download_status_is_ready(download_status_t *dls, time_t now,
|
|
|
|
int max_failures);
|
2007-12-19 05:18:28 +01:00
|
|
|
/** Return true iff, as of <b>now</b>, the resource tracked by <b>dls</b> is
|
|
|
|
* ready to get its download reattempted. */
|
2007-10-09 17:27:45 +02:00
|
|
|
static INLINE int
|
|
|
|
download_status_is_ready(download_status_t *dls, time_t now,
|
|
|
|
int max_failures)
|
|
|
|
{
|
|
|
|
return (dls->n_download_failures <= max_failures
|
|
|
|
&& dls->next_attempt_at <= now);
|
|
|
|
}
|
|
|
|
|
2008-12-23 22:17:52 +01:00
|
|
|
static void download_status_mark_impossible(download_status_t *dl);
|
|
|
|
/** Mark <b>dl</b> as never downloadable. */
|
|
|
|
static INLINE void
|
|
|
|
download_status_mark_impossible(download_status_t *dl)
|
|
|
|
{
|
|
|
|
dl->n_download_failures = IMPOSSIBLE_TO_DOWNLOAD;
|
|
|
|
}
|
|
|
|
|
2004-05-12 21:49:48 +02:00
|
|
|
/********************************* dirserv.c ***************************/
|
2008-08-13 21:25:18 +02:00
|
|
|
/** Maximum length of an exit policy summary. */
|
|
|
|
#define MAX_EXITPOLICY_SUMMARY_LEN (1000)
|
|
|
|
|
2008-02-05 22:39:36 +01:00
|
|
|
/** Maximum allowable length of a version line in a networkstatus. */
|
|
|
|
#define MAX_V_LINE_LEN 128
|
|
|
|
/** Length of "r Authority BadDirectory BadExit Exit Fast Guard HSDir Named
|
|
|
|
* Running Stable Unnamed V2Dir Valid\n". */
|
|
|
|
#define MAX_FLAG_LINE_LEN 96
|
2008-08-13 21:25:18 +02:00
|
|
|
/** Length of "w" line for weighting. Currently at most
|
2009-07-31 06:33:53 +02:00
|
|
|
* "w Bandwidth=<uint32t> Measured=<uint32t>\n" */
|
|
|
|
#define MAX_WEIGHT_LINE_LEN (12+10+10+10+1)
|
2008-08-13 21:25:18 +02:00
|
|
|
/** Maximum length of an exit policy summary line. */
|
|
|
|
#define MAX_POLICY_LINE_LEN (3+MAX_EXITPOLICY_SUMMARY_LEN)
|
2008-02-06 17:58:05 +01:00
|
|
|
/** Amount of space to allocate for each entry: r, s, and v lines. */
|
|
|
|
#define RS_ENTRY_LEN \
|
|
|
|
( /* first line */ \
|
|
|
|
MAX_NICKNAME_LEN+BASE64_DIGEST_LEN*2+ISO_TIME_LEN+INET_NTOA_BUF_LEN+ \
|
|
|
|
5*2 /* ports */ + 10 /* punctuation */ + \
|
|
|
|
/* second line */ \
|
|
|
|
MAX_FLAG_LINE_LEN + \
|
2008-08-13 21:25:18 +02:00
|
|
|
/* weight line */ \
|
|
|
|
MAX_WEIGHT_LINE_LEN + \
|
|
|
|
/* p line. */ \
|
|
|
|
MAX_POLICY_LINE_LEN + \
|
2008-02-06 17:58:05 +01:00
|
|
|
/* v line. */ \
|
|
|
|
MAX_V_LINE_LEN \
|
|
|
|
)
|
2006-09-29 06:51:28 +02:00
|
|
|
#define UNNAMED_ROUTER_NICKNAME "Unnamed"
|
|
|
|
|
2006-07-26 21:07:26 +02:00
|
|
|
int connection_dirserv_flushed_some(dir_connection_t *conn);
|
2007-01-27 09:55:06 +01:00
|
|
|
|
2004-05-12 21:49:48 +02:00
|
|
|
int dirserv_add_own_fingerprint(const char *nickname, crypto_pk_env_t *pk);
|
2006-09-14 07:00:02 +02:00
|
|
|
int dirserv_load_fingerprint_file(void);
|
2004-10-27 20:16:37 +02:00
|
|
|
void dirserv_free_fingerprint_list(void);
|
2004-09-29 00:24:56 +02:00
|
|
|
const char *dirserv_get_nickname_by_digest(const char *digest);
|
2008-12-17 22:50:01 +01:00
|
|
|
enum was_router_added_t dirserv_add_multiple_descriptors(
|
|
|
|
const char *desc, uint8_t purpose,
|
2007-09-27 22:46:30 +02:00
|
|
|
const char *source,
|
2007-06-09 09:05:19 +02:00
|
|
|
const char **msg);
|
2008-12-17 22:50:01 +01:00
|
|
|
enum was_router_added_t dirserv_add_descriptor(routerinfo_t *ri,
|
2009-04-01 15:02:04 +02:00
|
|
|
const char **msg,
|
|
|
|
const char *source);
|
2004-10-27 20:16:37 +02:00
|
|
|
void dirserv_free_descriptors(void);
|
2007-12-18 23:39:15 +01:00
|
|
|
void dirserv_set_router_is_running(routerinfo_t *router, time_t now);
|
|
|
|
int list_server_status_v1(smartlist_t *routers, char **router_status_out,
|
|
|
|
int for_controller);
|
2004-12-24 03:17:32 +01:00
|
|
|
int dirserv_dump_directory_to_string(char **dir_out,
|
2007-10-11 15:56:33 +02:00
|
|
|
crypto_pk_env_t *private_key);
|
2007-12-01 05:58:53 +01:00
|
|
|
|
|
|
|
int directory_fetches_from_authorities(or_options_t *options);
|
2007-12-21 07:08:00 +01:00
|
|
|
int directory_fetches_dir_info_early(or_options_t *options);
|
|
|
|
int directory_fetches_dir_info_later(or_options_t *options);
|
2007-12-20 07:47:59 +01:00
|
|
|
int directory_caches_v2_dir_info(or_options_t *options);
|
|
|
|
#define directory_caches_v1_dir_info(o) directory_caches_v2_dir_info(o)
|
2007-12-04 19:35:03 +01:00
|
|
|
int directory_caches_dir_info(or_options_t *options);
|
2007-12-01 05:58:53 +01:00
|
|
|
int directory_permits_begindir_requests(or_options_t *options);
|
|
|
|
int directory_permits_controller_requests(or_options_t *options);
|
2007-12-04 19:35:03 +01:00
|
|
|
int directory_too_idle_to_fetch_descriptors(or_options_t *options, time_t now);
|
2007-12-01 05:58:53 +01:00
|
|
|
|
2004-05-12 21:49:48 +02:00
|
|
|
void directory_set_dirty(void);
|
2006-06-18 09:38:55 +02:00
|
|
|
cached_dir_t *dirserv_get_directory(void);
|
2007-06-02 17:26:57 +02:00
|
|
|
cached_dir_t *dirserv_get_runningrouters(void);
|
2007-07-30 01:11:44 +02:00
|
|
|
cached_dir_t *dirserv_get_consensus(void);
|
2004-11-15 05:04:20 +01:00
|
|
|
void dirserv_set_cached_directory(const char *directory, time_t when,
|
|
|
|
int is_running_routers);
|
2005-10-18 22:12:22 +02:00
|
|
|
void dirserv_set_cached_networkstatus_v2(const char *directory,
|
|
|
|
const char *identity,
|
2005-08-25 22:33:17 +02:00
|
|
|
time_t published);
|
2007-07-30 01:11:44 +02:00
|
|
|
void dirserv_set_cached_networkstatus_v3(const char *consensus,
|
|
|
|
time_t published);
|
2007-01-10 21:43:40 +01:00
|
|
|
void dirserv_clear_old_networkstatuses(time_t cutoff);
|
2007-02-13 00:39:24 +01:00
|
|
|
void dirserv_clear_old_v1_info(time_t now);
|
2006-04-02 00:00:49 +02:00
|
|
|
void dirserv_get_networkstatus_v2(smartlist_t *result, const char *key);
|
2006-06-20 02:48:23 +02:00
|
|
|
void dirserv_get_networkstatus_v2_fingerprints(smartlist_t *result,
|
|
|
|
const char *key);
|
2006-06-18 09:38:55 +02:00
|
|
|
int dirserv_get_routerdesc_fingerprints(smartlist_t *fps_out, const char *key,
|
2008-01-10 18:48:40 +01:00
|
|
|
const char **msg,
|
2009-01-06 16:37:51 +01:00
|
|
|
int for_unencrypted_conn,
|
|
|
|
int is_extrainfo);
|
2005-10-18 19:09:57 +02:00
|
|
|
int dirserv_get_routerdescs(smartlist_t *descs_out, const char *key,
|
|
|
|
const char **msg);
|
2005-04-06 23:09:47 +02:00
|
|
|
void dirserv_orconn_tls_done(const char *address,
|
|
|
|
uint16_t or_port,
|
|
|
|
const char *digest_rcvd,
|
2005-06-21 01:04:13 +02:00
|
|
|
int as_advertised);
|
2007-08-17 03:29:58 +02:00
|
|
|
void dirserv_test_reachability(time_t now, int try_all);
|
2006-01-03 11:42:20 +01:00
|
|
|
int authdir_wants_to_reject_router(routerinfo_t *ri, const char **msg,
|
|
|
|
int complain);
|
2005-12-06 07:55:43 +01:00
|
|
|
int dirserv_would_reject_router(routerstatus_t *rs);
|
2007-06-15 06:23:36 +02:00
|
|
|
int dirserv_remove_old_statuses(smartlist_t *fps, time_t cutoff);
|
2007-08-14 22:19:58 +02:00
|
|
|
int dirserv_have_any_serverdesc(smartlist_t *fps, int spool_src);
|
2007-01-03 20:58:00 +01:00
|
|
|
size_t dirserv_estimate_data_size(smartlist_t *fps, int is_serverdescs,
|
|
|
|
int compressed);
|
2009-07-31 06:33:53 +02:00
|
|
|
typedef enum {
|
|
|
|
NS_V2, NS_V3_CONSENSUS, NS_V3_VOTE, NS_CONTROL_PORT
|
|
|
|
} routerstatus_format_type_t;
|
2007-05-22 19:58:30 +02:00
|
|
|
int routerstatus_format_entry(char *buf, size_t buf_len,
|
2007-06-04 21:19:01 +02:00
|
|
|
routerstatus_t *rs, const char *platform,
|
2009-07-31 06:33:53 +02:00
|
|
|
routerstatus_format_type_t format);
|
2005-02-11 00:18:39 +01:00
|
|
|
void dirserv_free_all(void);
|
2006-06-18 09:38:55 +02:00
|
|
|
void cached_dir_decref(cached_dir_t *d);
|
2007-07-26 00:56:44 +02:00
|
|
|
cached_dir_t *new_cached_dir(char *s, time_t published);
|
|
|
|
|
2009-07-31 06:33:53 +02:00
|
|
|
#ifdef DIRSERV_PRIVATE
|
|
|
|
typedef struct measured_bw_line_t {
|
|
|
|
char node_id[DIGEST_LEN];
|
|
|
|
char node_hex[MAX_HEX_NICKNAME_LEN+1];
|
|
|
|
long int bw;
|
|
|
|
} measured_bw_line_t;
|
|
|
|
|
2009-08-10 03:21:15 +02:00
|
|
|
int measured_bw_line_parse(measured_bw_line_t *out, const char *line);
|
2009-07-31 06:33:53 +02:00
|
|
|
|
2009-08-10 03:21:15 +02:00
|
|
|
int measured_bw_line_apply(measured_bw_line_t *parsed_line,
|
|
|
|
smartlist_t *routerstatuses);
|
2009-07-31 06:33:53 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
int dirserv_read_measured_bandwidths(const char *from_file,
|
|
|
|
smartlist_t *routerstatuses);
|
|
|
|
|
2007-06-03 05:05:10 +02:00
|
|
|
/********************************* dirvote.c ************************/
|
|
|
|
|
2007-10-11 18:06:47 +02:00
|
|
|
/** Lowest allowable value for VoteSeconds. */
|
2007-08-15 17:38:58 +02:00
|
|
|
#define MIN_VOTE_SECONDS 20
|
2007-10-11 18:06:42 +02:00
|
|
|
/** Lowest allowable value for DistSeconds. */
|
2007-08-15 17:38:58 +02:00
|
|
|
#define MIN_DIST_SECONDS 20
|
2007-10-11 18:06:42 +02:00
|
|
|
/** Smallest allowable voting interval. */
|
2007-08-15 17:38:58 +02:00
|
|
|
#define MIN_VOTE_INTERVAL 300
|
|
|
|
|
2007-07-27 20:33:30 +02:00
|
|
|
void dirvote_free_all(void);
|
|
|
|
|
2007-07-26 00:56:44 +02:00
|
|
|
/* vote manipulation */
|
2007-06-04 21:54:02 +02:00
|
|
|
char *networkstatus_compute_consensus(smartlist_t *votes,
|
2007-06-17 17:10:23 +02:00
|
|
|
int total_authorities,
|
2007-06-04 21:54:02 +02:00
|
|
|
crypto_pk_env_t *identity_key,
|
2008-05-12 06:22:01 +02:00
|
|
|
crypto_pk_env_t *signing_key,
|
|
|
|
const char *legacy_identity_key_digest,
|
|
|
|
crypto_pk_env_t *legacy_signing_key);
|
2008-02-05 22:39:29 +01:00
|
|
|
int networkstatus_add_detached_signatures(networkstatus_t *target,
|
2007-10-19 18:41:32 +02:00
|
|
|
ns_detached_signatures_t *sigs,
|
|
|
|
const char **msg_out);
|
2008-02-05 22:39:29 +01:00
|
|
|
char *networkstatus_get_detached_signatures(networkstatus_t *consensus);
|
2007-07-27 20:33:28 +02:00
|
|
|
void ns_detached_signatures_free(ns_detached_signatures_t *s);
|
2007-06-03 05:05:10 +02:00
|
|
|
|
2007-07-26 00:56:44 +02:00
|
|
|
/* cert manipulation */
|
2007-06-08 20:41:09 +02:00
|
|
|
authority_cert_t *authority_cert_dup(authority_cert_t *cert);
|
|
|
|
|
2007-10-04 18:21:58 +02:00
|
|
|
/** Describes the schedule by which votes should be generated. */
|
2007-07-18 22:46:12 +02:00
|
|
|
typedef struct vote_timing_t {
|
|
|
|
int vote_interval;
|
|
|
|
int n_intervals_valid;
|
|
|
|
int vote_delay;
|
|
|
|
int dist_delay;
|
|
|
|
} vote_timing_t;
|
2007-07-26 00:56:44 +02:00
|
|
|
/* vote scheduling */
|
2007-07-18 22:46:12 +02:00
|
|
|
void dirvote_get_preferred_voting_intervals(vote_timing_t *timing_out);
|
|
|
|
time_t dirvote_get_start_of_next_interval(time_t now, int interval);
|
2007-10-18 16:27:42 +02:00
|
|
|
void dirvote_recalculate_timing(or_options_t *options, time_t now);
|
|
|
|
void dirvote_act(or_options_t *options, time_t now);
|
2007-07-18 22:46:12 +02:00
|
|
|
|
2007-07-26 00:56:44 +02:00
|
|
|
/* invoked on timers and by outside triggers. */
|
2007-07-26 00:56:50 +02:00
|
|
|
struct pending_vote_t * dirvote_add_vote(const char *vote_body,
|
2007-08-13 23:01:02 +02:00
|
|
|
const char **msg_out,
|
|
|
|
int *status_out);
|
2007-10-10 01:02:02 +02:00
|
|
|
int dirvote_add_signatures(const char *detached_signatures_body,
|
2008-01-23 09:38:05 +01:00
|
|
|
const char *source,
|
2007-10-10 01:02:02 +02:00
|
|
|
const char **msg_out);
|
2007-07-26 00:56:44 +02:00
|
|
|
|
2007-08-15 21:55:52 +02:00
|
|
|
/* Item access */
|
|
|
|
const char *dirvote_get_pending_consensus(void);
|
|
|
|
const char *dirvote_get_pending_detached_signatures(void);
|
2007-10-09 21:14:48 +02:00
|
|
|
#define DGV_BY_ID 1
|
|
|
|
#define DGV_INCLUDE_PENDING 2
|
|
|
|
#define DGV_INCLUDE_PREVIOUS 4
|
|
|
|
const cached_dir_t *dirvote_get_vote(const char *fp, int flags);
|
2007-12-18 23:39:15 +01:00
|
|
|
void set_routerstatus_from_routerinfo(routerstatus_t *rs,
|
|
|
|
routerinfo_t *ri, time_t now,
|
|
|
|
int naming, int exits_can_be_guards,
|
|
|
|
int listbadexits, int listbaddirs);
|
2007-12-10 17:40:14 +01:00
|
|
|
void router_clear_status_flags(routerinfo_t *ri);
|
2008-02-05 22:39:29 +01:00
|
|
|
networkstatus_t *
|
2007-10-22 19:31:26 +02:00
|
|
|
dirserv_generate_networkstatus_vote_obj(crypto_pk_env_t *private_key,
|
|
|
|
authority_cert_t *cert);
|
2007-08-15 21:55:52 +02:00
|
|
|
|
2007-06-14 00:39:08 +02:00
|
|
|
#ifdef DIRVOTE_PRIVATE
|
2009-09-15 04:15:57 +02:00
|
|
|
char *format_networkstatus_vote(crypto_pk_env_t *private_key,
|
|
|
|
networkstatus_t *v3_ns);
|
|
|
|
char *dirvote_compute_params(smartlist_t *votes);
|
2007-06-14 00:39:08 +02:00
|
|
|
#endif
|
|
|
|
|
major overhaul: dns slave subsystem, topics
on startup, it forks off a master dns handler, which forks off dns
slaves (like the apache model). slaves as spawned as load increases,
and then reused. excess slaves are not ever killed, currently.
implemented topics. each topic has a receive window in each direction
at each edge of the circuit, and sends sendme's at the data level, as
per before. each circuit also has receive windows in each direction at
each hop; an edge sends a circuit-level sendme as soon as enough data
cells have arrived (regardless of whether the data cells were flushed
to the exit conns). removed the 'connected' cell type, since it's now
a topic command within data cells.
at the edge of the circuit, there can be multiple connections associated
with a single circuit. you find them via the linked list conn->next_topic.
currently each new ap connection starts its own circuit, so we ought
to see comparable performance to what we had before. but that's only
because i haven't written the code to reattach to old circuits. please
try to break it as-is, and then i'll make it reuse the same circuit and
we'll try to break that.
svn:r152
2003-01-26 10:02:24 +01:00
|
|
|
/********************************* dns.c ***************************/
|
|
|
|
|
2006-08-14 23:44:34 +02:00
|
|
|
int dns_init(void);
|
2008-12-10 21:45:31 +01:00
|
|
|
int has_dns_init_failed(void);
|
2005-02-11 02:26:47 +01:00
|
|
|
void dns_free_all(void);
|
2006-06-03 23:41:14 +02:00
|
|
|
uint32_t dns_clip_ttl(uint32_t ttl);
|
2007-02-02 19:58:04 +01:00
|
|
|
int dns_reset(void);
|
2006-07-26 21:07:26 +02:00
|
|
|
void connection_dns_remove(edge_connection_t *conn);
|
|
|
|
void assert_connection_edge_not_dns_pending(edge_connection_t *conn);
|
2004-04-09 11:39:42 +02:00
|
|
|
void assert_all_pending_dns_resolves_ok(void);
|
2006-09-21 23:48:06 +02:00
|
|
|
void dns_cancel_pending_resolve(const char *question);
|
2007-03-24 16:58:11 +01:00
|
|
|
int dns_resolve(edge_connection_t *exitconn);
|
2006-12-28 22:29:11 +01:00
|
|
|
void dns_launch_correctness_checks(void);
|
|
|
|
int dns_seems_to_be_broken(void);
|
2006-12-28 22:29:20 +01:00
|
|
|
void dns_reset_correctness_checks(void);
|
2009-05-23 05:33:44 +02:00
|
|
|
void dump_dns_mem_usage(int severity);
|
major overhaul: dns slave subsystem, topics
on startup, it forks off a master dns handler, which forks off dns
slaves (like the apache model). slaves as spawned as load increases,
and then reused. excess slaves are not ever killed, currently.
implemented topics. each topic has a receive window in each direction
at each edge of the circuit, and sends sendme's at the data level, as
per before. each circuit also has receive windows in each direction at
each hop; an edge sends a circuit-level sendme as soon as enough data
cells have arrived (regardless of whether the data cells were flushed
to the exit conns). removed the 'connected' cell type, since it's now
a topic command within data cells.
at the edge of the circuit, there can be multiple connections associated
with a single circuit. you find them via the linked list conn->next_topic.
currently each new ap connection starts its own circuit, so we ought
to see comparable performance to what we had before. but that's only
because i haven't written the code to reattach to old circuits. please
try to break it as-is, and then i'll make it reuse the same circuit and
we'll try to break that.
svn:r152
2003-01-26 10:02:24 +01:00
|
|
|
|
2007-05-24 22:31:30 +02:00
|
|
|
/********************************* dnsserv.c ************************/
|
|
|
|
|
|
|
|
void dnsserv_configure_listener(connection_t *conn);
|
|
|
|
void dnsserv_close_listener(connection_t *conn);
|
|
|
|
void dnsserv_resolved(edge_connection_t *conn,
|
|
|
|
int answer_type,
|
|
|
|
size_t answer_len,
|
|
|
|
const char *answer,
|
|
|
|
int ttl);
|
|
|
|
void dnsserv_reject_request(edge_connection_t *conn);
|
2008-02-05 22:39:40 +01:00
|
|
|
int dnsserv_launch_request(const char *name, int is_reverse);
|
2007-05-24 22:31:30 +02:00
|
|
|
|
2007-12-17 23:44:11 +01:00
|
|
|
/********************************* geoip.c **************************/
|
|
|
|
|
2009-05-27 17:52:46 +02:00
|
|
|
/** Round all GeoIP results to the next multiple of this value, to avoid
|
|
|
|
* leaking information. */
|
|
|
|
#define DIR_RECORD_USAGE_GRANULARITY 8
|
|
|
|
/** Time interval: Flush geoip data to disk this often. */
|
2009-08-14 14:45:53 +02:00
|
|
|
#define DIR_ENTRY_RECORD_USAGE_RETAIN_IPS (24*60*60)
|
2009-05-27 17:52:46 +02:00
|
|
|
/** How long do we have to have observed per-country request history before
|
|
|
|
* we are willing to talk about it? */
|
|
|
|
#define DIR_RECORD_USAGE_MIN_OBSERVATION_TIME (24*60*60)
|
|
|
|
|
2007-12-17 23:44:11 +01:00
|
|
|
#ifdef GEOIP_PRIVATE
|
2007-12-18 22:27:08 +01:00
|
|
|
int geoip_parse_entry(const char *line);
|
2007-12-17 23:44:11 +01:00
|
|
|
#endif
|
2008-06-04 11:02:25 +02:00
|
|
|
int should_record_bridge_info(or_options_t *options);
|
|
|
|
int geoip_load_file(const char *filename, or_options_t *options);
|
2007-12-17 23:44:11 +01:00
|
|
|
int geoip_get_country_by_ip(uint32_t ipaddr);
|
|
|
|
int geoip_get_n_countries(void);
|
2008-09-25 22:21:35 +02:00
|
|
|
const char *geoip_get_country_name(country_t num);
|
2007-12-17 23:44:11 +01:00
|
|
|
int geoip_is_loaded(void);
|
2008-09-25 22:21:35 +02:00
|
|
|
country_t geoip_get_country(const char *countrycode);
|
2008-05-29 04:29:35 +02:00
|
|
|
/** Indicates an action that we might be noting geoip statistics on.
|
|
|
|
* Note that if we're noticing CONNECT, we're a bridge, and if we're noticing
|
|
|
|
* the others, we're not.
|
|
|
|
*/
|
|
|
|
typedef enum {
|
2009-07-05 20:48:16 +02:00
|
|
|
/** We've noticed a connection as a bridge relay or entry guard. */
|
2008-05-29 04:29:35 +02:00
|
|
|
GEOIP_CLIENT_CONNECT = 0,
|
|
|
|
/** We've served a networkstatus consensus as a directory server. */
|
|
|
|
GEOIP_CLIENT_NETWORKSTATUS = 1,
|
|
|
|
/** We've served a v2 networkstatus consensus as a directory server. */
|
|
|
|
GEOIP_CLIENT_NETWORKSTATUS_V2 = 2,
|
|
|
|
} geoip_client_action_t;
|
|
|
|
void geoip_note_client_seen(geoip_client_action_t action,
|
|
|
|
uint32_t addr, time_t now);
|
2007-12-17 23:44:11 +01:00
|
|
|
void geoip_remove_old_clients(time_t cutoff);
|
2009-07-10 13:37:25 +02:00
|
|
|
/** Indicates either a positive reply or a reason for rejectng a network
|
|
|
|
* status request that will be included in geoip statistics. */
|
|
|
|
typedef enum {
|
|
|
|
/** Request is answered successfully. */
|
|
|
|
GEOIP_SUCCESS = 0,
|
|
|
|
/** V3 network status is not signed by a sufficient number of requested
|
|
|
|
* authorities. */
|
|
|
|
GEOIP_REJECT_NOT_ENOUGH_SIGS = 1,
|
|
|
|
/** Requested network status object is unavailable. */
|
|
|
|
GEOIP_REJECT_UNAVAILABLE = 2,
|
|
|
|
/** Requested network status not found. */
|
|
|
|
GEOIP_REJECT_NOT_FOUND = 3,
|
|
|
|
/** Network status has not been modified since If-Modified-Since time. */
|
|
|
|
GEOIP_REJECT_NOT_MODIFIED = 4,
|
|
|
|
/** Directory is busy. */
|
|
|
|
GEOIP_REJECT_BUSY = 5,
|
|
|
|
} geoip_ns_response_t;
|
|
|
|
#define GEOIP_NS_RESPONSE_NUM 6
|
|
|
|
void geoip_note_ns_response(geoip_client_action_t action,
|
|
|
|
geoip_ns_response_t response);
|
2007-12-17 23:44:16 +01:00
|
|
|
time_t geoip_get_history_start(void);
|
2009-08-14 14:45:53 +02:00
|
|
|
char *geoip_get_client_history_dirreq(time_t now,
|
|
|
|
geoip_client_action_t action);
|
|
|
|
char *geoip_get_client_history_bridge(time_t now,
|
|
|
|
geoip_client_action_t action);
|
2008-06-10 20:08:56 +02:00
|
|
|
char *geoip_get_request_history(time_t now, geoip_client_action_t action);
|
2007-12-17 23:44:18 +01:00
|
|
|
int getinfo_helper_geoip(control_connection_t *control_conn,
|
|
|
|
const char *question, char **answer);
|
2007-12-17 23:44:11 +01:00
|
|
|
void geoip_free_all(void);
|
|
|
|
|
2009-07-12 16:33:31 +02:00
|
|
|
/** Directory requests that we are measuring can be either direct or
|
|
|
|
* tunneled. */
|
|
|
|
typedef enum {
|
2009-07-14 22:24:50 +02:00
|
|
|
DIRREQ_DIRECT = 0,
|
|
|
|
DIRREQ_TUNNELED = 1,
|
|
|
|
} dirreq_type_t;
|
2009-07-12 16:33:31 +02:00
|
|
|
|
|
|
|
/** Possible states for either direct or tunneled directory requests that
|
|
|
|
* are relevant for determining network status download times. */
|
|
|
|
typedef enum {
|
|
|
|
/** Found that the client requests a network status; applies to both
|
|
|
|
* direct and tunneled requests; initial state of a request that we are
|
|
|
|
* measuring. */
|
2009-07-14 22:24:50 +02:00
|
|
|
DIRREQ_IS_FOR_NETWORK_STATUS = 0,
|
2009-07-12 16:33:31 +02:00
|
|
|
/** Finished writing a network status to the directory connection;
|
|
|
|
* applies to both direct and tunneled requests; completes a direct
|
|
|
|
* request. */
|
2009-07-14 22:24:50 +02:00
|
|
|
DIRREQ_FLUSHING_DIR_CONN_FINISHED = 1,
|
2009-07-12 16:33:31 +02:00
|
|
|
/** END cell sent to circuit that initiated a tunneled request. */
|
2009-07-14 22:24:50 +02:00
|
|
|
DIRREQ_END_CELL_SENT = 2,
|
2009-07-12 16:33:31 +02:00
|
|
|
/** Flushed last cell from queue of the circuit that initiated a
|
|
|
|
* tunneled request to the outbuf of the OR connection. */
|
2009-07-14 22:24:50 +02:00
|
|
|
DIRREQ_CIRC_QUEUE_FLUSHED = 3,
|
2009-07-12 16:33:31 +02:00
|
|
|
/** Flushed last byte from buffer of the OR connection belonging to the
|
|
|
|
* circuit that initiated a tunneled request; completes a tunneled
|
|
|
|
* request. */
|
2009-07-14 22:24:50 +02:00
|
|
|
DIRREQ_OR_CONN_BUFFER_FLUSHED = 4
|
|
|
|
} dirreq_state_t;
|
|
|
|
|
|
|
|
void geoip_start_dirreq(uint64_t dirreq_id, size_t response_size,
|
|
|
|
geoip_client_action_t action, dirreq_type_t type);
|
|
|
|
void geoip_change_dirreq_state(uint64_t dirreq_id, dirreq_type_t type,
|
|
|
|
dirreq_state_t new_state);
|
2009-07-12 16:33:31 +02:00
|
|
|
|
2009-08-19 15:41:12 +02:00
|
|
|
void geoip_dirreq_stats_init(time_t now);
|
|
|
|
void geoip_dirreq_stats_write(time_t now);
|
|
|
|
void geoip_entry_stats_init(time_t now);
|
|
|
|
void geoip_entry_stats_write(time_t now);
|
|
|
|
|
2004-10-31 21:28:41 +01:00
|
|
|
/********************************* hibernate.c **********************/
|
|
|
|
|
2004-11-22 22:56:51 +01:00
|
|
|
int accounting_parse_options(or_options_t *options, int validate_only);
|
2004-11-15 05:01:31 +01:00
|
|
|
int accounting_is_enabled(or_options_t *options);
|
2004-11-04 23:33:06 +01:00
|
|
|
void configure_accounting(time_t now);
|
|
|
|
void accounting_run_housekeeping(time_t now);
|
|
|
|
void accounting_add_bytes(size_t n_read, size_t n_written, int seconds);
|
2006-12-07 19:57:37 +01:00
|
|
|
int accounting_record_bandwidth_usage(time_t now, or_state_t *state);
|
2004-10-31 21:28:41 +01:00
|
|
|
void hibernate_begin_shutdown(void);
|
|
|
|
int we_are_hibernating(void);
|
|
|
|
void consider_hibernation(time_t now);
|
2006-12-08 05:39:13 +01:00
|
|
|
int getinfo_helper_accounting(control_connection_t *conn,
|
|
|
|
const char *question, char **answer);
|
2005-08-07 23:24:00 +02:00
|
|
|
void accounting_set_bandwidth_usage_from_state(or_state_t *state);
|
2005-07-22 16:55:09 +02:00
|
|
|
|
2002-06-27 00:45:49 +02:00
|
|
|
/********************************* main.c ***************************/
|
|
|
|
|
2006-08-11 09:09:17 +02:00
|
|
|
extern int has_completed_circuit;
|
|
|
|
|
2002-06-27 00:45:49 +02:00
|
|
|
int connection_add(connection_t *conn);
|
|
|
|
int connection_remove(connection_t *conn);
|
2009-06-04 20:49:16 +02:00
|
|
|
void connection_unregister_events(connection_t *conn);
|
2004-06-02 00:09:58 +02:00
|
|
|
int connection_in_array(connection_t *conn);
|
2005-01-12 07:42:32 +01:00
|
|
|
void add_connection_to_closeable_list(connection_t *conn);
|
2005-01-31 01:33:32 +01:00
|
|
|
int connection_is_on_closeable_list(connection_t *conn);
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2007-05-22 17:49:14 +02:00
|
|
|
smartlist_t *get_connection_array(void);
|
2003-09-30 21:27:54 +02:00
|
|
|
|
2009-06-04 20:49:16 +02:00
|
|
|
typedef enum watchable_events {
|
|
|
|
READ_EVENT=0x02,
|
|
|
|
WRITE_EVENT=0x04
|
|
|
|
} watchable_events_t;
|
|
|
|
void connection_watch_events(connection_t *conn, watchable_events_t events);
|
2003-09-07 12:24:40 +02:00
|
|
|
int connection_is_reading(connection_t *conn);
|
Implemented link padding and receiver token buckets
Each socket reads at most 'bandwidth' bytes per second sustained, but
can handle bursts of up to 10*bandwidth bytes.
Cells are now sent out at evenly-spaced intervals, with padding sent
out otherwise. Set Linkpadding=0 in the rc file to send cells as soon
as they're available (and to never send padding cells).
Added license/copyrights statements at the top of most files.
router->min and router->max have been merged into a single 'bandwidth'
value. We should make the routerinfo_t reflect this (want to do that,
Mat?)
As the bandwidth increases, and we want to stop sleeping more and more
frequently to send a single cell, cpu usage goes up. At 128kB/s we're
pretty much calling poll with a timeout of 1ms or even 0ms. The current
code takes a timeout of 0-9ms and makes it 10ms. prepare_for_poll()
handles everything that should have happened in the past, so as long as
our buffers don't get too full in that 10ms, we're ok.
Speaking of too full, if you run three servers at 100kB/s with -l debug,
it spends too much time printing debugging messages to be able to keep
up with the cells. The outbuf ultimately fills up and it kills that
connection. If you run with -l err, it works fine up through 500kB/s and
probably beyond. Down the road we'll want to teach it to recognize when
an outbuf is getting full, and back off.
svn:r50
2002-07-16 03:12:15 +02:00
|
|
|
void connection_stop_reading(connection_t *conn);
|
|
|
|
void connection_start_reading(connection_t *conn);
|
2004-03-03 06:08:01 +01:00
|
|
|
|
2004-02-27 05:42:14 +01:00
|
|
|
int connection_is_writing(connection_t *conn);
|
2002-07-18 08:37:58 +02:00
|
|
|
void connection_stop_writing(connection_t *conn);
|
|
|
|
void connection_start_writing(connection_t *conn);
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2007-04-21 19:26:12 +02:00
|
|
|
void connection_stop_reading_from_linked_conn(connection_t *conn);
|
|
|
|
|
2005-01-07 16:57:57 +01:00
|
|
|
void directory_all_unreachable(time_t now);
|
2005-09-15 07:19:38 +02:00
|
|
|
void directory_info_has_arrived(time_t now, int from_cache);
|
2004-04-01 00:02:13 +02:00
|
|
|
|
2006-12-28 22:29:20 +01:00
|
|
|
void ip_address_changed(int at_interface);
|
|
|
|
void dns_servers_relaunch_checks(void);
|
|
|
|
|
2006-08-18 01:00:32 +02:00
|
|
|
void control_signal_act(int the_signal);
|
2004-08-08 09:25:45 +02:00
|
|
|
void handle_signals(int is_parent);
|
2008-09-01 22:06:26 +02:00
|
|
|
|
|
|
|
int try_locking(or_options_t *options, int err_if_locked);
|
|
|
|
int have_lockfile(void);
|
|
|
|
void release_lockfile(void);
|
|
|
|
|
2004-07-23 00:15:36 +02:00
|
|
|
void tor_cleanup(void);
|
2005-05-03 05:51:20 +02:00
|
|
|
void tor_free_all(int postfork);
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2004-11-02 04:02:17 +01:00
|
|
|
int tor_main(int argc, char *argv[]);
|
|
|
|
|
2007-09-06 20:19:09 +02:00
|
|
|
#ifdef MAIN_PRIVATE
|
|
|
|
int do_main_loop(void);
|
|
|
|
int do_list_fingerprint(void);
|
|
|
|
void do_hash_password(void);
|
|
|
|
int tor_init(int argc, char **argv);
|
|
|
|
#endif
|
|
|
|
|
2007-10-08 23:21:50 +02:00
|
|
|
/********************************* networkstatus.c *********************/
|
|
|
|
|
2007-10-10 21:33:19 +02:00
|
|
|
/** How old do we allow a v2 network-status to get before removing it
|
2007-10-08 23:21:50 +02:00
|
|
|
* completely? */
|
|
|
|
#define MAX_NETWORKSTATUS_AGE (10*24*60*60)
|
|
|
|
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Location where we found a v2 networkstatus. */
|
2007-10-11 18:06:47 +02:00
|
|
|
typedef enum {
|
|
|
|
NS_FROM_CACHE, NS_FROM_DIR_BY_FP, NS_FROM_DIR_ALL, NS_GENERATED
|
2008-12-17 18:20:48 +01:00
|
|
|
} v2_networkstatus_source_t;
|
2007-10-11 18:06:47 +02:00
|
|
|
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Possible statuses of a version of Tor, given opinions from the directory
|
|
|
|
* servers. */
|
2007-10-11 18:06:47 +02:00
|
|
|
typedef enum version_status_t {
|
|
|
|
VS_RECOMMENDED=0, /**< This version is listed as recommended. */
|
|
|
|
VS_OLD=1, /**< This version is older than any recommended version. */
|
|
|
|
VS_NEW=2, /**< This version is newer than any recommended version. */
|
|
|
|
VS_NEW_IN_SERIES=3, /**< This version is newer than any recommended version
|
|
|
|
* in its series, but later recommended versions exist.
|
|
|
|
*/
|
2007-10-16 01:15:24 +02:00
|
|
|
VS_UNRECOMMENDED=4, /**< This version is not recommended (general case). */
|
2008-02-06 13:45:04 +01:00
|
|
|
VS_EMPTY=5, /**< The version list was empty; no agreed-on versions. */
|
2007-10-16 01:15:24 +02:00
|
|
|
VS_UNKNOWN, /**< We have no idea. */
|
2007-10-11 18:06:47 +02:00
|
|
|
} version_status_t;
|
|
|
|
|
2007-10-08 23:21:50 +02:00
|
|
|
void networkstatus_reset_warnings(void);
|
2007-10-16 01:15:24 +02:00
|
|
|
void networkstatus_reset_download_failures(void);
|
|
|
|
int router_reload_v2_networkstatus(void);
|
2007-10-08 23:21:50 +02:00
|
|
|
int router_reload_consensus_networkstatus(void);
|
2007-10-11 18:06:47 +02:00
|
|
|
void routerstatus_free(routerstatus_t *rs);
|
2007-10-16 01:15:24 +02:00
|
|
|
void networkstatus_v2_free(networkstatus_v2_t *ns);
|
2008-02-05 22:39:29 +01:00
|
|
|
void networkstatus_vote_free(networkstatus_t *ns);
|
2007-10-22 19:31:26 +02:00
|
|
|
networkstatus_voter_info_t *networkstatus_get_voter_by_id(
|
2008-02-05 22:39:29 +01:00
|
|
|
networkstatus_t *vote,
|
2007-10-22 19:31:26 +02:00
|
|
|
const char *identity);
|
2008-02-05 22:39:29 +01:00
|
|
|
int networkstatus_check_consensus_signature(networkstatus_t *consensus,
|
2007-10-22 19:31:26 +02:00
|
|
|
int warn);
|
2008-02-05 22:39:29 +01:00
|
|
|
int networkstatus_check_voter_signature(networkstatus_t *consensus,
|
2007-10-22 19:31:26 +02:00
|
|
|
networkstatus_voter_info_t *voter,
|
|
|
|
authority_cert_t *cert);
|
2007-10-08 23:21:50 +02:00
|
|
|
char *networkstatus_get_cache_filename(const char *identity_digest);
|
2007-10-16 01:15:24 +02:00
|
|
|
int router_set_networkstatus_v2(const char *s, time_t arrived_at,
|
2008-12-17 18:20:48 +01:00
|
|
|
v2_networkstatus_source_t source,
|
2007-10-08 23:21:50 +02:00
|
|
|
smartlist_t *requested_fingerprints);
|
2007-10-16 01:15:24 +02:00
|
|
|
void networkstatus_v2_list_clean(time_t now);
|
2009-07-31 06:33:53 +02:00
|
|
|
int compare_digest_to_routerstatus_entry(const void *_key,
|
|
|
|
const void **_member);
|
2007-10-16 01:15:24 +02:00
|
|
|
routerstatus_t *networkstatus_v2_find_entry(networkstatus_v2_t *ns,
|
2007-10-08 23:21:50 +02:00
|
|
|
const char *digest);
|
2008-02-05 22:39:29 +01:00
|
|
|
routerstatus_t *networkstatus_vote_find_entry(networkstatus_t *ns,
|
2007-10-16 01:15:24 +02:00
|
|
|
const char *digest);
|
2008-02-05 22:39:29 +01:00
|
|
|
int networkstatus_vote_find_entry_idx(networkstatus_t *ns,
|
2007-11-03 21:12:41 +01:00
|
|
|
const char *digest, int *found_out);
|
2007-10-08 23:21:50 +02:00
|
|
|
const smartlist_t *networkstatus_get_v2_list(void);
|
2007-10-16 01:15:24 +02:00
|
|
|
download_status_t *router_get_dl_status_by_descriptor_digest(const char *d);
|
|
|
|
routerstatus_t *router_get_consensus_status_by_id(const char *digest);
|
|
|
|
routerstatus_t *router_get_consensus_status_by_descriptor_digest(
|
|
|
|
const char *digest);
|
|
|
|
routerstatus_t *router_get_consensus_status_by_nickname(const char *nickname,
|
2007-10-11 18:06:47 +02:00
|
|
|
int warn_if_unnamed);
|
2007-10-08 23:21:50 +02:00
|
|
|
const char *networkstatus_get_router_digest_by_nickname(const char *nickname);
|
2007-10-19 20:56:24 +02:00
|
|
|
int networkstatus_nickname_is_unnamed(const char *nickname);
|
2007-10-11 18:06:47 +02:00
|
|
|
void networkstatus_consensus_download_failed(int status_code);
|
2007-10-22 18:32:04 +02:00
|
|
|
void update_consensus_networkstatus_fetch_time(time_t now);
|
2007-10-11 18:06:47 +02:00
|
|
|
int should_delay_dir_fetches(or_options_t *options);
|
|
|
|
void update_networkstatus_downloads(time_t now);
|
2007-10-22 19:31:22 +02:00
|
|
|
void update_certificate_downloads(time_t now);
|
2008-06-07 07:27:34 +02:00
|
|
|
int consensus_is_waiting_for_certs(void);
|
2007-10-16 01:15:24 +02:00
|
|
|
networkstatus_v2_t *networkstatus_v2_get_by_digest(const char *digest);
|
2008-02-05 22:39:29 +01:00
|
|
|
networkstatus_t *networkstatus_get_latest_consensus(void);
|
|
|
|
networkstatus_t *networkstatus_get_live_consensus(time_t now);
|
|
|
|
networkstatus_t *networkstatus_get_reasonably_live_consensus(time_t now);
|
2008-01-07 20:15:34 +01:00
|
|
|
#define NSSET_FROM_CACHE 1
|
|
|
|
#define NSSET_WAS_WAITING_FOR_CERTS 2
|
|
|
|
#define NSSET_DONT_DOWNLOAD_CERTS 4
|
2009-01-05 17:56:11 +01:00
|
|
|
#define NSSET_ACCEPT_OBSOLETE 8
|
2008-01-07 20:15:34 +01:00
|
|
|
int networkstatus_set_current_consensus(const char *consensus, unsigned flags);
|
2007-10-11 18:06:47 +02:00
|
|
|
void networkstatus_note_certs_arrived(void);
|
2007-11-11 19:46:16 +01:00
|
|
|
void routers_update_all_from_networkstatus(time_t now, int dir_version);
|
2007-10-12 23:33:39 +02:00
|
|
|
void routerstatus_list_update_from_consensus_networkstatus(time_t now);
|
|
|
|
void routers_update_status_from_consensus_networkstatus(smartlist_t *routers,
|
|
|
|
int reset_failures);
|
2007-10-19 04:15:47 +02:00
|
|
|
void signed_descs_update_status_from_consensus_networkstatus(
|
|
|
|
smartlist_t *descs);
|
|
|
|
|
2007-10-11 18:06:47 +02:00
|
|
|
char *networkstatus_getinfo_helper_single(routerstatus_t *rs);
|
2007-12-19 05:58:58 +01:00
|
|
|
char *networkstatus_getinfo_by_purpose(const char *purpose_string, time_t now);
|
2007-12-19 06:04:05 +01:00
|
|
|
void networkstatus_dump_bridge_status_to_file(time_t now);
|
2009-09-15 05:39:08 +02:00
|
|
|
int32_t networkstatus_get_param(networkstatus_t *ns, const char *param_name,
|
|
|
|
int32_t default_val);
|
2007-10-11 18:06:47 +02:00
|
|
|
int getinfo_helper_networkstatus(control_connection_t *conn,
|
|
|
|
const char *question, char **answer);
|
2007-10-08 23:21:50 +02:00
|
|
|
void networkstatus_free_all(void);
|
|
|
|
|
2007-09-10 15:50:00 +02:00
|
|
|
/********************************* ntmain.c ***************************/
|
2007-09-06 19:42:05 +02:00
|
|
|
#ifdef MS_WINDOWS
|
|
|
|
#define NT_SERVICE
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef NT_SERVICE
|
2007-09-06 20:19:09 +02:00
|
|
|
int nt_service_parse_options(int argc, char **argv, int *should_exit);
|
2007-09-06 19:42:05 +02:00
|
|
|
int nt_service_is_stopping(void);
|
|
|
|
void nt_service_set_state(DWORD state);
|
|
|
|
#else
|
|
|
|
#define nt_service_is_stopping() (0)
|
|
|
|
#endif
|
|
|
|
|
2002-06-27 00:45:49 +02:00
|
|
|
/********************************* onion.c ***************************/
|
|
|
|
|
2008-02-06 00:20:49 +01:00
|
|
|
int onion_pending_add(or_circuit_t *circ, char *onionskin);
|
|
|
|
or_circuit_t *onion_next_task(char **onionskin_out);
|
2006-07-23 09:37:35 +02:00
|
|
|
void onion_pending_remove(or_circuit_t *circ);
|
2002-06-27 00:45:49 +02:00
|
|
|
|
2003-05-05 06:27:00 +02:00
|
|
|
int onion_skin_create(crypto_pk_env_t *router_key,
|
|
|
|
crypto_dh_env_t **handshake_state_out,
|
2003-12-16 09:21:58 +01:00
|
|
|
char *onion_skin_out);
|
2003-05-05 06:27:00 +02:00
|
|
|
|
2005-05-03 00:35:18 +02:00
|
|
|
int onion_skin_server_handshake(const char *onion_skin,
|
2003-05-05 06:27:00 +02:00
|
|
|
crypto_pk_env_t *private_key,
|
2004-04-25 00:17:50 +02:00
|
|
|
crypto_pk_env_t *prev_private_key,
|
2003-12-16 09:21:58 +01:00
|
|
|
char *handshake_reply_out,
|
2003-05-05 06:27:00 +02:00
|
|
|
char *key_out,
|
2004-10-14 04:47:09 +02:00
|
|
|
size_t key_out_len);
|
2003-05-05 06:27:00 +02:00
|
|
|
|
|
|
|
int onion_skin_client_handshake(crypto_dh_env_t *handshake_state,
|
2005-05-03 00:35:18 +02:00
|
|
|
const char *handshake_reply,
|
|
|
|
char *key_out,
|
|
|
|
size_t key_out_len);
|
|
|
|
|
|
|
|
int fast_server_handshake(const char *key_in,
|
|
|
|
char *handshake_reply_out,
|
|
|
|
char *key_out,
|
|
|
|
size_t key_out_len);
|
|
|
|
|
|
|
|
int fast_client_handshake(const char *handshake_state,
|
|
|
|
const char *handshake_reply_out,
|
|
|
|
char *key_out,
|
|
|
|
size_t key_out_len);
|
2003-05-05 06:27:00 +02:00
|
|
|
|
2005-02-11 02:26:47 +01:00
|
|
|
void clear_pending_onions(void);
|
|
|
|
|
2006-03-27 04:25:34 +02:00
|
|
|
/********************************* policies.c ************************/
|
|
|
|
|
2006-12-29 03:49:12 +01:00
|
|
|
/* (length of "accept 255.255.255.255/255.255.255.255:65535-65535\n" plus a
|
2009-05-27 23:55:51 +02:00
|
|
|
* NUL.)
|
2006-12-29 03:49:12 +01:00
|
|
|
*/
|
|
|
|
#define POLICY_BUF_LEN 52
|
|
|
|
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Outcome of applying an address policy to an address. */
|
2006-03-27 04:25:34 +02:00
|
|
|
typedef enum {
|
2008-12-17 18:20:31 +01:00
|
|
|
/** The address was accepted */
|
2006-03-27 04:25:34 +02:00
|
|
|
ADDR_POLICY_ACCEPTED=0,
|
2008-12-17 18:20:31 +01:00
|
|
|
/** The address was rejected */
|
2006-03-27 04:25:34 +02:00
|
|
|
ADDR_POLICY_REJECTED=-1,
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Part of the address was unknown, but as far as we can tell, it was
|
|
|
|
* accepted. */
|
2006-03-27 04:25:34 +02:00
|
|
|
ADDR_POLICY_PROBABLY_ACCEPTED=1,
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Part of the address was unknown, but as far as we can tell, it was
|
|
|
|
* rejected. */
|
2006-03-27 04:25:34 +02:00
|
|
|
ADDR_POLICY_PROBABLY_REJECTED=2
|
|
|
|
} addr_policy_result_t;
|
|
|
|
|
|
|
|
int firewall_is_fascist_or(void);
|
2008-08-05 22:08:19 +02:00
|
|
|
int fascist_firewall_allows_address_or(const tor_addr_t *addr, uint16_t port);
|
|
|
|
int fascist_firewall_allows_or(routerinfo_t *ri);
|
|
|
|
int fascist_firewall_allows_address_dir(const tor_addr_t *addr, uint16_t port);
|
|
|
|
int dir_policy_permits_address(const tor_addr_t *addr);
|
|
|
|
int socks_policy_permits_address(const tor_addr_t *addr);
|
2006-03-27 04:25:34 +02:00
|
|
|
int authdir_policy_permits_address(uint32_t addr, uint16_t port);
|
|
|
|
int authdir_policy_valid_address(uint32_t addr, uint16_t port);
|
2007-12-10 17:49:54 +01:00
|
|
|
int authdir_policy_baddir_address(uint32_t addr, uint16_t port);
|
2006-10-23 05:48:52 +02:00
|
|
|
int authdir_policy_badexit_address(uint32_t addr, uint16_t port);
|
2006-03-27 04:25:34 +02:00
|
|
|
|
|
|
|
int validate_addr_policies(or_options_t *options, char **msg);
|
2008-01-02 05:43:44 +01:00
|
|
|
void policy_expand_private(smartlist_t **policy);
|
2008-02-05 22:39:32 +01:00
|
|
|
int policies_parse_from_options(or_options_t *options);
|
2006-03-27 04:25:34 +02:00
|
|
|
|
2008-01-02 05:43:44 +01:00
|
|
|
addr_policy_t *addr_policy_get_canonical_entry(addr_policy_t *ent);
|
|
|
|
int cmp_addr_policies(smartlist_t *a, smartlist_t *b);
|
2008-08-05 22:08:19 +02:00
|
|
|
addr_policy_result_t compare_tor_addr_to_addr_policy(const tor_addr_t *addr,
|
2008-12-29 02:47:28 +01:00
|
|
|
uint16_t port, const smartlist_t *policy);
|
2006-03-27 04:25:34 +02:00
|
|
|
addr_policy_result_t compare_addr_to_addr_policy(uint32_t addr,
|
2008-12-29 02:47:28 +01:00
|
|
|
uint16_t port, const smartlist_t *policy);
|
2008-01-02 05:43:44 +01:00
|
|
|
int policies_parse_exit_policy(config_line_t *cfg, smartlist_t **dest,
|
2007-11-10 22:17:51 +01:00
|
|
|
int rejectprivate, const char *local_address);
|
2008-01-02 05:43:44 +01:00
|
|
|
void policies_set_router_exitpolicy_to_reject_all(routerinfo_t *exitrouter);
|
|
|
|
int exit_policy_is_general_exit(smartlist_t *policy);
|
2008-12-29 02:47:28 +01:00
|
|
|
int policy_is_reject_star(const smartlist_t *policy);
|
2006-12-08 05:39:13 +01:00
|
|
|
int getinfo_helper_policies(control_connection_t *conn,
|
|
|
|
const char *question, char **answer);
|
2008-07-24 15:44:04 +02:00
|
|
|
int policy_write_item(char *buf, size_t buflen, addr_policy_t *item,
|
|
|
|
int format_for_desc);
|
2006-03-27 04:25:34 +02:00
|
|
|
|
2008-01-02 05:43:44 +01:00
|
|
|
void addr_policy_list_free(smartlist_t *p);
|
2006-03-27 04:25:34 +02:00
|
|
|
void addr_policy_free(addr_policy_t *p);
|
|
|
|
void policies_free_all(void);
|
|
|
|
|
2008-08-13 14:45:28 +02:00
|
|
|
char *policy_summarize(smartlist_t *policy);
|
|
|
|
|
2008-06-11 02:17:02 +02:00
|
|
|
/********************************* reasons.c ***************************/
|
|
|
|
|
|
|
|
const char *stream_end_reason_to_control_string(int reason);
|
|
|
|
const char *stream_end_reason_to_string(int reason);
|
|
|
|
socks5_reply_status_t stream_end_reason_to_socks5_response(int reason);
|
2008-06-11 03:14:23 +02:00
|
|
|
uint8_t errno_to_stream_end_reason(int e);
|
2008-06-11 02:17:02 +02:00
|
|
|
|
|
|
|
const char *orconn_end_reason_to_control_string(int r);
|
|
|
|
int tls_error_to_orconn_end_reason(int e);
|
2008-06-11 03:14:23 +02:00
|
|
|
int errno_to_orconn_end_reason(int e);
|
2008-06-11 02:17:02 +02:00
|
|
|
|
|
|
|
const char *circuit_end_reason_to_control_string(int reason);
|
2009-06-19 18:40:23 +02:00
|
|
|
const char *socks4_response_code_to_string(uint8_t code);
|
|
|
|
const char *socks5_response_code_to_string(uint8_t code);
|
2008-06-11 02:17:02 +02:00
|
|
|
|
2004-05-12 21:49:48 +02:00
|
|
|
/********************************* relay.c ***************************/
|
2004-05-10 19:30:51 +02:00
|
|
|
|
2005-12-31 12:52:13 +01:00
|
|
|
extern uint64_t stats_n_relay_cells_relayed;
|
|
|
|
extern uint64_t stats_n_relay_cells_delivered;
|
2003-09-27 23:30:10 +02:00
|
|
|
|
2004-05-12 21:49:48 +02:00
|
|
|
int circuit_receive_relay_cell(cell_t *cell, circuit_t *circ,
|
2008-12-17 18:20:19 +01:00
|
|
|
cell_direction_t cell_direction);
|
2003-09-27 23:30:10 +02:00
|
|
|
|
2004-05-13 09:24:49 +02:00
|
|
|
void relay_header_pack(char *dest, const relay_header_t *src);
|
|
|
|
void relay_header_unpack(relay_header_t *dest, const char *src);
|
2008-07-23 17:58:30 +02:00
|
|
|
int relay_send_command_from_edge(streamid_t stream_id, circuit_t *circ,
|
2008-02-20 01:57:37 +01:00
|
|
|
uint8_t relay_command, const char *payload,
|
2006-10-23 05:48:52 +02:00
|
|
|
size_t payload_len, crypt_path_t *cpath_layer);
|
2007-03-24 16:58:11 +01:00
|
|
|
int connection_edge_send_command(edge_connection_t *fromconn,
|
2008-02-20 01:57:37 +01:00
|
|
|
uint8_t relay_command, const char *payload,
|
2007-03-24 16:57:51 +01:00
|
|
|
size_t payload_len);
|
2006-07-26 21:07:37 +02:00
|
|
|
int connection_edge_package_raw_inbuf(edge_connection_t *conn,
|
|
|
|
int package_partial);
|
2006-07-26 21:07:26 +02:00
|
|
|
void connection_edge_consider_sending_sendme(edge_connection_t *conn);
|
2004-05-13 09:24:49 +02:00
|
|
|
|
|
|
|
extern uint64_t stats_n_data_cells_packaged;
|
|
|
|
extern uint64_t stats_n_data_bytes_packaged;
|
|
|
|
extern uint64_t stats_n_data_cells_received;
|
|
|
|
extern uint64_t stats_n_data_bytes_received;
|
|
|
|
|
2007-04-11 02:30:29 +02:00
|
|
|
void init_cell_pool(void);
|
|
|
|
void free_cell_pool(void);
|
2007-04-11 15:18:25 +02:00
|
|
|
void clean_cell_pool(void);
|
2007-04-19 20:47:04 +02:00
|
|
|
void dump_cell_pool_usage(int severity);
|
2007-04-11 02:30:29 +02:00
|
|
|
|
2007-03-26 16:07:59 +02:00
|
|
|
void cell_queue_clear(cell_queue_t *queue);
|
2007-04-10 01:15:46 +02:00
|
|
|
void cell_queue_append(cell_queue_t *queue, packed_cell_t *cell);
|
|
|
|
void cell_queue_append_packed_copy(cell_queue_t *queue, const cell_t *cell);
|
2007-03-26 16:07:59 +02:00
|
|
|
|
|
|
|
void append_cell_to_circuit_queue(circuit_t *circ, or_connection_t *orconn,
|
2008-12-17 18:20:19 +01:00
|
|
|
cell_t *cell, cell_direction_t direction);
|
2007-03-26 16:07:59 +02:00
|
|
|
void connection_or_unlink_all_active_circs(or_connection_t *conn);
|
|
|
|
int connection_or_flush_from_first_active_circuit(or_connection_t *conn,
|
2008-04-09 20:44:50 +02:00
|
|
|
int max, time_t now);
|
2007-03-26 16:07:59 +02:00
|
|
|
void assert_active_circuits_ok(or_connection_t *orconn);
|
|
|
|
void make_circuit_inactive_on_conn(circuit_t *circ, or_connection_t *conn);
|
|
|
|
void make_circuit_active_on_conn(circuit_t *circ, or_connection_t *conn);
|
|
|
|
|
2008-08-05 22:08:19 +02:00
|
|
|
int append_address_to_payload(char *payload_out, const tor_addr_t *addr);
|
|
|
|
const char *decode_address_from_payload(tor_addr_t *addr_out,
|
|
|
|
const char *payload,
|
|
|
|
int payload_len);
|
|
|
|
|
2004-03-20 02:48:05 +01:00
|
|
|
/********************************* rephist.c ***************************/
|
|
|
|
|
|
|
|
void rep_hist_init(void);
|
|
|
|
void rep_hist_note_connect_failed(const char* nickname, time_t when);
|
|
|
|
void rep_hist_note_connect_succeeded(const char* nickname, time_t when);
|
2004-03-20 05:59:29 +01:00
|
|
|
void rep_hist_note_disconnect(const char* nickname, time_t when);
|
2004-03-20 02:48:05 +01:00
|
|
|
void rep_hist_note_connection_died(const char* nickname, time_t when);
|
|
|
|
void rep_hist_note_extend_succeeded(const char *from_name,
|
2004-04-03 00:23:15 +02:00
|
|
|
const char *to_name);
|
2004-03-20 02:48:05 +01:00
|
|
|
void rep_hist_note_extend_failed(const char *from_name, const char *to_name);
|
2004-03-20 05:59:29 +01:00
|
|
|
void rep_hist_dump_stats(time_t now, int severity);
|
2008-02-20 03:17:41 +01:00
|
|
|
void rep_hist_note_bytes_read(size_t num_bytes, time_t when);
|
|
|
|
void rep_hist_note_bytes_written(size_t num_bytes, time_t when);
|
2009-08-19 15:41:12 +02:00
|
|
|
void rep_hist_note_exit_bytes_read(uint16_t port, size_t num_bytes);
|
|
|
|
void rep_hist_note_exit_bytes_written(uint16_t port, size_t num_bytes);
|
|
|
|
void rep_hist_note_exit_stream_opened(uint16_t port);
|
|
|
|
void rep_hist_exit_stats_init(time_t now);
|
|
|
|
void rep_hist_exit_stats_write(time_t now);
|
2004-08-07 04:46:16 +02:00
|
|
|
int rep_hist_bandwidth_assess(void);
|
2007-04-16 20:54:56 +02:00
|
|
|
char *rep_hist_get_bandwidth_lines(int for_extrainfo);
|
2006-05-30 08:19:06 +02:00
|
|
|
void rep_hist_update_state(or_state_t *state);
|
|
|
|
int rep_hist_load_state(or_state_t *state, char **err);
|
2004-11-21 06:14:46 +01:00
|
|
|
void rep_history_clean(time_t before);
|
Introduce a notion of 'internal' circs, which are chosen without regard
to the exit policy of the last hop. Intro and rendezvous circs must
be internal circs, to avoid leaking information. Resolve and connect
streams can use internal circs if they want.
New circuit pooling algorithm: make sure to have enough circs around
to satisfy any predicted ports, and also make sure to have 2 internal
circs around if we've required internal circs lately (with high uptime
if we've seen that lately).
Split NewCircuitPeriod config option into NewCircuitPeriod (30 secs),
which describes how often we retry making new circuits if current ones
are dirty, and MaxCircuitDirtiness (10 mins), which describes how long
we're willing to make use of an already-dirty circuit.
Once rendezvous circuits are established, keep using the same circuit as
long as you attach a new stream to it at least every 10 minutes. (So web
browsing doesn't require you to build new rend circs every 30 seconds.)
Cannibalize GENERAL circs to be C_REND, C_INTRO, S_INTRO, and S_REND
circ as necessary, if there are any completed ones lying around when
we try to launch one.
Re-instate the ifdef's to use version-0 style introduce cells, since
there was yet another bug in handling version-1 style. We'll try switching
over again after 0.0.9 is obsolete.
Bugfix: when choosing an exit node for a new non-internal circ, don't take
into account whether it'll be useful for any pending x.onion addresses --
it won't.
Bugfix: we weren't actually publishing the hidden service descriptor when
it became dirty. So we only published it every 20 minutes or so, which
means when you first start your Tor, the hidden service will seem broken.
svn:r3360
2005-01-17 19:13:09 +01:00
|
|
|
|
2007-08-17 03:29:58 +02:00
|
|
|
void rep_hist_note_router_reachable(const char *id, time_t when);
|
|
|
|
void rep_hist_note_router_unreachable(const char *id, time_t when);
|
2009-06-20 11:25:14 +02:00
|
|
|
int rep_hist_record_mtbf_data(time_t now, int missing_means_down);
|
2007-08-20 18:34:17 +02:00
|
|
|
int rep_hist_load_mtbf_data(time_t now);
|
2007-08-17 03:29:58 +02:00
|
|
|
|
2007-08-16 21:32:29 +02:00
|
|
|
time_t rep_hist_downrate_old_runs(time_t now);
|
|
|
|
double rep_hist_get_stability(const char *id, time_t when);
|
2007-09-17 20:27:49 +02:00
|
|
|
double rep_hist_get_weighted_fractional_uptime(const char *id, time_t when);
|
2007-11-08 17:58:59 +01:00
|
|
|
long rep_hist_get_weighted_time_known(const char *id, time_t when);
|
2007-08-21 07:37:24 +02:00
|
|
|
int rep_hist_have_measured_enough_stability(void);
|
2008-09-26 20:02:48 +02:00
|
|
|
const char *rep_hist_get_router_stability_doc(time_t now);
|
2007-08-16 21:32:29 +02:00
|
|
|
|
2008-04-16 02:10:39 +02:00
|
|
|
void rep_hist_note_used_port(time_t now, uint16_t port);
|
2004-12-07 16:29:54 +01:00
|
|
|
smartlist_t *rep_hist_get_predicted_ports(time_t now);
|
Introduce a notion of 'internal' circs, which are chosen without regard
to the exit policy of the last hop. Intro and rendezvous circs must
be internal circs, to avoid leaking information. Resolve and connect
streams can use internal circs if they want.
New circuit pooling algorithm: make sure to have enough circs around
to satisfy any predicted ports, and also make sure to have 2 internal
circs around if we've required internal circs lately (with high uptime
if we've seen that lately).
Split NewCircuitPeriod config option into NewCircuitPeriod (30 secs),
which describes how often we retry making new circuits if current ones
are dirty, and MaxCircuitDirtiness (10 mins), which describes how long
we're willing to make use of an already-dirty circuit.
Once rendezvous circuits are established, keep using the same circuit as
long as you attach a new stream to it at least every 10 minutes. (So web
browsing doesn't require you to build new rend circs every 30 seconds.)
Cannibalize GENERAL circs to be C_REND, C_INTRO, S_INTRO, and S_REND
circ as necessary, if there are any completed ones lying around when
we try to launch one.
Re-instate the ifdef's to use version-0 style introduce cells, since
there was yet another bug in handling version-1 style. We'll try switching
over again after 0.0.9 is obsolete.
Bugfix: when choosing an exit node for a new non-internal circ, don't take
into account whether it'll be useful for any pending x.onion addresses --
it won't.
Bugfix: we weren't actually publishing the hidden service descriptor when
it became dirty. So we only published it every 20 minutes or so, which
means when you first start your Tor, the hidden service will seem broken.
svn:r3360
2005-01-17 19:13:09 +01:00
|
|
|
void rep_hist_note_used_resolve(time_t now);
|
2005-12-14 21:40:40 +01:00
|
|
|
void rep_hist_note_used_internal(time_t now, int need_uptime,
|
|
|
|
int need_capacity);
|
|
|
|
int rep_hist_get_predicted_internal(time_t now, int *need_uptime,
|
|
|
|
int *need_capacity);
|
2004-03-20 02:48:05 +01:00
|
|
|
|
2006-07-22 09:15:34 +02:00
|
|
|
int any_predicted_circuits(time_t now);
|
2006-06-09 00:36:13 +02:00
|
|
|
int rep_hist_circbuilding_dormant(time_t now);
|
2005-12-24 00:56:42 +01:00
|
|
|
|
2007-02-16 21:01:02 +01:00
|
|
|
/** Possible public/private key operations in Tor: used to keep track of where
|
|
|
|
* we're spending our time. */
|
2006-10-31 20:17:07 +01:00
|
|
|
typedef enum {
|
|
|
|
SIGN_DIR, SIGN_RTR,
|
|
|
|
VERIFY_DIR, VERIFY_RTR,
|
|
|
|
ENC_ONIONSKIN, DEC_ONIONSKIN,
|
|
|
|
TLS_HANDSHAKE_C, TLS_HANDSHAKE_S,
|
|
|
|
REND_CLIENT, REND_MID, REND_SERVER,
|
|
|
|
} pk_op_t;
|
|
|
|
void note_crypto_pk_op(pk_op_t operation);
|
|
|
|
void dump_pk_ops(int severity);
|
|
|
|
|
2005-02-11 00:18:39 +01:00
|
|
|
void rep_hist_free_all(void);
|
|
|
|
|
2007-05-01 01:25:22 +02:00
|
|
|
/* for hidden service usage statistics */
|
2007-04-30 19:46:13 +02:00
|
|
|
void hs_usage_note_publish_total(const char *service_id, time_t now);
|
|
|
|
void hs_usage_note_publish_novel(const char *service_id, time_t now);
|
|
|
|
void hs_usage_note_fetch_total(const char *service_id, time_t now);
|
|
|
|
void hs_usage_note_fetch_successful(const char *service_id, time_t now);
|
|
|
|
void hs_usage_write_statistics_to_file(time_t now);
|
|
|
|
void hs_usage_free_all(void);
|
|
|
|
|
2009-08-19 15:41:12 +02:00
|
|
|
void rep_hist_buffer_stats_init(time_t now);
|
|
|
|
void rep_hist_buffer_stats_add_circ(circuit_t *circ,
|
|
|
|
time_t end_of_interval);
|
|
|
|
void rep_hist_buffer_stats_write(time_t now);
|
2009-07-05 19:53:25 +02:00
|
|
|
|
2004-04-03 00:23:15 +02:00
|
|
|
/********************************* rendclient.c ***************************/
|
|
|
|
|
2006-07-23 09:37:35 +02:00
|
|
|
void rend_client_introcirc_has_opened(origin_circuit_t *circ);
|
|
|
|
void rend_client_rendcirc_has_opened(origin_circuit_t *circ);
|
|
|
|
int rend_client_introduction_acked(origin_circuit_t *circ, const char *request,
|
2005-12-14 21:40:40 +01:00
|
|
|
size_t request_len);
|
2008-09-24 16:44:29 +02:00
|
|
|
void rend_client_refetch_v2_renddesc(const rend_data_t *rend_query);
|
2005-12-14 21:40:40 +01:00
|
|
|
int rend_client_remove_intro_point(extend_info_t *failed_intro,
|
2008-09-24 16:44:29 +02:00
|
|
|
const rend_data_t *rend_query);
|
2006-07-23 09:37:35 +02:00
|
|
|
int rend_client_rendezvous_acked(origin_circuit_t *circ, const char *request,
|
2005-12-14 21:40:40 +01:00
|
|
|
size_t request_len);
|
2006-07-23 09:37:35 +02:00
|
|
|
int rend_client_receive_rendezvous(origin_circuit_t *circ, const char *request,
|
2005-12-14 21:40:40 +01:00
|
|
|
size_t request_len);
|
2009-05-03 01:04:25 +02:00
|
|
|
void rend_client_desc_trynow(const char *query);
|
2004-04-03 00:23:15 +02:00
|
|
|
|
2008-09-24 16:44:29 +02:00
|
|
|
extend_info_t *rend_client_get_random_intro(const rend_data_t *rend_query);
|
2004-04-03 03:59:53 +02:00
|
|
|
|
2006-07-23 09:37:35 +02:00
|
|
|
int rend_client_send_introduction(origin_circuit_t *introcirc,
|
|
|
|
origin_circuit_t *rendcirc);
|
2008-08-12 18:12:26 +02:00
|
|
|
int rend_parse_service_authorization(or_options_t *options,
|
|
|
|
int validate_only);
|
|
|
|
rend_service_authorization_t *rend_client_lookup_service_authorization(
|
|
|
|
const char *onion_address);
|
|
|
|
void rend_service_authorization_free_all(void);
|
2008-09-24 16:44:29 +02:00
|
|
|
rend_data_t *rend_data_dup(const rend_data_t *request);
|
2008-08-12 18:12:26 +02:00
|
|
|
|
2004-03-30 21:52:42 +02:00
|
|
|
/********************************* rendcommon.c ***************************/
|
|
|
|
|
2008-08-08 16:36:11 +02:00
|
|
|
/** Hidden-service side configuration of client authorization. */
|
|
|
|
typedef struct rend_authorized_client_t {
|
|
|
|
char *client_name;
|
|
|
|
char descriptor_cookie[REND_DESC_COOKIE_LEN];
|
|
|
|
crypto_pk_env_t *client_key;
|
|
|
|
} rend_authorized_client_t;
|
|
|
|
|
2007-12-15 21:28:09 +01:00
|
|
|
/** ASCII-encoded v2 hidden service descriptor. */
|
|
|
|
typedef struct rend_encoded_v2_service_descriptor_t {
|
|
|
|
char desc_id[DIGEST_LEN]; /**< Descriptor ID. */
|
|
|
|
char *desc_str; /**< Descriptor string. */
|
|
|
|
} rend_encoded_v2_service_descriptor_t;
|
|
|
|
|
2007-12-21 10:28:22 +01:00
|
|
|
/** Introduction point information. */
|
|
|
|
typedef struct rend_intro_point_t {
|
|
|
|
extend_info_t *extend_info; /**< Extend info of this introduction point. */
|
|
|
|
crypto_pk_env_t *intro_key; /**< Introduction key that replaces the service
|
|
|
|
* key, if this descriptor is V2. */
|
|
|
|
} rend_intro_point_t;
|
|
|
|
|
2005-07-14 10:43:19 +02:00
|
|
|
/** Information used to connect to a hidden service. */
|
2004-03-31 04:07:38 +02:00
|
|
|
typedef struct rend_service_descriptor_t {
|
2005-06-29 23:46:55 +02:00
|
|
|
crypto_pk_env_t *pk; /**< This service's public key. */
|
2007-10-28 20:48:16 +01:00
|
|
|
int version; /**< Version of the descriptor format: 0 or 2. */
|
2005-06-29 23:46:55 +02:00
|
|
|
time_t timestamp; /**< Time when the descriptor was generated. */
|
2005-07-14 10:43:19 +02:00
|
|
|
uint16_t protocols; /**< Bitmask: which rendezvous protocols are supported?
|
2005-06-29 23:46:55 +02:00
|
|
|
* (We allow bits '0', '1', and '2' to be set.) */
|
2007-12-21 10:28:22 +01:00
|
|
|
/** List of the service's introduction points. Elements are removed if
|
|
|
|
* introduction attempts fail. */
|
|
|
|
smartlist_t *intro_nodes;
|
2008-09-09 10:41:58 +02:00
|
|
|
/** Has descriptor been uploaded to all hidden service directories? */
|
|
|
|
int all_uploads_performed;
|
|
|
|
/** List of hidden service directories to which an upload request for
|
|
|
|
* this descriptor could be sent. Smartlist exists only when at least one
|
|
|
|
* of the previous upload requests failed (otherwise it's not important
|
|
|
|
* to know which uploads succeeded and which not). */
|
|
|
|
smartlist_t *successful_uploads;
|
2004-03-31 04:07:38 +02:00
|
|
|
} rend_service_descriptor_t;
|
|
|
|
|
2008-09-24 16:44:29 +02:00
|
|
|
/** Free all storage associated with <b>data</b> */
|
|
|
|
static INLINE void
|
|
|
|
rend_data_free(rend_data_t *data)
|
|
|
|
{
|
|
|
|
tor_free(data);
|
|
|
|
}
|
|
|
|
|
2004-05-12 22:58:27 +02:00
|
|
|
int rend_cmp_service_ids(const char *one, const char *two);
|
|
|
|
|
2008-10-27 17:46:45 +01:00
|
|
|
void rend_process_relay_cell(circuit_t *circ, const crypt_path_t *layer_hint,
|
|
|
|
int command, size_t length, const char *payload);
|
2004-04-03 05:37:11 +02:00
|
|
|
|
2004-03-31 04:07:38 +02:00
|
|
|
void rend_service_descriptor_free(rend_service_descriptor_t *desc);
|
2005-12-14 21:40:40 +01:00
|
|
|
rend_service_descriptor_t *rend_parse_service_descriptor(const char *str,
|
|
|
|
size_t len);
|
2004-03-31 05:42:56 +02:00
|
|
|
int rend_get_service_id(crypto_pk_env_t *pk, char *out);
|
2007-12-15 21:28:09 +01:00
|
|
|
void rend_encoded_v2_service_descriptor_free(
|
|
|
|
rend_encoded_v2_service_descriptor_t *desc);
|
2007-12-21 10:28:22 +01:00
|
|
|
void rend_intro_point_free(rend_intro_point_t *intro);
|
2004-03-31 05:42:56 +02:00
|
|
|
|
2005-10-06 06:33:40 +02:00
|
|
|
/** A cached rendezvous descriptor. */
|
2004-04-08 00:00:54 +02:00
|
|
|
typedef struct rend_cache_entry_t {
|
2007-01-23 20:22:52 +01:00
|
|
|
size_t len; /**< Length of <b>desc</b> */
|
|
|
|
time_t received; /**< When was the descriptor received? */
|
|
|
|
char *desc; /**< Service descriptor */
|
|
|
|
rend_service_descriptor_t *parsed; /**< Parsed value of 'desc' */
|
2004-04-08 00:00:54 +02:00
|
|
|
} rend_cache_entry_t;
|
|
|
|
|
2004-03-31 06:10:10 +02:00
|
|
|
void rend_cache_init(void);
|
|
|
|
void rend_cache_clean(void);
|
2007-11-02 03:25:28 +01:00
|
|
|
void rend_cache_clean_v2_descs_as_dir(void);
|
2005-02-28 23:38:00 +01:00
|
|
|
void rend_cache_free_all(void);
|
2004-05-05 23:32:43 +02:00
|
|
|
int rend_valid_service_id(const char *query);
|
2005-12-14 21:40:40 +01:00
|
|
|
int rend_cache_lookup_desc(const char *query, int version, const char **desc,
|
|
|
|
size_t *desc_len);
|
|
|
|
int rend_cache_lookup_entry(const char *query, int version,
|
|
|
|
rend_cache_entry_t **entry_out);
|
2007-10-31 21:48:06 +01:00
|
|
|
int rend_cache_lookup_v2_desc_as_dir(const char *query, const char **desc);
|
2007-04-30 19:46:13 +02:00
|
|
|
int rend_cache_store(const char *desc, size_t desc_len, int published);
|
2007-10-29 20:10:47 +01:00
|
|
|
int rend_cache_store_v2_desc_as_client(const char *desc,
|
2008-09-24 16:44:29 +02:00
|
|
|
const rend_data_t *rend_query);
|
2007-10-29 20:10:47 +01:00
|
|
|
int rend_cache_store_v2_desc_as_dir(const char *desc);
|
2007-04-30 19:46:13 +02:00
|
|
|
int rend_cache_size(void);
|
2007-12-15 21:28:09 +01:00
|
|
|
int rend_encode_v2_descriptors(smartlist_t *descs_out,
|
2007-10-28 20:48:14 +01:00
|
|
|
rend_service_descriptor_t *desc, time_t now,
|
2008-08-19 17:41:28 +02:00
|
|
|
uint8_t period, rend_auth_type_t auth_type,
|
|
|
|
crypto_pk_env_t *client_key,
|
|
|
|
smartlist_t *client_cookies);
|
2007-10-28 20:48:14 +01:00
|
|
|
int rend_compute_v2_desc_id(char *desc_id_out, const char *service_id,
|
|
|
|
const char *descriptor_cookie,
|
|
|
|
time_t now, uint8_t replica);
|
|
|
|
int rend_id_is_in_interval(const char *a, const char *b, const char *c);
|
|
|
|
void rend_get_descriptor_id_bytes(char *descriptor_id_out,
|
|
|
|
const char *service_id,
|
|
|
|
const char *secret_id_part);
|
2004-03-31 04:07:38 +02:00
|
|
|
|
2004-03-31 23:35:23 +02:00
|
|
|
/********************************* rendservice.c ***************************/
|
|
|
|
|
2005-08-13 02:22:07 +02:00
|
|
|
int num_rend_services(void);
|
2004-11-09 00:12:40 +01:00
|
|
|
int rend_config_services(or_options_t *options, int validate_only);
|
2004-04-13 19:16:47 +02:00
|
|
|
int rend_service_load_keys(void);
|
2004-04-13 07:20:52 +02:00
|
|
|
void rend_services_init(void);
|
2004-04-13 19:16:47 +02:00
|
|
|
void rend_services_introduce(void);
|
2004-11-15 10:05:54 +01:00
|
|
|
void rend_consider_services_upload(time_t now);
|
2008-09-09 10:41:58 +02:00
|
|
|
void rend_hsdir_routers_changed(void);
|
|
|
|
void rend_consider_descriptor_republication(void);
|
2004-03-31 23:35:23 +02:00
|
|
|
|
2006-07-23 09:37:35 +02:00
|
|
|
void rend_service_intro_has_opened(origin_circuit_t *circuit);
|
|
|
|
int rend_service_intro_established(origin_circuit_t *circuit,
|
|
|
|
const char *request,
|
2005-12-14 21:40:40 +01:00
|
|
|
size_t request_len);
|
2006-07-23 09:37:35 +02:00
|
|
|
void rend_service_rendezvous_has_opened(origin_circuit_t *circuit);
|
|
|
|
int rend_service_introduce(origin_circuit_t *circuit, const char *request,
|
2005-12-14 21:40:40 +01:00
|
|
|
size_t request_len);
|
2006-07-23 09:37:35 +02:00
|
|
|
void rend_service_relaunch_rendezvous(origin_circuit_t *oldcirc);
|
2006-07-26 21:07:26 +02:00
|
|
|
int rend_service_set_connection_addr_port(edge_connection_t *conn,
|
2006-07-23 09:37:35 +02:00
|
|
|
origin_circuit_t *circ);
|
2004-04-09 22:02:16 +02:00
|
|
|
void rend_service_dump_stats(int severity);
|
2005-02-11 00:18:39 +01:00
|
|
|
void rend_service_free_all(void);
|
2004-04-03 05:37:11 +02:00
|
|
|
|
|
|
|
/********************************* rendmid.c *******************************/
|
2006-07-23 09:37:35 +02:00
|
|
|
int rend_mid_establish_intro(or_circuit_t *circ, const char *request,
|
2005-12-14 21:40:40 +01:00
|
|
|
size_t request_len);
|
2006-07-23 09:37:35 +02:00
|
|
|
int rend_mid_introduce(or_circuit_t *circ, const char *request,
|
2005-12-14 21:40:40 +01:00
|
|
|
size_t request_len);
|
2006-07-23 09:37:35 +02:00
|
|
|
int rend_mid_establish_rendezvous(or_circuit_t *circ, const char *request,
|
2005-12-14 21:40:40 +01:00
|
|
|
size_t request_len);
|
2006-07-23 09:37:35 +02:00
|
|
|
int rend_mid_rendezvous(or_circuit_t *circ, const char *request,
|
2005-12-14 21:40:40 +01:00
|
|
|
size_t request_len);
|
2004-04-02 00:21:01 +02:00
|
|
|
|
2004-05-12 21:49:48 +02:00
|
|
|
/********************************* router.c ***************************/
|
|
|
|
|
|
|
|
crypto_pk_env_t *get_onion_key(void);
|
|
|
|
time_t get_onion_key_set_at(void);
|
|
|
|
void set_identity_key(crypto_pk_env_t *k);
|
|
|
|
crypto_pk_env_t *get_identity_key(void);
|
2004-11-21 05:19:04 +01:00
|
|
|
int identity_key_is_set(void);
|
2007-05-22 20:52:32 +02:00
|
|
|
authority_cert_t *get_my_v3_authority_cert(void);
|
|
|
|
crypto_pk_env_t *get_my_v3_authority_signing_key(void);
|
2008-05-12 04:14:01 +02:00
|
|
|
authority_cert_t *get_my_v3_legacy_cert(void);
|
|
|
|
crypto_pk_env_t *get_my_v3_legacy_signing_key(void);
|
2004-06-05 03:50:35 +02:00
|
|
|
void dup_onion_keys(crypto_pk_env_t **key, crypto_pk_env_t **last);
|
2004-05-12 21:49:48 +02:00
|
|
|
void rotate_onion_key(void);
|
2007-05-29 19:31:13 +02:00
|
|
|
crypto_pk_env_t *init_key_from_file(const char *fname, int generate,
|
|
|
|
int severity);
|
2007-09-11 22:17:22 +02:00
|
|
|
void v3_authority_check_key_expiry(void);
|
|
|
|
|
2005-02-27 10:47:01 +01:00
|
|
|
int init_keys(void);
|
|
|
|
|
2005-03-31 21:26:33 +02:00
|
|
|
int check_whether_orport_reachable(void);
|
|
|
|
int check_whether_dirport_reachable(void);
|
2006-09-15 07:53:00 +02:00
|
|
|
void consider_testing_reachability(int test_or, int test_dir);
|
2005-02-27 10:47:01 +01:00
|
|
|
void router_orport_found_reachable(void);
|
|
|
|
void router_dirport_found_reachable(void);
|
2006-09-15 07:30:25 +02:00
|
|
|
void router_perform_bandwidth_test(int num_circs, time_t now);
|
2005-02-27 10:47:01 +01:00
|
|
|
|
|
|
|
int authdir_mode(or_options_t *options);
|
2007-05-02 11:12:04 +02:00
|
|
|
int authdir_mode_v1(or_options_t *options);
|
|
|
|
int authdir_mode_v2(or_options_t *options);
|
2007-07-26 00:56:44 +02:00
|
|
|
int authdir_mode_v3(or_options_t *options);
|
2007-12-21 07:33:02 +01:00
|
|
|
int authdir_mode_any_main(or_options_t *options);
|
|
|
|
int authdir_mode_any_nonhidserv(or_options_t *options);
|
2007-12-19 00:45:24 +01:00
|
|
|
int authdir_mode_handles_descs(or_options_t *options, int purpose);
|
2007-06-09 09:05:19 +02:00
|
|
|
int authdir_mode_publishes_statuses(or_options_t *options);
|
|
|
|
int authdir_mode_tests_reachability(or_options_t *options);
|
2007-05-04 10:04:27 +02:00
|
|
|
int authdir_mode_bridge(or_options_t *options);
|
2007-12-21 07:33:02 +01:00
|
|
|
|
2005-02-27 10:47:01 +01:00
|
|
|
int clique_mode(or_options_t *options);
|
|
|
|
int server_mode(or_options_t *options);
|
|
|
|
int advertised_server_mode(void);
|
|
|
|
int proxy_mode(or_options_t *options);
|
2006-09-15 07:30:25 +02:00
|
|
|
void consider_publishable_server(int force);
|
2004-05-12 21:49:48 +02:00
|
|
|
|
2004-07-20 21:45:29 +02:00
|
|
|
int router_is_clique_mode(routerinfo_t *router);
|
2004-11-13 17:53:48 +01:00
|
|
|
void router_upload_dir_desc_to_dirservers(int force);
|
2005-08-22 05:10:53 +02:00
|
|
|
void mark_my_descriptor_dirty_if_older_than(time_t when);
|
2004-11-13 17:53:48 +01:00
|
|
|
void mark_my_descriptor_dirty(void);
|
2005-08-22 05:10:53 +02:00
|
|
|
void check_descriptor_bandwidth_changed(time_t now);
|
2005-10-13 00:41:16 +02:00
|
|
|
void check_descriptor_ipaddress_changed(time_t now);
|
2008-02-09 11:46:22 +01:00
|
|
|
void router_new_address_suggestion(const char *suggestion,
|
|
|
|
const dir_connection_t *d_conn);
|
2006-07-26 21:07:26 +02:00
|
|
|
int router_compare_to_my_exit_policy(edge_connection_t *conn);
|
2004-05-12 21:49:48 +02:00
|
|
|
routerinfo_t *router_get_my_routerinfo(void);
|
2007-04-16 20:39:39 +02:00
|
|
|
extrainfo_t *router_get_my_extrainfo(void);
|
2004-05-12 21:49:48 +02:00
|
|
|
const char *router_get_my_descriptor(void);
|
2005-05-23 07:20:52 +02:00
|
|
|
int router_digest_is_me(const char *digest);
|
2008-02-24 23:11:12 +01:00
|
|
|
int router_extrainfo_digest_is_me(const char *digest);
|
2004-05-12 21:49:48 +02:00
|
|
|
int router_is_me(routerinfo_t *router);
|
2005-09-08 22:18:15 +02:00
|
|
|
int router_fingerprint_is_me(const char *fp);
|
2006-09-09 05:18:39 +02:00
|
|
|
int router_pick_published_address(or_options_t *options, uint32_t *addr);
|
2004-11-13 17:53:48 +01:00
|
|
|
int router_rebuild_descriptor(int force);
|
2004-10-14 04:47:09 +02:00
|
|
|
int router_dump_router_to_string(char *s, size_t maxlen, routerinfo_t *router,
|
2004-05-12 21:49:48 +02:00
|
|
|
crypto_pk_env_t *ident_key);
|
2007-04-16 19:55:08 +02:00
|
|
|
int extrainfo_dump_to_string(char *s, size_t maxlen, extrainfo_t *extrainfo,
|
|
|
|
crypto_pk_env_t *ident_key);
|
2009-01-28 07:50:36 +01:00
|
|
|
char *extrainfo_get_client_geoip_summary(time_t);
|
2004-08-18 06:44:24 +02:00
|
|
|
int is_legal_nickname(const char *s);
|
|
|
|
int is_legal_nickname_or_hexdigest(const char *s);
|
2006-03-15 06:06:26 +01:00
|
|
|
int is_legal_hexdigest(const char *s);
|
2009-03-18 20:30:26 +01:00
|
|
|
void router_get_verbose_nickname(char *buf, const routerinfo_t *router);
|
2009-03-18 20:30:37 +01:00
|
|
|
void routerstatus_get_verbose_nickname(char *buf,
|
|
|
|
const routerstatus_t *router);
|
2005-10-06 01:20:45 +02:00
|
|
|
void router_reset_warnings(void);
|
2006-12-28 22:29:20 +01:00
|
|
|
void router_reset_reachability(void);
|
2005-10-06 01:20:45 +02:00
|
|
|
void router_free_all(void);
|
2004-05-12 21:49:48 +02:00
|
|
|
|
2007-09-27 22:46:30 +02:00
|
|
|
const char *router_purpose_to_string(uint8_t p);
|
|
|
|
uint8_t router_purpose_from_string(const char *s);
|
|
|
|
|
2007-04-11 15:18:25 +02:00
|
|
|
#ifdef ROUTER_PRIVATE
|
|
|
|
/* Used only by router.c and test.c */
|
|
|
|
void get_platform_str(char *platform, size_t len);
|
|
|
|
#endif
|
|
|
|
|
2004-05-12 21:49:48 +02:00
|
|
|
/********************************* routerlist.c ***************************/
|
|
|
|
|
2005-09-13 23:14:55 +02:00
|
|
|
/** Represents information about a single trusted directory server. */
|
2004-10-12 17:55:20 +02:00
|
|
|
typedef struct trusted_dir_server_t {
|
2005-10-04 23:21:09 +02:00
|
|
|
char *description;
|
|
|
|
char *nickname;
|
2007-01-03 11:30:26 +01:00
|
|
|
char *address; /**< Hostname. */
|
|
|
|
uint32_t addr; /**< IPv4 address. */
|
|
|
|
uint16_t dir_port; /**< Directory port. */
|
|
|
|
uint16_t or_port; /**< OR port: Used for tunneling connections. */
|
|
|
|
char digest[DIGEST_LEN]; /**< Digest of identity key. */
|
2007-05-22 19:58:25 +02:00
|
|
|
char v3_identity_digest[DIGEST_LEN]; /**< Digest of v3 (authority only,
|
|
|
|
* high-security) identity key. */
|
|
|
|
|
2005-09-13 23:14:55 +02:00
|
|
|
unsigned int is_running:1; /**< True iff we think this server is running. */
|
2007-05-09 06:15:46 +02:00
|
|
|
|
2007-01-06 06:42:31 +01:00
|
|
|
/** True iff this server has accepted the most recent server descriptor
|
|
|
|
* we tried to upload to it. */
|
|
|
|
unsigned int has_accepted_serverdesc:1;
|
2006-09-29 01:57:59 +02:00
|
|
|
|
2007-05-29 19:31:13 +02:00
|
|
|
/** What kind of authority is this? (Bitfield.) */
|
2007-05-09 06:15:46 +02:00
|
|
|
authority_type_t type;
|
|
|
|
|
2007-10-09 17:27:45 +02:00
|
|
|
download_status_t v2_ns_dl_status; /**< Status of downloading this server's
|
|
|
|
* v2 network status. */
|
2007-11-01 05:14:23 +01:00
|
|
|
time_t addr_current_at; /**< When was the document that we derived the
|
|
|
|
* address information from published? */
|
2007-05-22 19:58:25 +02:00
|
|
|
|
2007-10-09 17:27:15 +02:00
|
|
|
routerstatus_t fake_status; /**< Used when we need to pass this trusted
|
2005-12-15 21:44:15 +01:00
|
|
|
* dir_server_t to directory_initiate_command_*
|
|
|
|
* as a routerstatus_t. Not updated by the
|
|
|
|
* router-status management code!
|
|
|
|
**/
|
2004-10-12 17:55:20 +02:00
|
|
|
} trusted_dir_server_t;
|
|
|
|
|
2009-04-12 09:56:58 +02:00
|
|
|
#define ROUTER_REQUIRED_MIN_BANDWIDTH (20*1024)
|
2007-10-11 18:06:47 +02:00
|
|
|
|
|
|
|
#define ROUTER_MAX_DECLARED_BANDWIDTH INT32_MAX
|
|
|
|
|
2007-06-10 09:34:21 +02:00
|
|
|
int get_n_authorities(authority_type_t type);
|
2007-10-11 18:06:47 +02:00
|
|
|
int trusted_dirs_reload_certs(void);
|
2008-02-21 00:20:36 +01:00
|
|
|
int trusted_dirs_load_certs_from_string(const char *contents, int from_store,
|
|
|
|
int flush);
|
2007-10-11 18:06:47 +02:00
|
|
|
void trusted_dirs_flush_certs_to_disk(void);
|
|
|
|
authority_cert_t *authority_cert_get_newest_by_id(const char *id_digest);
|
|
|
|
authority_cert_t *authority_cert_get_by_sk_digest(const char *sk_digest);
|
|
|
|
authority_cert_t *authority_cert_get_by_digests(const char *id_digest,
|
|
|
|
const char *sk_digest);
|
2008-01-27 00:18:30 +01:00
|
|
|
void authority_cert_get_all(smartlist_t *certs_out);
|
|
|
|
void authority_cert_dl_failed(const char *id_digest, int status);
|
2008-02-05 22:39:29 +01:00
|
|
|
void authority_certs_fetch_missing(networkstatus_t *status, time_t now);
|
2007-10-11 18:06:47 +02:00
|
|
|
int router_reload_router_list(void);
|
2006-04-10 03:35:56 +02:00
|
|
|
smartlist_t *router_get_trusted_dir_servers(void);
|
2007-10-24 20:42:16 +02:00
|
|
|
|
|
|
|
/* Flags for pick_directory_server and pick_trusteddirserver. */
|
2008-12-11 20:12:48 +01:00
|
|
|
/** Flag to indicate that we should not automatically be willing to use
|
|
|
|
* ourself to answer a directory request.
|
|
|
|
* Passed to router_pick_directory_server (et al).*/
|
2007-10-24 20:42:16 +02:00
|
|
|
#define PDS_ALLOW_SELF (1<<0)
|
2008-12-11 20:12:48 +01:00
|
|
|
/** Flag to indicate that if no servers seem to be up, we should mark all
|
|
|
|
* directory servers as up and try again.
|
|
|
|
* Passed to router_pick_directory_server (et al).*/
|
2007-10-24 20:42:16 +02:00
|
|
|
#define PDS_RETRY_IF_NO_SERVERS (1<<1)
|
2008-12-11 20:12:48 +01:00
|
|
|
/** Flag to indicate that we should not exclude directory servers that
|
|
|
|
* our ReachableAddress settings would exclude. This usually means that
|
|
|
|
* we're going to connect to the server over Tor, and so we don't need to
|
|
|
|
* worry about our firewall telling us we can't.
|
|
|
|
* Passed to router_pick_directory_server (et al).*/
|
2007-10-24 20:42:16 +02:00
|
|
|
#define PDS_IGNORE_FASCISTFIREWALL (1<<2)
|
2008-12-11 20:12:48 +01:00
|
|
|
/** Flag to indicate that we should not use any directory authority to which
|
|
|
|
* we have an existing directory connection for downloading server descriptors
|
2008-12-11 20:12:55 +01:00
|
|
|
* or extrainfo documents.
|
|
|
|
*
|
|
|
|
* Passed to router_pick_directory_server (et al)
|
|
|
|
*
|
2008-12-18 17:11:24 +01:00
|
|
|
* [XXXX NOTE: This option is only implemented for pick_trusteddirserver,
|
2008-12-11 20:12:55 +01:00
|
|
|
* not pick_directory_server. If we make it work on pick_directory_server
|
|
|
|
* too, we could conservatively make it only prevent multiple fetches to
|
|
|
|
* the same authority, or we could aggressively make it prevent multiple
|
2008-12-18 17:11:24 +01:00
|
|
|
* fetches to _any_ single directory server.]
|
2008-12-11 20:12:55 +01:00
|
|
|
*/
|
2008-12-11 20:12:48 +01:00
|
|
|
#define PDS_NO_EXISTING_SERVERDESC_FETCH (1<<3)
|
2007-10-24 20:42:16 +02:00
|
|
|
#define _PDS_PREFER_TUNNELED_DIR_CONNS (1<<16)
|
|
|
|
routerstatus_t *router_pick_directory_server(authority_type_t type, int flags);
|
2007-10-11 18:06:47 +02:00
|
|
|
trusted_dir_server_t *router_get_trusteddirserver_by_digest(const char *d);
|
|
|
|
trusted_dir_server_t *trusteddirserver_get_by_v3_auth_digest(const char *d);
|
2007-10-24 20:42:16 +02:00
|
|
|
routerstatus_t *router_pick_trusteddirserver(authority_type_t type, int flags);
|
2008-06-10 20:28:10 +02:00
|
|
|
int router_get_my_share_of_directory_requests(double *v2_share_out,
|
|
|
|
double *v3_share_out);
|
2007-10-11 18:06:47 +02:00
|
|
|
void router_reset_status_download_failures(void);
|
2005-09-02 22:37:31 +02:00
|
|
|
void routerlist_add_family(smartlist_t *sl, routerinfo_t *router);
|
2007-10-11 23:40:35 +02:00
|
|
|
int routers_in_same_family(routerinfo_t *r1, routerinfo_t *r2);
|
2005-12-14 21:40:40 +01:00
|
|
|
void add_nickname_list_to_smartlist(smartlist_t *sl, const char *list,
|
2007-02-13 02:27:55 +01:00
|
|
|
int must_be_running);
|
2006-09-29 01:57:44 +02:00
|
|
|
int router_nickname_is_in_list(routerinfo_t *router, const char *list);
|
2004-08-18 12:32:50 +02:00
|
|
|
routerinfo_t *routerlist_find_my_routerinfo(void);
|
2005-12-14 21:40:40 +01:00
|
|
|
routerinfo_t *router_find_exact_exit_enclave(const char *address,
|
|
|
|
uint16_t port);
|
|
|
|
int router_is_unreliable(routerinfo_t *router, int need_uptime,
|
2006-02-12 04:43:39 +01:00
|
|
|
int need_capacity, int need_guard);
|
2006-03-28 14:01:58 +02:00
|
|
|
uint32_t router_get_advertised_bandwidth(routerinfo_t *router);
|
2008-08-13 21:25:18 +02:00
|
|
|
uint32_t router_get_advertised_bandwidth_capped(routerinfo_t *router);
|
2007-10-11 18:06:47 +02:00
|
|
|
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Possible ways to weight routers when choosing one randomly. See
|
|
|
|
* routerlist_sl_choose_by_bandwidth() for more information.*/
|
2007-08-24 14:33:53 +02:00
|
|
|
typedef enum {
|
|
|
|
NO_WEIGHTING, WEIGHT_FOR_EXIT, WEIGHT_FOR_GUARD
|
|
|
|
} bandwidth_weight_rule_t;
|
|
|
|
routerinfo_t *routerlist_sl_choose_by_bandwidth(smartlist_t *sl,
|
|
|
|
bandwidth_weight_rule_t rule);
|
2007-01-27 10:24:23 +01:00
|
|
|
routerstatus_t *routerstatus_sl_choose_by_bandwidth(smartlist_t *sl);
|
2008-07-24 11:22:34 +02:00
|
|
|
|
2008-12-17 18:20:31 +01:00
|
|
|
/** Flags to be passed to control router_choose_random_node() to indicate what
|
|
|
|
* kind of nodes to pick according to what algorithm. */
|
2008-07-24 11:22:34 +02:00
|
|
|
typedef enum {
|
|
|
|
CRN_NEED_UPTIME = 1<<0,
|
|
|
|
CRN_NEED_CAPACITY = 1<<1,
|
|
|
|
CRN_NEED_GUARD = 1<<2,
|
|
|
|
CRN_ALLOW_INVALID = 1<<3,
|
2008-12-18 17:11:24 +01:00
|
|
|
/* XXXX not used, apparently. */
|
2008-07-24 11:22:34 +02:00
|
|
|
CRN_STRICT_PREFERRED = 1<<4,
|
2008-12-18 17:11:24 +01:00
|
|
|
/* XXXX not used, apparently. */
|
2008-07-24 11:22:34 +02:00
|
|
|
CRN_WEIGHT_AS_EXIT = 1<<5
|
|
|
|
} router_crn_flags_t;
|
|
|
|
|
2004-10-27 23:14:11 +02:00
|
|
|
routerinfo_t *router_choose_random_node(const char *preferred,
|
2005-09-02 22:37:31 +02:00
|
|
|
smartlist_t *excludedsmartlist,
|
2008-07-18 20:36:32 +02:00
|
|
|
struct routerset_t *excludedset,
|
2008-07-24 11:22:34 +02:00
|
|
|
router_crn_flags_t flags);
|
|
|
|
|
2005-10-05 00:23:31 +02:00
|
|
|
routerinfo_t *router_get_by_nickname(const char *nickname,
|
|
|
|
int warn_if_unnamed);
|
2007-10-11 18:06:47 +02:00
|
|
|
int router_digest_version_as_new_as(const char *digest, const char *cutoff);
|
|
|
|
int router_digest_is_trusted_dir_type(const char *digest,
|
|
|
|
authority_type_t type);
|
|
|
|
#define router_digest_is_trusted_dir(d) \
|
2007-12-23 05:22:55 +01:00
|
|
|
router_digest_is_trusted_dir_type((d), NO_AUTHORITY)
|
2007-10-11 18:06:47 +02:00
|
|
|
|
|
|
|
int router_addr_is_trusted_dir(uint32_t addr);
|
2007-04-27 12:26:09 +02:00
|
|
|
int hexdigest_to_digest(const char *hexdigest, char *digest);
|
2004-07-01 03:16:59 +02:00
|
|
|
routerinfo_t *router_get_by_hexdigest(const char *hexdigest);
|
|
|
|
routerinfo_t *router_get_by_digest(const char *digest);
|
2005-11-05 21:15:27 +01:00
|
|
|
signed_descriptor_t *router_get_by_descriptor_digest(const char *digest);
|
2007-05-18 23:19:53 +02:00
|
|
|
signed_descriptor_t *router_get_by_extrainfo_digest(const char *digest);
|
2007-04-16 20:39:39 +02:00
|
|
|
signed_descriptor_t *extrainfo_get_by_descriptor_digest(const char *digest);
|
2006-01-12 19:04:17 +01:00
|
|
|
const char *signed_descriptor_get_body(signed_descriptor_t *desc);
|
2007-12-06 08:15:06 +01:00
|
|
|
const char *signed_descriptor_get_annotations(signed_descriptor_t *desc);
|
2005-10-18 19:43:54 +02:00
|
|
|
routerlist_t *router_get_routerlist(void);
|
2004-05-12 21:49:48 +02:00
|
|
|
void routerinfo_free(routerinfo_t *router);
|
2007-04-16 06:17:58 +02:00
|
|
|
void extrainfo_free(extrainfo_t *extrainfo);
|
2007-10-11 18:06:47 +02:00
|
|
|
void routerlist_free(routerlist_t *rl);
|
|
|
|
void dump_routerlist_mem_usage(int severity);
|
2009-06-20 07:52:59 +02:00
|
|
|
void routerlist_remove(routerlist_t *rl, routerinfo_t *ri, int make_old,
|
|
|
|
time_t now);
|
2005-09-15 01:42:06 +02:00
|
|
|
void routerlist_free_all(void);
|
2007-10-11 18:06:47 +02:00
|
|
|
void routerlist_reset_warnings(void);
|
2006-03-18 02:24:04 +01:00
|
|
|
void router_set_status(const char *digest, int up);
|
2008-12-17 22:50:01 +01:00
|
|
|
|
|
|
|
/** Return value for router_add_to_routerlist() and dirserv_add_descriptor() */
|
|
|
|
typedef enum was_router_added_t {
|
2008-12-22 07:25:49 +01:00
|
|
|
ROUTER_ADDED_SUCCESSFULLY = 1,
|
|
|
|
ROUTER_ADDED_NOTIFY_GENERATOR = 0,
|
2008-12-22 05:53:11 +01:00
|
|
|
ROUTER_BAD_EI = -1,
|
|
|
|
ROUTER_WAS_NOT_NEW = -2,
|
|
|
|
ROUTER_NOT_IN_CONSENSUS = -3,
|
|
|
|
ROUTER_NOT_IN_CONSENSUS_OR_NETWORKSTATUS = -4,
|
|
|
|
ROUTER_AUTHDIR_REJECTS = -5,
|
2008-12-17 22:50:01 +01:00
|
|
|
} was_router_added_t;
|
|
|
|
|
|
|
|
static int WRA_WAS_ADDED(was_router_added_t s);
|
|
|
|
static int WRA_WAS_OUTDATED(was_router_added_t s);
|
|
|
|
static int WRA_WAS_REJECTED(was_router_added_t s);
|
2008-12-22 17:37:20 +01:00
|
|
|
/** Return true iff the descriptor was added. It might still be necessary to
|
|
|
|
* check whether the descriptor generator should be notified.
|
|
|
|
*/
|
2008-12-17 22:50:01 +01:00
|
|
|
static INLINE int
|
|
|
|
WRA_WAS_ADDED(was_router_added_t s) {
|
|
|
|
return s == ROUTER_ADDED_SUCCESSFULLY || s == ROUTER_ADDED_NOTIFY_GENERATOR;
|
|
|
|
}
|
2008-12-22 17:37:20 +01:00
|
|
|
/** Return true iff the descriptor was not added because it was either:
|
|
|
|
* - not in the consensus
|
|
|
|
* - neither in the consensus nor in any networkstatus document
|
|
|
|
* - it was outdated.
|
|
|
|
*/
|
2008-12-17 22:50:01 +01:00
|
|
|
static INLINE int WRA_WAS_OUTDATED(was_router_added_t s)
|
|
|
|
{
|
|
|
|
return (s == ROUTER_WAS_NOT_NEW ||
|
|
|
|
s == ROUTER_NOT_IN_CONSENSUS ||
|
|
|
|
s == ROUTER_NOT_IN_CONSENSUS_OR_NETWORKSTATUS);
|
|
|
|
}
|
2008-12-22 17:37:20 +01:00
|
|
|
/** Return true iff the descriptor rejected because it was malformed. */
|
2008-12-17 22:50:01 +01:00
|
|
|
static INLINE int WRA_WAS_REJECTED(was_router_added_t s)
|
|
|
|
{
|
|
|
|
return (s == ROUTER_AUTHDIR_REJECTS);
|
|
|
|
}
|
|
|
|
was_router_added_t router_add_to_routerlist(routerinfo_t *router,
|
|
|
|
const char **msg,
|
|
|
|
int from_cache,
|
|
|
|
int from_fetch);
|
2008-12-22 05:53:11 +01:00
|
|
|
was_router_added_t router_add_extrainfo_to_routerlist(
|
|
|
|
extrainfo_t *ei, const char **msg,
|
2007-04-16 23:37:21 +02:00
|
|
|
int from_cache, int from_fetch);
|
2007-10-11 18:06:47 +02:00
|
|
|
void routerlist_remove_old_routers(void);
|
2007-10-12 09:57:29 +02:00
|
|
|
int router_load_single_router(const char *s, uint8_t purpose, int cache,
|
2006-03-17 23:08:59 +01:00
|
|
|
const char **msg);
|
2008-12-23 22:17:52 +01:00
|
|
|
int router_load_routers_from_string(const char *s, const char *eos,
|
2006-06-22 09:01:54 +02:00
|
|
|
saved_location_t saved_location,
|
2007-06-10 09:34:21 +02:00
|
|
|
smartlist_t *requested_fingerprints,
|
2007-09-21 08:14:36 +02:00
|
|
|
int descriptor_digests,
|
2007-09-27 22:46:30 +02:00
|
|
|
const char *prepend_annotations);
|
2007-05-22 04:20:52 +02:00
|
|
|
void router_load_extrainfo_from_string(const char *s, const char *eos,
|
2007-05-18 23:19:19 +02:00
|
|
|
saved_location_t saved_location,
|
2007-10-11 18:06:47 +02:00
|
|
|
smartlist_t *requested_fingerprints,
|
2007-09-21 08:14:36 +02:00
|
|
|
int descriptor_digests);
|
2007-10-11 18:06:47 +02:00
|
|
|
void routerlist_retry_directory_downloads(time_t now);
|
2005-01-12 05:58:23 +01:00
|
|
|
int router_exit_policy_all_routers_reject(uint32_t addr, uint16_t port,
|
|
|
|
int need_uptime);
|
2004-05-12 21:49:48 +02:00
|
|
|
int router_exit_policy_rejects_all(routerinfo_t *router);
|
2008-02-04 17:58:50 +01:00
|
|
|
trusted_dir_server_t *add_trusted_dir_server(const char *nickname,
|
|
|
|
const char *address,
|
|
|
|
uint16_t dir_port, uint16_t or_port,
|
|
|
|
const char *digest, const char *v3_auth_digest,
|
|
|
|
authority_type_t type);
|
2007-10-22 19:31:26 +02:00
|
|
|
void authority_cert_free(authority_cert_t *cert);
|
2004-10-13 21:56:42 +02:00
|
|
|
void clear_trusted_dir_servers(void);
|
2006-04-10 23:29:29 +02:00
|
|
|
int any_trusted_dir_is_v1_authority(void);
|
2005-09-15 07:19:38 +02:00
|
|
|
void update_router_descriptor_downloads(time_t now);
|
2007-05-18 23:19:19 +02:00
|
|
|
void update_extrainfo_downloads(time_t now);
|
2005-09-15 07:19:38 +02:00
|
|
|
int router_have_minimum_dir_info(void);
|
2007-10-08 23:21:50 +02:00
|
|
|
void router_dir_info_changed(void);
|
2007-11-02 05:18:28 +01:00
|
|
|
const char *get_dir_info_status_string(void);
|
2008-06-09 08:33:29 +02:00
|
|
|
int count_loading_descriptors_progress(void);
|
2005-09-22 08:34:29 +02:00
|
|
|
void router_reset_descriptor_download_failures(void);
|
2005-10-12 15:49:13 +02:00
|
|
|
int router_differences_are_cosmetic(routerinfo_t *r1, routerinfo_t *r2);
|
2007-05-20 20:03:26 +02:00
|
|
|
int routerinfo_incompatible_with_extrainfo(routerinfo_t *ri, extrainfo_t *ei,
|
2007-10-21 02:08:35 +02:00
|
|
|
signed_descriptor_t *sd,
|
2007-05-20 20:03:26 +02:00
|
|
|
const char **msg);
|
2007-04-30 07:36:41 +02:00
|
|
|
void routerlist_assert_ok(routerlist_t *rl);
|
2007-10-11 18:06:47 +02:00
|
|
|
const char *esc_router_info(routerinfo_t *router);
|
2007-10-12 23:33:39 +02:00
|
|
|
void routers_sort_by_identity(smartlist_t *routers);
|
2007-05-22 19:58:25 +02:00
|
|
|
|
2008-07-18 20:36:32 +02:00
|
|
|
routerset_t *routerset_new(void);
|
|
|
|
int routerset_parse(routerset_t *target, const char *s,
|
|
|
|
const char *description);
|
|
|
|
void routerset_union(routerset_t *target, const routerset_t *source);
|
2008-09-25 22:21:35 +02:00
|
|
|
int routerset_is_list(const routerset_t *set);
|
2008-09-25 23:06:32 +02:00
|
|
|
int routerset_needs_geoip(const routerset_t *set);
|
2008-07-18 20:36:32 +02:00
|
|
|
int routerset_contains_router(const routerset_t *set, routerinfo_t *ri);
|
|
|
|
int routerset_contains_routerstatus(const routerset_t *set,
|
|
|
|
routerstatus_t *rs);
|
2009-05-27 20:45:44 +02:00
|
|
|
int routerset_contains_extendinfo(const routerset_t *set,
|
|
|
|
const extend_info_t *ei);
|
2008-07-18 20:36:32 +02:00
|
|
|
void routerset_get_all_routers(smartlist_t *out, const routerset_t *routerset,
|
|
|
|
int running_only);
|
2008-09-25 22:21:35 +02:00
|
|
|
void routersets_get_disjunction(smartlist_t *target, const smartlist_t *source,
|
|
|
|
const routerset_t *include,
|
|
|
|
const routerset_t *exclude, int running_only);
|
2008-07-18 20:36:32 +02:00
|
|
|
void routerset_subtract_routers(smartlist_t *out,
|
|
|
|
const routerset_t *routerset);
|
|
|
|
char *routerset_to_string(const routerset_t *routerset);
|
2008-09-25 22:21:35 +02:00
|
|
|
void routerset_refresh_countries(routerset_t *target);
|
|
|
|
int routerset_equal(const routerset_t *old, const routerset_t *new);
|
2008-07-18 20:36:32 +02:00
|
|
|
void routerset_free(routerset_t *routerset);
|
2008-09-25 22:21:35 +02:00
|
|
|
void routerinfo_set_country(routerinfo_t *ri);
|
|
|
|
void routerlist_refresh_countries(void);
|
2009-02-16 16:15:06 +01:00
|
|
|
void refresh_all_country_info(void);
|
2008-07-18 20:36:32 +02:00
|
|
|
|
2007-10-29 20:10:42 +01:00
|
|
|
int hid_serv_get_responsible_directories(smartlist_t *responsible_dirs,
|
2007-11-03 21:12:41 +01:00
|
|
|
const char *id);
|
|
|
|
int hid_serv_acting_as_directory(void);
|
|
|
|
int hid_serv_responsible_for_desc_id(const char *id);
|
2007-10-29 20:10:42 +01:00
|
|
|
|
2004-05-12 21:49:48 +02:00
|
|
|
/********************************* routerparse.c ************************/
|
|
|
|
|
2004-11-30 00:04:26 +01:00
|
|
|
#define MAX_STATUS_TAG_LEN 32
|
|
|
|
/** Structure to hold parsed Tor versions. This is a little messier
|
|
|
|
* than we would like it to be, because we changed version schemes with 0.1.0.
|
|
|
|
*
|
2005-03-19 06:07:19 +01:00
|
|
|
* See version-spec.txt for the whole business.
|
2004-11-30 00:04:26 +01:00
|
|
|
*/
|
2004-07-13 21:16:49 +02:00
|
|
|
typedef struct tor_version_t {
|
|
|
|
int major;
|
|
|
|
int minor;
|
|
|
|
int micro;
|
2004-11-30 00:04:26 +01:00
|
|
|
/** Release status. For version in the post-0.1 format, this is always
|
|
|
|
* VER_RELEASE. */
|
|
|
|
enum { VER_PRE=0, VER_RC=1, VER_RELEASE=2, } status;
|
2004-07-13 21:16:49 +02:00
|
|
|
int patchlevel;
|
2004-11-30 00:04:26 +01:00
|
|
|
char status_tag[MAX_STATUS_TAG_LEN];
|
2007-04-17 02:58:30 +02:00
|
|
|
int svn_revision;
|
2009-06-12 19:38:37 +02:00
|
|
|
|
|
|
|
int git_tag_len;
|
|
|
|
char git_tag[DIGEST_LEN];
|
2004-07-13 21:16:49 +02:00
|
|
|
} tor_version_t;
|
|
|
|
|
2004-05-12 21:49:48 +02:00
|
|
|
int router_get_router_hash(const char *s, char *digest);
|
|
|
|
int router_get_dir_hash(const char *s, char *digest);
|
2004-06-25 02:29:31 +02:00
|
|
|
int router_get_runningrouters_hash(const char *s, char *digest);
|
2005-08-25 22:33:17 +02:00
|
|
|
int router_get_networkstatus_v2_hash(const char *s, char *digest);
|
2007-05-22 20:52:32 +02:00
|
|
|
int router_get_networkstatus_v3_hash(const char *s, char *digest);
|
2007-04-16 06:17:58 +02:00
|
|
|
int router_get_extrainfo_hash(const char *s, char *digest);
|
2005-12-14 21:40:40 +01:00
|
|
|
int router_append_dirobj_signature(char *buf, size_t buf_len,
|
|
|
|
const char *digest,
|
2005-08-26 17:34:53 +02:00
|
|
|
crypto_pk_env_t *private_key);
|
2007-05-22 04:20:52 +02:00
|
|
|
int router_parse_list_from_string(const char **s, const char *eos,
|
2006-04-29 20:42:26 +02:00
|
|
|
smartlist_t *dest,
|
2007-04-30 21:48:39 +02:00
|
|
|
saved_location_t saved_location,
|
2007-09-26 18:19:44 +02:00
|
|
|
int is_extrainfo,
|
2007-09-27 18:08:10 +02:00
|
|
|
int allow_annotations,
|
|
|
|
const char *prepend_annotations);
|
2004-05-12 21:49:48 +02:00
|
|
|
int router_parse_routerlist_from_directory(const char *s,
|
|
|
|
routerlist_t **dest,
|
2004-10-03 04:37:52 +02:00
|
|
|
crypto_pk_env_t *pkey,
|
2005-01-06 21:11:52 +01:00
|
|
|
int check_version,
|
|
|
|
int write_to_cache);
|
2005-09-14 23:09:25 +02:00
|
|
|
int router_parse_runningrouters(const char *str);
|
2005-09-15 07:19:38 +02:00
|
|
|
int router_parse_directory(const char *str);
|
2006-06-22 09:01:54 +02:00
|
|
|
routerinfo_t *router_parse_entry_from_string(const char *s, const char *end,
|
2007-09-26 18:19:44 +02:00
|
|
|
int cache_copy,
|
2007-09-27 18:08:10 +02:00
|
|
|
int allow_annotations,
|
|
|
|
const char *prepend_annotations);
|
2007-04-16 06:17:58 +02:00
|
|
|
extrainfo_t *extrainfo_parse_entry_from_string(const char *s, const char *end,
|
2007-08-14 04:23:57 +02:00
|
|
|
int cache_copy, struct digest_ri_map_t *routermap);
|
2008-01-02 05:43:44 +01:00
|
|
|
addr_policy_t *router_parse_addr_policy_item_from_string(const char *s,
|
|
|
|
int assume_action);
|
2005-09-21 02:41:06 +02:00
|
|
|
version_status_t tor_version_is_obsolete(const char *myversion,
|
|
|
|
const char *versionlist);
|
2004-07-13 21:16:49 +02:00
|
|
|
int tor_version_parse(const char *s, tor_version_t *out);
|
2004-09-27 08:00:43 +02:00
|
|
|
int tor_version_as_new_as(const char *platform, const char *cutoff);
|
2004-07-13 21:16:49 +02:00
|
|
|
int tor_version_compare(tor_version_t *a, tor_version_t *b);
|
2006-04-03 08:23:24 +02:00
|
|
|
void sort_version_list(smartlist_t *lst, int remove_duplicates);
|
2008-01-02 05:43:44 +01:00
|
|
|
void assert_addr_policy_ok(smartlist_t *t);
|
2006-11-30 23:23:01 +01:00
|
|
|
void dump_distinct_digest_count(int severity);
|
2004-05-12 21:49:48 +02:00
|
|
|
|
2009-07-31 06:33:53 +02:00
|
|
|
int compare_routerstatus_entries(const void **_a, const void **_b);
|
2007-10-16 01:15:24 +02:00
|
|
|
networkstatus_v2_t *networkstatus_v2_parse_from_string(const char *s);
|
2008-02-05 22:39:29 +01:00
|
|
|
networkstatus_t *networkstatus_parse_vote_from_string(const char *s,
|
2008-07-24 11:22:27 +02:00
|
|
|
const char **eos_out,
|
|
|
|
networkstatus_type_t ns_type);
|
2007-07-27 20:33:28 +02:00
|
|
|
ns_detached_signatures_t *networkstatus_parse_detached_signatures(
|
|
|
|
const char *s, const char *eos);
|
2005-09-02 22:37:31 +02:00
|
|
|
|
2007-05-02 23:37:55 +02:00
|
|
|
authority_cert_t *authority_cert_parse_from_string(const char *s,
|
2007-05-22 19:58:25 +02:00
|
|
|
const char **end_of_string);
|
2007-10-28 20:48:14 +01:00
|
|
|
int rend_parse_v2_service_descriptor(rend_service_descriptor_t **parsed_out,
|
|
|
|
char *desc_id_out,
|
|
|
|
char **intro_points_encrypted_out,
|
|
|
|
size_t *intro_points_encrypted_size_out,
|
|
|
|
size_t *encoded_size_out,
|
|
|
|
const char **next_out, const char *desc);
|
2008-08-19 17:41:28 +02:00
|
|
|
int rend_decrypt_introduction_points(char **ipos_decrypted,
|
|
|
|
size_t *ipos_decrypted_size,
|
2007-10-28 20:48:14 +01:00
|
|
|
const char *descriptor_cookie,
|
2008-08-19 17:41:28 +02:00
|
|
|
const char *ipos_encrypted,
|
|
|
|
size_t ipos_encrypted_size);
|
|
|
|
int rend_parse_introduction_points(rend_service_descriptor_t *parsed,
|
|
|
|
const char *intro_points_encoded,
|
|
|
|
size_t intro_points_encoded_size);
|
2008-08-08 16:36:11 +02:00
|
|
|
int rend_parse_client_keys(strmap_t *parsed_clients, const char *str);
|
2007-05-02 23:37:55 +02:00
|
|
|
|
2002-06-27 00:45:49 +02:00
|
|
|
#endif
|
2005-06-09 21:03:31 +02:00
|
|
|
|