aboutsummaryrefslogtreecommitdiff
path: root/src/ats/gnunet-service-ats.c
diff options
context:
space:
mode:
authorChristian Grothoff <christian@grothoff.org>2011-10-13 20:54:17 +0000
committerChristian Grothoff <christian@grothoff.org>2011-10-13 20:54:17 +0000
commit42f0a310ce2d0c9c2cd4b62e8da617d8bc9b8290 (patch)
treece839c1c56d5a4b14b756ccbcf5654009460ed9b /src/ats/gnunet-service-ats.c
parent8a8968521fba2e248c37c7b817fa970c5c5097e2 (diff)
downloadgnunet-42f0a310ce2d0c9c2cd4b62e8da617d8bc9b8290.tar.gz
gnunet-42f0a310ce2d0c9c2cd4b62e8da617d8bc9b8290.zip
moving out addresses as well
Diffstat (limited to 'src/ats/gnunet-service-ats.c')
-rw-r--r--src/ats/gnunet-service-ats.c63
1 files changed, 3 insertions, 60 deletions
diff --git a/src/ats/gnunet-service-ats.c b/src/ats/gnunet-service-ats.c
index aca877d7b..dff19abea 100644
--- a/src/ats/gnunet-service-ats.c
+++ b/src/ats/gnunet-service-ats.c
@@ -28,29 +28,9 @@
28#include "gnunet_ats_service.h" 28#include "gnunet_ats_service.h"
29#include "gnunet-service-ats_performance.h" 29#include "gnunet-service-ats_performance.h"
30#include "gnunet-service-ats_scheduling.h" 30#include "gnunet-service-ats_scheduling.h"
31// #include "gnunet-service-ats_performance.h" 31#include "gnunet-service-ats_addresses.h"
32#include "ats.h" 32#include "ats.h"
33 33
34struct ATS_Address
35{
36 struct GNUNET_PeerIdentity peer;
37
38 size_t addr_len;
39
40 uint32_t session_id;
41
42 uint32_t ats_count;
43
44 void * addr;
45
46 char * plugin;
47
48 struct GNUNET_TRANSPORT_ATS_Information * ats;
49};
50
51static struct GNUNET_CONTAINER_MultiHashMap * addresses;
52
53
54 34
55static void 35static void
56handle_ats_start (void *cls, struct GNUNET_SERVER_Client *client, 36handle_ats_start (void *cls, struct GNUNET_SERVER_Client *client,
@@ -80,42 +60,6 @@ handle_ats_start (void *cls, struct GNUNET_SERVER_Client *client,
80} 60}
81 61
82 62
83struct CompareAddressContext
84{
85 struct ATS_Address * search;
86 struct ATS_Address * result;
87};
88
89int compare_address_it (void *cls,
90 const GNUNET_HashCode * key,
91 void *value)
92{
93 struct CompareAddressContext * cac = cls;
94 struct ATS_Address * aa = (struct ATS_Address *) value;
95 if (0 == strcmp(aa->plugin, cac->search->plugin))
96 {
97 if ((aa->addr_len == cac->search->addr_len) &&
98 (0 == memcmp (aa->addr, cac->search->addr, aa->addr_len)))
99 cac->result = aa;
100 return GNUNET_NO;
101 }
102 return GNUNET_YES;
103}
104
105
106static int
107free_address_it (void *cls,
108 const GNUNET_HashCode * key,
109 void *value)
110{
111 struct ATS_Address * aa = cls;
112 GNUNET_free (aa);
113 return GNUNET_OK;
114}
115
116
117
118
119 63
120/** 64/**
121 * Task run during shutdown. 65 * Task run during shutdown.
@@ -126,8 +70,7 @@ free_address_it (void *cls,
126static void 70static void
127cleanup_task (void *cls, const struct GNUNET_SCHEDULER_TaskContext *tc) 71cleanup_task (void *cls, const struct GNUNET_SCHEDULER_TaskContext *tc)
128{ 72{
129 GNUNET_CONTAINER_multihashmap_iterate (addresses, &free_address_it, NULL); 73 GAS_addresses_done ();
130 GNUNET_CONTAINER_multihashmap_destroy (addresses);
131} 74}
132 75
133 76
@@ -157,7 +100,7 @@ run (void *cls, struct GNUNET_SERVER_Handle *server,
157 GNUNET_MESSAGE_TYPE_ATS_PREFERENCE_CHANGE, 0}, 100 GNUNET_MESSAGE_TYPE_ATS_PREFERENCE_CHANGE, 0},
158 {NULL, NULL, 0, 0} 101 {NULL, NULL, 0, 0}
159 }; 102 };
160 addresses = GNUNET_CONTAINER_multihashmap_create(128); 103 GAS_addresses_init ();
161 GNUNET_SERVER_add_handlers (server, handlers); 104 GNUNET_SERVER_add_handlers (server, handlers);
162 GNUNET_SCHEDULER_add_delayed (GNUNET_TIME_UNIT_FOREVER_REL, &cleanup_task, 105 GNUNET_SCHEDULER_add_delayed (GNUNET_TIME_UNIT_FOREVER_REL, &cleanup_task,
163 NULL); 106 NULL);