mirror of
https://gitlab.torproject.org/tpo/core/tor.git
synced 2024-11-14 15:23:27 +01:00
r15142@catbus: nickm | 2007-09-18 11:43:32 -0400
Split "Have all the authorities accepted our server descriptor?" into its own function. Patch from Robert Hogan. svn:r11482
This commit is contained in:
parent
eee8d750b6
commit
a2b76befff
@ -183,6 +183,21 @@ router_supports_extrainfo(const char *identity_digest, int is_authority)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Return true iff all trusted directory servers have accepted our
|
||||||
|
* server descriptor. */
|
||||||
|
int
|
||||||
|
directories_have_accepted_server_descriptor(void)
|
||||||
|
{
|
||||||
|
smartlist_t *servers = router_get_trusted_dir_servers();
|
||||||
|
SMARTLIST_FOREACH(servers, trusted_dir_server_t *, d, {
|
||||||
|
if ((d->type & (V1_AUTHORITY|V2_AUTHORITY)) &&
|
||||||
|
!d->has_accepted_serverdesc) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
/** Start a connection to every suitable directory authority, using
|
/** Start a connection to every suitable directory authority, using
|
||||||
* connection purpose 'purpose' and uploading the payload 'payload'
|
* connection purpose 'purpose' and uploading the payload 'payload'
|
||||||
* (length 'payload_len'). The purpose should be one of
|
* (length 'payload_len'). The purpose should be one of
|
||||||
@ -1400,10 +1415,8 @@ connection_dir_client_reached_eof(dir_connection_t *conn)
|
|||||||
if (conn->_base.purpose == DIR_PURPOSE_UPLOAD_DIR) {
|
if (conn->_base.purpose == DIR_PURPOSE_UPLOAD_DIR) {
|
||||||
switch (status_code) {
|
switch (status_code) {
|
||||||
case 200: {
|
case 200: {
|
||||||
int all_done = 1;
|
|
||||||
trusted_dir_server_t *ds =
|
trusted_dir_server_t *ds =
|
||||||
router_get_trusteddirserver_by_digest(conn->identity_digest);
|
router_get_trusteddirserver_by_digest(conn->identity_digest);
|
||||||
smartlist_t *servers;
|
|
||||||
log_info(LD_GENERAL,"eof (status 200) after uploading server "
|
log_info(LD_GENERAL,"eof (status 200) after uploading server "
|
||||||
"descriptor: finished.");
|
"descriptor: finished.");
|
||||||
control_event_server_status(
|
control_event_server_status(
|
||||||
@ -1411,15 +1424,7 @@ connection_dir_client_reached_eof(dir_connection_t *conn)
|
|||||||
conn->_base.address, conn->_base.port);
|
conn->_base.address, conn->_base.port);
|
||||||
|
|
||||||
ds->has_accepted_serverdesc = 1;
|
ds->has_accepted_serverdesc = 1;
|
||||||
servers = router_get_trusted_dir_servers();
|
if (directories_have_accepted_server_descriptor())
|
||||||
SMARTLIST_FOREACH(servers, trusted_dir_server_t *, d, {
|
|
||||||
if ((d->type & (V1_AUTHORITY|V2_AUTHORITY)) &&
|
|
||||||
!d->has_accepted_serverdesc) {
|
|
||||||
all_done = 0;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
if (all_done)
|
|
||||||
control_event_server_status(LOG_NOTICE, "GOOD_SERVER_DESCRIPTOR");
|
control_event_server_status(LOG_NOTICE, "GOOD_SERVER_DESCRIPTOR");
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -2761,6 +2761,7 @@ int assign_to_cpuworker(connection_t *cpuworker, uint8_t question_type,
|
|||||||
|
|
||||||
/********************************* directory.c ***************************/
|
/********************************* directory.c ***************************/
|
||||||
|
|
||||||
|
int directories_have_accepted_server_descriptor(void);
|
||||||
char *authority_type_to_string(authority_type_t auth);
|
char *authority_type_to_string(authority_type_t auth);
|
||||||
void directory_post_to_dirservers(uint8_t dir_purpose, uint8_t router_purpose,
|
void directory_post_to_dirservers(uint8_t dir_purpose, uint8_t router_purpose,
|
||||||
authority_type_t type, const char *payload,
|
authority_type_t type, const char *payload,
|
||||||
|
Loading…
Reference in New Issue
Block a user