diff options
author | Tobias Brunner <tobias@strongswan.org> | 2010-07-06 12:09:06 +0200 |
---|---|---|
committer | Tobias Brunner <tobias@strongswan.org> | 2010-09-02 19:01:24 +0200 |
commit | a22853b302f6b15c03f647fcf4c9e9498314dcd7 (patch) | |
tree | d5623a0ed48ccdb131b63a53e54873f3da24a9e1 /src/libcharon/kernel/kernel_handler.c | |
parent | 81f6ec276b1322d79428e6195c03065259482a50 (diff) | |
download | strongswan-a22853b302f6b15c03f647fcf4c9e9498314dcd7.tar.bz2 strongswan-a22853b302f6b15c03f647fcf4c9e9498314dcd7.tar.xz |
Moved delete/rekey CHILD_SA job creation to kernel event handler.
Diffstat (limited to 'src/libcharon/kernel/kernel_handler.c')
-rw-r--r-- | src/libcharon/kernel/kernel_handler.c | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/src/libcharon/kernel/kernel_handler.c b/src/libcharon/kernel/kernel_handler.c index 5a12e35ab..64907b77d 100644 --- a/src/libcharon/kernel/kernel_handler.c +++ b/src/libcharon/kernel/kernel_handler.c @@ -18,6 +18,8 @@ #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> typedef struct private_kernel_handler_t private_kernel_handler_t; @@ -52,6 +54,26 @@ METHOD(kernel_listener_t, acquire, bool, return TRUE; } +METHOD(kernel_listener_t, expire, bool, + private_kernel_handler_t *this, u_int32_t reqid, protocol_id_t protocol, + u_int32_t spi, bool hard) +{ + job_t *job; + DBG1(DBG_KNL, "creating %s job for %N CHILD_SA with SPI %.8x " + "and reqid {%u}", hard ? "delete" : "rekey", + protocol_id_names, protocol, ntohl(spi), reqid); + if (hard) + { + job = (job_t*)delete_child_sa_job_create(reqid, protocol, spi); + } + else + { + job = (job_t*)rekey_child_sa_job_create(reqid, protocol, spi); + } + hydra->processor->queue_job(hydra->processor, job); + return TRUE; +} + METHOD(kernel_handler_t, destroy, void, private_kernel_handler_t *this) { @@ -68,6 +90,7 @@ kernel_handler_t *kernel_handler_create() .public = { .listener = { .acquire = _acquire, + .expire = _expire, }, .destroy = _destroy, }, |