[tor-commits] [tor/master] Make rend_authorized_client_free public

nickm at torproject.org nickm at torproject.org
Mon May 9 18:41:48 UTC 2016


commit e7ff23beea6f415f661821bdefda8b1df3deb7a6
Author: John Brooks <john.brooks at dereferenced.net>
Date:   Mon Apr 13 21:35:40 2015 -0600

    Make rend_authorized_client_free public
    
    This is needed by control.c.
    
    Also, check whether client_name is set before doing memwipe.
---
 src/or/rendservice.c | 5 +++--
 src/or/rendservice.h | 2 ++
 2 files changed, 5 insertions(+), 2 deletions(-)

diff --git a/src/or/rendservice.c b/src/or/rendservice.c
index 22a01c9..fbc228a 100644
--- a/src/or/rendservice.c
+++ b/src/or/rendservice.c
@@ -183,14 +183,15 @@ num_rend_services(void)
 }
 
 /** Helper: free storage held by a single service authorized client entry. */
-static void
+void
 rend_authorized_client_free(rend_authorized_client_t *client)
 {
   if (!client)
     return;
   if (client->client_key)
     crypto_pk_free(client->client_key);
-  memwipe(client->client_name, 0, strlen(client->client_name));
+  if (client->client_name)
+    memwipe(client->client_name, 0, strlen(client->client_name));
   tor_free(client->client_name);
   memwipe(client->descriptor_cookie, 0, sizeof(client->descriptor_cookie));
   tor_free(client);
diff --git a/src/or/rendservice.h b/src/or/rendservice.h
index a16a99c..2bb0c6a 100644
--- a/src/or/rendservice.h
+++ b/src/or/rendservice.h
@@ -106,6 +106,8 @@ rend_service_port_config_t *rend_service_parse_port_config(const char *string,
                                                            char **err_msg_out);
 void rend_service_port_config_free(rend_service_port_config_t *p);
 
+void rend_authorized_client_free(rend_authorized_client_t *client);
+
 /** Return value from rend_service_add_ephemeral. */
 typedef enum {
   RSAE_BADVIRTPORT = -4, /**< Invalid VIRTPORT/TARGET(s) */





More information about the tor-commits mailing list