aboutsummaryrefslogtreecommitdiffstats
path: root/src/libcharon/kernel
diff options
context:
space:
mode:
authorTobias Brunner <tobias@strongswan.org>2010-07-06 12:46:40 +0200
committerTobias Brunner <tobias@strongswan.org>2010-09-02 19:01:24 +0200
commit4e258e63c3771509ff529a6369aa4bd44d5fb882 (patch)
tree63f89238230606693c138003eaaf3feaa13b59ed /src/libcharon/kernel
parent01563352e8f95c24d50cb7e987aa9afed639dd44 (diff)
downloadstrongswan-4e258e63c3771509ff529a6369aa4bd44d5fb882.tar.bz2
strongswan-4e258e63c3771509ff529a6369aa4bd44d5fb882.tar.xz
Moved migrate job creation to kernel event handler.
Diffstat (limited to 'src/libcharon/kernel')
-rw-r--r--src/libcharon/kernel/kernel_handler.c19
1 files changed, 18 insertions, 1 deletions
diff --git a/src/libcharon/kernel/kernel_handler.c b/src/libcharon/kernel/kernel_handler.c
index b4fe1efed..4fae6cde2 100644
--- a/src/libcharon/kernel/kernel_handler.c
+++ b/src/libcharon/kernel/kernel_handler.c
@@ -18,8 +18,9 @@
#include <hydra.h>
#include <daemon.h>
#include <processing/jobs/acquire_job.h>
-#include <processing/jobs/rekey_child_sa_job.h>
#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/update_sa_job.h>
typedef struct private_kernel_handler_t private_kernel_handler_t;
@@ -87,6 +88,21 @@ METHOD(kernel_listener_t, mapping, bool,
return TRUE;
}
+METHOD(kernel_listener_t, migrate, bool,
+ private_kernel_handler_t *this, u_int32_t reqid,
+ traffic_selector_t *src_ts, traffic_selector_t *dst_ts,
+ policy_dir_t direction, host_t *local, host_t *remote)
+{
+ job_t *job;
+ DBG1(DBG_KNL, "creating migrate job for policy %R === %R %N with "
+ "reqid {%u}", src_ts, dst_ts, policy_dir_names, direction,
+ reqid, local);
+ job = (job_t*)migrate_job_create(reqid, src_ts, dst_ts, direction, local,
+ remote);
+ hydra->processor->queue_job(hydra->processor, job);
+ return TRUE;
+}
+
METHOD(kernel_handler_t, destroy, void,
private_kernel_handler_t *this)
{
@@ -105,6 +121,7 @@ kernel_handler_t *kernel_handler_create()
.acquire = _acquire,
.expire = _expire,
.mapping = _mapping,
+ .migrate = _migrate,
},
.destroy = _destroy,
},