[tor-commits] [obfsproxy/master] Don't pass the protocol name as part of the option list provided to the protocol-specific params initialization method. Improve diagnostics in obfs2.c.
nickm at torproject.org
nickm at torproject.org
Fri Sep 9 17:08:55 UTC 2011
commit 798a292f4a4b3fd38c6ac9d3d6b238e75f35eee8
Author: Zack Weinberg <zackw at panix.com>
Date: Thu Jul 14 12:53:00 2011 -0700
Don't pass the protocol name as part of the option list provided to the protocol-specific params initialization method. Improve diagnostics in obfs2.c.
---
src/protocol.c | 4 +++-
src/protocols/dummy.c | 12 +++++-------
src/protocols/obfs2.c | 28 +++++++++++++---------------
3 files changed, 21 insertions(+), 23 deletions(-)
diff --git a/src/protocol.c b/src/protocol.c
index 85b975f..9aa1f8b 100644
--- a/src/protocol.c
+++ b/src/protocol.c
@@ -36,7 +36,9 @@ proto_params_init(int n_options, const char *const *options)
size_t i;
for (i = 0; i < n_supported_protocols; i++)
if (!strcmp(*options, supported_protocols[i]->name))
- return supported_protocols[i]->init(n_options, options);
+ /* Remove the first element of 'options' (which is always the
+ protocol name) from the list passed to the init method. */
+ return supported_protocols[i]->init(n_options - 1, options + 1);
return NULL;
}
diff --git a/src/protocols/dummy.c b/src/protocols/dummy.c
index 7db48d7..f121725 100644
--- a/src/protocols/dummy.c
+++ b/src/protocols/dummy.c
@@ -50,24 +50,22 @@ parse_and_set_options(int n_options, const char *const *options,
{
const char* defport;
- if (n_options != 3)
+ if (n_options != 2)
return -1;
- assert(!strcmp(options[0],"dummy"));
-
- if (!strcmp(options[1], "client")) {
+ if (!strcmp(options[0], "client")) {
defport = "48988"; /* bf5c */
params->mode = LSN_SIMPLE_CLIENT;
- } else if (!strcmp(options[1], "socks")) {
+ } else if (!strcmp(options[0], "socks")) {
defport = "23548"; /* 5bf5 */
params->mode = LSN_SOCKS_CLIENT;
- } else if (!strcmp(options[1], "server")) {
+ } else if (!strcmp(options[0], "server")) {
defport = "11253"; /* 2bf5 */
params->mode = LSN_SIMPLE_SERVER;
} else
return -1;
- if (resolve_address_port(options[2], 1, 1,
+ if (resolve_address_port(options[1], 1, 1,
¶ms->listen_address,
¶ms->listen_address_len, defport) < 0) {
log_warn("addr");
diff --git a/src/protocols/obfs2.c b/src/protocols/obfs2.c
index cc208ed..41a2614 100644
--- a/src/protocols/obfs2.c
+++ b/src/protocols/obfs2.c
@@ -66,14 +66,11 @@ parse_and_set_options(int n_options, const char *const *options,
int got_ss=0;
const char* defport;
- if ((n_options < 3) || (n_options > 5)) {
- log_warn("%s(): wrong options number: %d", __func__, n_options);
+ if ((n_options < 2) || (n_options > 4)) {
+ log_warn("obfs2: wrong number of options: %d", n_options);
return -1;
}
- assert(!strcmp(*options,"obfs2"));
- options++;
-
/* Now parse the optional arguments */
while (!strncmp(*options,"--",2)) {
if (!strncmp(*options,"--dest=",7)) {
@@ -92,7 +89,7 @@ parse_and_set_options(int n_options, const char *const *options,
params->shared_secret_len = strlen(*options+16);
got_ss=1;
} else {
- log_warn("%s(): Unknown argument.", __func__);
+ log_warn("obfs2: Unknown argument.");
return -1;
}
options++;
@@ -108,7 +105,7 @@ parse_and_set_options(int n_options, const char *const *options,
defport = "11253"; /* 2bf5 */
params->mode = LSN_SIMPLE_SERVER;
} else {
- log_warn("%s(): only client/socks/server modes supported.", __func__);
+ log_warn("obfs2: only client/socks/server modes supported.");
return -1;
}
options++;
@@ -122,16 +119,16 @@ parse_and_set_options(int n_options, const char *const *options,
/* Validate option selection. */
if (got_dest && (params->mode == LSN_SOCKS_CLIENT)) {
- log_warn("%s(): You can't be on socks mode and have --dest.", __func__);
+ log_warn("obfs2: You can't be on socks mode and have --dest.");
return -1;
}
if (!got_dest && (params->mode != LSN_SOCKS_CLIENT)) {
- log_warn("%s(): client/server mode needs --dest.", __func__);
+ log_warn("obfs2: client/server mode needs --dest.");
return -1;
}
- log_debug("%s(): Parsed obfs2 options nicely!", __func__);
+ log_debug("obfs2: Parsed options nicely!");
params->vtable = &obfs2_vtable;
return 0;
@@ -371,8 +368,8 @@ obfs2_handshake(struct protocol_t *s, struct evbuffer *buf)
and write those bytes onto 'dest'. Return 0 on success, -1 on failure.
*/
static int
-crypt_and_transmit(crypt_t *crypto,
- struct evbuffer *source, struct evbuffer *dest)
+obfs2_crypt_and_transmit(crypt_t *crypto,
+ struct evbuffer *source, struct evbuffer *dest)
{
uchar data[1024];
while (1) {
@@ -399,12 +396,13 @@ obfs2_send(struct protocol_t *s,
if (state->send_crypto) {
/* First of all, send any data that we've been waiting to send. */
if (state->pending_data_to_send) {
- crypt_and_transmit(state->send_crypto, state->pending_data_to_send, dest);
+ obfs2_crypt_and_transmit(state->send_crypto, state->pending_data_to_send,
+ dest);
evbuffer_free(state->pending_data_to_send);
state->pending_data_to_send = NULL;
}
/* Our crypto is set up; just relay the bytes */
- return crypt_and_transmit(state->send_crypto, source, dest);
+ return obfs2_crypt_and_transmit(state->send_crypto, source, dest);
} else {
/* Our crypto isn't set up yet, we'll have to queue the data */
if (evbuffer_get_length(source)) {
@@ -544,7 +542,7 @@ obfs2_recv(struct protocol_t *s, struct evbuffer *source,
log_debug("%s(): Processing %d bytes data onto destination buffer",
__func__, (int) evbuffer_get_length(source));
- crypt_and_transmit(state->recv_crypto, source, dest);
+ obfs2_crypt_and_transmit(state->recv_crypto, source, dest);
if (r != RECV_SEND_PENDING)
r = RECV_GOOD;
More information about the tor-commits
mailing list