diff options
author | Roger Dingledine <arma@torproject.org> | 2005-05-20 08:51:45 +0000 |
---|---|---|
committer | Roger Dingledine <arma@torproject.org> | 2005-05-20 08:51:45 +0000 |
commit | f0e309e5bdb9227ed73a59e983da83771c062941 (patch) | |
tree | 8b34cccb7501e269d254901af3f8c30cc891c018 /src/or/connection.c | |
parent | 918c5a9115c1e39e8ef28e6241cfcd7bdaf5374b (diff) | |
download | tor-f0e309e5bdb9227ed73a59e983da83771c062941.tar.gz tor-f0e309e5bdb9227ed73a59e983da83771c062941.zip |
add HttpProxyAuthenticator config option too
svn:r4272
Diffstat (limited to 'src/or/connection.c')
-rw-r--r-- | src/or/connection.c | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/src/or/connection.c b/src/or/connection.c index 1b14670a02..7ecff7ba15 100644 --- a/src/or/connection.c +++ b/src/or/connection.c @@ -1559,6 +1559,28 @@ int connection_send_destroy(uint16_t circ_id, connection_t *conn) { return 0; } +/** Alloocates a base64'ed authenticator for use in http or https + * auth, based on the input string <b>authenticator</b>. Returns it + * if success, else returns NULL. */ +char * +alloc_http_authenticator(const char *authenticator) { + /* an authenticator in Basic authentication + * is just the string "username:password" */ + const int authenticator_length = strlen(authenticator); + /* The base64_encode function needs a minimum buffer length + * of 66 bytes. */ + const int base64_authenticator_length = (authenticator_length/48+1)*66; + char *base64_authenticator = tor_malloc(base64_authenticator_length); + if (base64_encode(base64_authenticator, base64_authenticator_length, + authenticator, authenticator_length) < 0) { + tor_free(base64_authenticator); /* free and set to null */ + } else { + /* remove extra \n at end of encoding */ + base64_authenticator[strlen(base64_authenticator) - 1] = 0; + } + return base64_authenticator; +} + /** Process new bytes that have arrived on conn-\>inbuf. * * This function just passes conn to the connection-specific |