]> git.ipfire.org Git - thirdparty/strongswan.git/commitdiff
added imc/imv_manager remove method
authorAndreas Steffen <andreas.steffen@strongswan.org>
Mon, 8 Nov 2010 14:53:50 +0000 (15:53 +0100)
committerAndreas Steffen <andreas.steffen@strongswan.org>
Tue, 9 Nov 2010 19:43:51 +0000 (20:43 +0100)
src/libcharon/plugins/tnc_imc/tnc_imc_manager.c
src/libcharon/plugins/tnc_imv/tnc_imv_manager.c
src/libcharon/tnc/imc/imc_manager.h
src/libcharon/tnc/imv/imv_manager.h

index da10274f13f8acb641dde686fb3c809d86da9f12..bc1147ad86a43e3071ce009ace3447ec06e3fe49 100644 (file)
@@ -67,12 +67,31 @@ METHOD(imc_manager_t, add, bool,
        {
                DBG1(DBG_TNC, "could not provide bind function for IMC '%s'",
                                           imc->get_name(imc));
+               this->imcs->remove_last(this->imcs, (void**)&imc);
                return FALSE;
        }
 
        return TRUE;
 }
 
+METHOD(imc_manager_t, remove_, imc_t*,
+       private_tnc_imc_manager_t *this, TNC_IMCID id)
+{
+       enumerator_t *enumerator;
+       imc_t *imc;
+
+       enumerator = this->imcs->create_enumerator(this->imcs);
+       while (enumerator->enumerate(enumerator, &imc))
+       {
+               if (id == imc->get_id(imc))
+               {
+                       this->imcs->remove_at(this->imcs, enumerator);
+                       return imc;
+               }
+       }
+       enumerator->destroy(enumerator);
+}
+
 METHOD(imc_manager_t, notify_connection_change, void,
        private_tnc_imc_manager_t *this, TNC_ConnectionID id,
        TNC_ConnectionState state)
@@ -178,6 +197,7 @@ imc_manager_t* tnc_imc_manager_create(void)
        INIT(this,
                .public = {
                        .add = _add,
+                       .remove = _remove_, /* avoid name conflict with stdio.h */
                        .notify_connection_change = _notify_connection_change,
                        .begin_handshake = _begin_handshake,
                        .set_message_types = _set_message_types,
index 4beaccc078aecfe45013d2c39a2e32c8c4ad1116..667f1e322afe385e60976e0927f546b90229b442 100644 (file)
@@ -67,11 +67,30 @@ METHOD(imv_manager_t, add, bool,
        {
                DBG1(DBG_TNC, "could not provide bind function for IMV '%s'",
                                           imv->get_name(imv));
+               this->imvs->remove_last(this->imvs, (void**)&imv);
                return FALSE;
        }
        return TRUE;
 }
 
+METHOD(imv_manager_t, remove_, imv_t*,
+       private_tnc_imv_manager_t *this, TNC_IMVID id)
+{
+       enumerator_t *enumerator;
+       imv_t *imv;
+
+       enumerator = this->imvs->create_enumerator(this->imvs);
+       while (enumerator->enumerate(enumerator, &imv))
+       {
+               if (id == imv->get_id(imv))
+               {
+                       this->imvs->remove_at(this->imvs, enumerator);
+                       return imv;
+               }
+       }
+       enumerator->destroy(enumerator);
+}
+
 METHOD(imv_manager_t, notify_connection_change, void,
        private_tnc_imv_manager_t *this, TNC_ConnectionID id,
                                                                         TNC_ConnectionState state)
@@ -163,6 +182,7 @@ imv_manager_t* tnc_imv_manager_create(void)
        INIT(this,
                .public = {
                        .add = _add,
+                       .remove = _remove_, /* avoid name conflict with stdio.h */
                        .notify_connection_change = _notify_connection_change,
                        .set_message_types = _set_message_types,
                        .receive_message = _receive_message,
index 60bfe349902135db6c988e5156b9848a05c3e85b..169259f72ca25a2d5607d400b19e87bb3b74821e 100644 (file)
@@ -40,6 +40,14 @@ struct imc_manager_t {
         */
         bool (*add)(imc_manager_t *this, imc_t *imc);
 
+       /**
+        * Remove an IMC instance from the list and return it
+        *
+        * @param id                            ID of IMC instance
+        * @return                                      removed IMC instance
+        */
+       imc_t* (*remove)(imc_manager_t *this, TNC_IMCID id);
+
        /**
         * Notify all IMC instances
         *
index c93f572fcd9060115c043c190950f0c5def96879..56cb6a0f8757564e7c8147fd5edab4a17312f59f 100644 (file)
@@ -40,6 +40,14 @@ struct imv_manager_t {
         */
        bool (*add)(imv_manager_t *this, imv_t *imv);
 
+       /**
+        * Remove an IMV instance from the list and return it
+        *
+        * @param id                            ID of IMV instance
+        * @return                                      removed IMC instance
+        */
+       void (*remove)(imv_manager_t *this, TNC_IMVID id);
+
        /**
         * Notify all IMV instances
         *