Tor 0.4.9.0-alpha-dev
|
Code to interpret the user's configuration of Tor's directory authority module. More...
#include "orconfig.h"
#include "feature/dirauth/dirauth_config.h"
#include "lib/encoding/confline.h"
#include "lib/confmgt/confmgt.h"
#include "lib/conf/confdecl.h"
#include "lib/version/torversion.h"
#include "core/or/or.h"
#include "core/or/tor_version_st.h"
#include "core/or/versions.h"
#include "app/config/config.h"
#include "app/config/resolve_addr.h"
#include "feature/dirauth/voting_schedule.h"
#include "feature/stats/rephist.h"
#include "feature/dirauth/authmode.h"
#include "feature/dirauth/bwauth.h"
#include "feature/dirauth/dirauth_periodic.h"
#include "feature/dirauth/dirauth_sys.h"
#include "feature/dirauth/dirvote.h"
#include "feature/dirauth/guardfraction.h"
#include "feature/dirauth/dirauth_options_st.h"
#include "feature/dirauth/dirauth_options.inc"
Go to the source code of this file.
Macros | |
#define | REJECT(arg) STMT_BEGIN *msg = tor_strdup(arg); return -1; STMT_END |
#define | COMPLAIN(args, ...) STMT_BEGIN log_warn(LD_CONFIG, args, ##__VA_ARGS__); STMT_END |
#define | YES_IF_CHANGED_INT(opt) if (!CFG_EQ_INT(old_options, new_options, opt)) return 1; |
#define | CONF_CONTEXT TABLE |
#define | DIRAUTH_OPTIONS_MAGIC 0x41757448 |
Functions | |
bool | dirauth_should_reject_requests_under_load (void) |
int | options_validate_dirauth_mode (const or_options_t *old_options, or_options_t *options, char **msg) |
int | options_validate_dirauth_schedule (const or_options_t *old_options, or_options_t *options, char **msg) |
int | options_validate_dirauth_testing (const or_options_t *old_options, or_options_t *options, char **msg) |
static int | options_transition_affects_dirauth_timing (const or_options_t *old_options, const or_options_t *new_options) |
int | options_act_dirauth (const or_options_t *old_options) |
int | options_act_dirauth_mtbf (const or_options_t *old_options) |
int | options_act_dirauth_stats (const or_options_t *old_options, bool *print_notice_out) |
static int | dirauth_options_pre_normalize (void *arg, char **msg_out) |
static int | dirauth_options_validate (const void *arg, char **msg) |
Variables | |
const config_format_t | dirauth_options_fmt |
Code to interpret the user's configuration of Tor's directory authority module.
Definition in file dirauth_config.c.
#define COMPLAIN | ( | args, | |
... | |||
) | STMT_BEGIN log_warn(LD_CONFIG, args, ##__VA_ARGS__); STMT_END |
Definition at line 46 of file dirauth_config.c.
#define CONF_CONTEXT TABLE |
Definition at line 502 of file dirauth_config.c.
#define DIRAUTH_OPTIONS_MAGIC 0x41757448 |
Magic number for dirauth_options_t.
Definition at line 507 of file dirauth_config.c.
#define REJECT | ( | arg | ) | STMT_BEGIN *msg = tor_strdup(arg); return -1; STMT_END |
Definition at line 40 of file dirauth_config.c.
#define YES_IF_CHANGED_INT | ( | opt | ) | if (!CFG_EQ_INT(old_options, new_options, opt)) return 1; |
Definition at line 50 of file dirauth_config.c.
|
static |
Make any necessary modifications to a dirauth_options_t that occur before validation. On success return 0; on failure return -1 and set *msg_out to a newly allocated error string.
Definition at line 400 of file dirauth_config.c.
|
static |
Check whether a dirauth_options_t is correct.
On success return 0; on failure return -1 and set *msg_out to a newly allocated error string.
Definition at line 429 of file dirauth_config.c.
bool dirauth_should_reject_requests_under_load | ( | void | ) |
Return true iff we are configured to reject request under load for non relay connections.
Definition at line 56 of file dirauth_config.c.
int options_act_dirauth | ( | const or_options_t * | old_options | ) |
Fetch the active option list, and take dirauth actions based on it. All of the things we do should survive being done repeatedly. If present, old_options contains the previous value of the options.
Return 0 if all goes well, return -1 if it's time to die.
Note: We haven't moved all the "act on new configuration" logic into the options_act* functions yet. Some is still in do_hup() and other places.
Definition at line 305 of file dirauth_config.c.
int options_act_dirauth_mtbf | ( | const or_options_t * | old_options | ) |
Fetch the active option list, and take dirauth mtbf actions based on it. All of the things we do should survive being done repeatedly. If present, old_options contains the previous value of the options.
Must be called immediately after a successful or_state_load().
Return 0 if all goes well, return -1 if it's time to die.
Note: We haven't moved all the "act on new configuration" logic into the options_act* functions yet. Some is still in do_hup() and other places.
Definition at line 333 of file dirauth_config.c.
int options_act_dirauth_stats | ( | const or_options_t * | old_options, |
bool * | print_notice_out | ||
) |
Fetch the active option list, and take dirauth statistics actions based on it. All of the things we do should survive being done repeatedly. If present, old_options contains the previous value of the options.
Sets *print_notice_out if we enabled stats, and need to print a stats log using options_act_relay_stats_msg().
Return 0 if all goes well, return -1 if it's time to die.
Note: We haven't moved all the "act on new configuration" logic into the options_act* functions yet. Some is still in do_hup() and other places.
Definition at line 365 of file dirauth_config.c.
|
static |
Return true if changing the configuration from old to new affects the timing of the voting subsystem
Definition at line 272 of file dirauth_config.c.
Referenced by options_act_dirauth().
int options_validate_dirauth_mode | ( | const or_options_t * | old_options, |
or_options_t * | options, | ||
char ** | msg | ||
) |
Legacy validation/normalization function for the dirauth mode options in options. Uses old_options as the previous options.
Returns 0 on success, returns -1 and sets *msg to a newly allocated string on error.
Definition at line 69 of file dirauth_config.c.
int options_validate_dirauth_schedule | ( | const or_options_t * | old_options, |
or_options_t * | options, | ||
char ** | msg | ||
) |
Legacy validation/normalization function for the dirauth schedule options in options. Uses old_options as the previous options.
Returns 0 on success, returns -1 and sets *msg to a newly allocated string on error.
Definition at line 135 of file dirauth_config.c.
int options_validate_dirauth_testing | ( | const or_options_t * | old_options, |
or_options_t * | options, | ||
char ** | msg | ||
) |
Legacy validation/normalization function for the dirauth testing options in options. Uses old_options as the previous options.
Returns 0 on success, returns -1 and sets *msg to a newly allocated string on error.
Definition at line 214 of file dirauth_config.c.
const config_format_t dirauth_options_fmt |
Declare the configuration options for the dirauth module.
Definition at line 512 of file dirauth_config.c.