aboutsummaryrefslogtreecommitdiffstats
path: root/src/libcharon/kernel
diff options
context:
space:
mode:
authorTobias Brunner <tobias@strongswan.org>2010-07-06 16:03:09 +0200
committerTobias Brunner <tobias@strongswan.org>2010-09-02 19:01:25 +0200
commitba26508d0598d440638710736031864320253d94 (patch)
tree01459ecd827e571b90a4436475cec5bd46b56508 /src/libcharon/kernel
parent61e8e73206829e1d37c8e64585dd283ab4a29cef (diff)
downloadstrongswan-ba26508d0598d440638710736031864320253d94.tar.bz2
strongswan-ba26508d0598d440638710736031864320253d94.tar.xz
Moved roam job creation to kernel event handler.
Diffstat (limited to 'src/libcharon/kernel')
-rw-r--r--src/libcharon/kernel/kernel_handler.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/libcharon/kernel/kernel_handler.c b/src/libcharon/kernel/kernel_handler.c
index 4fae6cde2..482f1494c 100644
--- a/src/libcharon/kernel/kernel_handler.c
+++ b/src/libcharon/kernel/kernel_handler.c
@@ -21,6 +21,7 @@
#include <processing/jobs/delete_child_sa_job.h>
#include <processing/jobs/migrate_job.h>
#include <processing/jobs/rekey_child_sa_job.h>
+#include <processing/jobs/roam_job.h>
#include <processing/jobs/update_sa_job.h>
typedef struct private_kernel_handler_t private_kernel_handler_t;
@@ -103,6 +104,15 @@ METHOD(kernel_listener_t, migrate, bool,
return TRUE;
}
+METHOD(kernel_listener_t, roam, bool,
+ private_kernel_handler_t *this, bool address)
+{
+ job_t *job;
+ job = (job_t*)roam_job_create(address);
+ hydra->processor->queue_job(hydra->processor, job);
+ return TRUE;
+}
+
METHOD(kernel_handler_t, destroy, void,
private_kernel_handler_t *this)
{
@@ -122,6 +132,7 @@ kernel_handler_t *kernel_handler_create()
.expire = _expire,
.mapping = _mapping,
.migrate = _migrate,
+ .roam = _roam,
},
.destroy = _destroy,
},