From 01563352e8f95c24d50cb7e987aa9afed639dd44 Mon Sep 17 00:00:00 2001 From: Tobias Brunner Date: Tue, 6 Jul 2010 12:34:15 +0200 Subject: Moved update SA job creation to kernel event handler. --- src/libcharon/kernel/kernel_handler.c | 14 ++++++++++++++ 1 file changed, 14 insertions(+) (limited to 'src/libcharon/kernel/kernel_handler.c') diff --git a/src/libcharon/kernel/kernel_handler.c b/src/libcharon/kernel/kernel_handler.c index 64907b77d..b4fe1efed 100644 --- a/src/libcharon/kernel/kernel_handler.c +++ b/src/libcharon/kernel/kernel_handler.c @@ -20,6 +20,7 @@ #include #include #include +#include typedef struct private_kernel_handler_t private_kernel_handler_t; @@ -74,6 +75,18 @@ METHOD(kernel_listener_t, expire, bool, return TRUE; } +METHOD(kernel_listener_t, mapping, bool, + private_kernel_handler_t *this, u_int32_t reqid, u_int32_t spi, + host_t *remote) +{ + job_t *job; + DBG1(DBG_KNL, "NAT mappings of ESP CHILD_SA with SPI %.8x and " + "reqid {%u} changed, queuing update job", ntohl(spi), reqid); + job = (job_t*)update_sa_job_create(reqid, remote); + hydra->processor->queue_job(hydra->processor, job); + return TRUE; +} + METHOD(kernel_handler_t, destroy, void, private_kernel_handler_t *this) { @@ -91,6 +104,7 @@ kernel_handler_t *kernel_handler_create() .listener = { .acquire = _acquire, .expire = _expire, + .mapping = _mapping, }, .destroy = _destroy, }, -- cgit v1.2.3