From: Nick Mathewson Date: Fri, 6 Aug 2004 19:54:20 +0000 (+0000) Subject: There is no space after network-status; make router_get_hash_impl more bulletproof. X-Git-Tag: tor-0.0.8pre3~53 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=2ff6d6d8b94140a20a8ef6c8a1f7155ef85d275b;p=thirdparty%2Ftor.git There is no space after network-status; make router_get_hash_impl more bulletproof. svn:r2162 --- diff --git a/src/or/routerparse.c b/src/or/routerparse.c index e4db112150..bf94e84e79 100644 --- a/src/or/routerparse.c +++ b/src/or/routerparse.c @@ -143,7 +143,7 @@ static int check_directory_signature(const char *digest, int router_get_dir_hash(const char *s, char *digest) { return router_get_hash_impl(s,digest, - "signed-directory","directory-signature"); + "signed-directory","\ndirectory-signature"); } /** Set digest to the SHA-1 digest of the hash of the first router in @@ -152,7 +152,7 @@ int router_get_dir_hash(const char *s, char *digest) int router_get_router_hash(const char *s, char *digest) { return router_get_hash_impl(s,digest, - "router ","router-signature"); + "router ","\nrouter-signature"); } /** Set digest to the SHA-1 digest of the hash of the running-routers @@ -161,7 +161,7 @@ int router_get_router_hash(const char *s, char *digest) int router_get_runningrouters_hash(const char *s, char *digest) { return router_get_hash_impl(s,digest, - "network-status ","directory-signature"); + "network-status","\ndirectory-signature"); } /** Parse a date of the format "YYYY-MM-DD hh:mm:ss" and store the result into @@ -1341,6 +1341,11 @@ static int router_get_hash_impl(const char *s, char *digest, log_fn(LOG_WARN,"couldn't find \"%s\"",start_str); return -1; } + if (start != s && *(start-1) != '\n') { + log_fn(LOG_WARN, "first occurance of \"%s\" is not at the start of a line", + start_str); + return -1; + } end = strstr(start+strlen(start_str), end_str); if (!end) { log_fn(LOG_WARN,"couldn't find \"%s\"",end_str);