pass identity to release_address(), allows providers to do a lookup by id
authorMartin Willi <martin@strongswan.org>
Fri, 5 Dec 2008 09:40:50 +0000 (09:40 -0000)
committerMartin Willi <martin@strongswan.org>
Fri, 5 Dec 2008 09:40:50 +0000 (09:40 -0000)
src/charon/config/attributes/attribute_manager.c
src/charon/config/attributes/attribute_manager.h
src/charon/config/attributes/attribute_provider.h
src/charon/plugins/sql/sql_attribute.c
src/charon/plugins/stroke/stroke_attribute.c
src/charon/plugins/unit_tester/tests/test_pool.c
src/charon/sa/ike_sa.c

index f162b4e..b919c42 100644 (file)
@@ -74,7 +74,7 @@ static host_t* acquire_address(private_attribute_manager_t *this,
  * Implementation of attribute_manager_t.release_address.
  */
 static void release_address(private_attribute_manager_t *this,
-                                                       char *pool, host_t *address)
+                                                       char *pool, host_t *address, identification_t *id)
 {
        enumerator_t *enumerator;
        attribute_provider_t *current;
@@ -83,7 +83,7 @@ static void release_address(private_attribute_manager_t *this,
        enumerator = this->providers->create_enumerator(this->providers);
        while (enumerator->enumerate(enumerator, &current))
        {
-               if (current->release_address(current, pool, address))
+               if (current->release_address(current, pool, address, id))
                {
                        break;
                }
@@ -132,7 +132,7 @@ attribute_manager_t *attribute_manager_create()
        private_attribute_manager_t *this = malloc_thing(private_attribute_manager_t);
        
        this->public.acquire_address = (host_t*(*)(attribute_manager_t*, char*, identification_t*,auth_info_t*,host_t*))acquire_address;
-       this->public.release_address = (void(*)(attribute_manager_t*, char *, host_t*))release_address;
+       this->public.release_address = (void(*)(attribute_manager_t*, char *, host_t*, identification_t*))release_address;
        this->public.add_provider = (void(*)(attribute_manager_t*, attribute_provider_t *provider))add_provider;
        this->public.remove_provider = (void(*)(attribute_manager_t*, attribute_provider_t *provider))remove_provider;
        this->public.destroy = (void(*)(attribute_manager_t*))destroy;
index 540e054..d2b69e0 100644 (file)
@@ -50,9 +50,10 @@ struct attribute_manager_t {
         *
         * @param pool                  pool name from which the address was acquired
         * @param address               address to release
+        * @param id                    peer identity to get address for
         */
        void (*release_address)(attribute_manager_t *this,
-                                                       char *pool, host_t *address);
+                                                       char *pool, host_t *address, identification_t *id);
        
        /**
         * Register an attribute provider to the manager.
index 1712bd1..9810c03 100644 (file)
@@ -51,10 +51,11 @@ struct attribute_provider_t {
         *
         * @param pool                  name of the pool this address was acquired from
         * @param address               address to release
+        * @param id                    peer ID
         * @return                              TRUE if the address has been released by the provider
         */
        bool (*release_address)(attribute_provider_t *this,
-                                                       char *pool, host_t *address);
+                                                       char *pool, host_t *address, identification_t *id);
 };
 
 #endif /* ATTRIBUTE_PROVIDER_H_ @}*/
index 486a432..cd6f7c0 100644 (file)
@@ -210,7 +210,7 @@ static host_t* acquire_address(private_sql_attribute_t *this,
  * Implementation of attribute_provider_t.release_address
  */
 static bool release_address(private_sql_attribute_t *this,
-                                                       char *name, host_t *address)
+                                                       char *name, host_t *address, identification_t *id)
 {
        enumerator_t *enumerator;
        bool found = FALSE;
@@ -264,7 +264,7 @@ sql_attribute_t *sql_attribute_create(database_t *db)
        time_t now = time(NULL);
        
        this->public.provider.acquire_address = (host_t*(*)(attribute_provider_t *this, char*, identification_t *,auth_info_t *, host_t *))acquire_address;
-       this->public.provider.release_address = (bool(*)(attribute_provider_t *this, char*,host_t *))release_address;
+       this->public.provider.release_address = (bool(*)(attribute_provider_t *this, char*,host_t *, identification_t*))release_address;
        this->public.destroy = (void(*)(sql_attribute_t*))destroy;
        
        this->db = db;
index 71b56bc..0312182 100644 (file)
@@ -203,7 +203,7 @@ static host_t* acquire_address(private_stroke_attribute_t *this,
  * Implementation of attribute_provider_t.release_address
  */
 static bool release_address(private_stroke_attribute_t *this,
-                                                       char *name, host_t *address)
+                                                       char *name, host_t *address, identification_t *id)
 {
        pool_t *pool;
        bool found = FALSE;
@@ -327,7 +327,7 @@ stroke_attribute_t *stroke_attribute_create()
        private_stroke_attribute_t *this = malloc_thing(private_stroke_attribute_t);
        
        this->public.provider.acquire_address = (host_t*(*)(attribute_provider_t *this, char*, identification_t *,auth_info_t *, host_t *))acquire_address;
-       this->public.provider.release_address = (bool(*)(attribute_provider_t *this, char*,host_t *))release_address;
+       this->public.provider.release_address = (bool(*)(attribute_provider_t *this, char*,host_t *, identification_t*))release_address;
        this->public.add_pool = (void(*)(stroke_attribute_t*, stroke_msg_t *msg))add_pool;
        this->public.del_pool = (void(*)(stroke_attribute_t*, stroke_msg_t *msg))del_pool;
        this->public.destroy = (void(*)(stroke_attribute_t*))destroy;
index 4033433..b11f717 100644 (file)
@@ -60,7 +60,7 @@ static void* testing(void *thread)
        /* release addresses */
        for (i = 0; i < ALLOCS; i++)
        {
-               charon->attributes->release_address(charon->attributes, "test", addr[i]);
+               charon->attributes->release_address(charon->attributes, "test", addr[i], id[i]);
        }
        
        /* cleanup */
index 979fe19..fa04c04 100644 (file)
@@ -2261,7 +2261,7 @@ static void destroy(private_ike_sa_t *this)
                {
                        charon->attributes->release_address(charon->attributes,
                                                                        this->peer_cfg->get_pool(this->peer_cfg),
-                                                                       this->other_virtual_ip);
+                                                                       this->other_virtual_ip, this->other_id);
                }
                this->other_virtual_ip->destroy(this->other_virtual_ip);
        }