diff options
author | Tobias Brunner <tobias@strongswan.org> | 2010-07-06 11:50:43 +0200 |
---|---|---|
committer | Tobias Brunner <tobias@strongswan.org> | 2010-09-02 19:01:23 +0200 |
commit | 81f6ec276b1322d79428e6195c03065259482a50 (patch) | |
tree | b5cb627a457329290bebf6e7e5e056cfa5b8cd36 /src/libcharon/kernel/kernel_handler.c | |
parent | 09ae31f13a65e4946d5e71ffd635af62b1695e1c (diff) | |
download | strongswan-81f6ec276b1322d79428e6195c03065259482a50.tar.bz2 strongswan-81f6ec276b1322d79428e6195c03065259482a50.tar.xz |
Moved acquire 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, 22 insertions, 1 deletions
diff --git a/src/libcharon/kernel/kernel_handler.c b/src/libcharon/kernel/kernel_handler.c index 0e967fe5f..5a12e35ab 100644 --- a/src/libcharon/kernel/kernel_handler.c +++ b/src/libcharon/kernel/kernel_handler.c @@ -15,7 +15,9 @@ #include "kernel_handler.h" +#include <hydra.h> #include <daemon.h> +#include <processing/jobs/acquire_job.h> typedef struct private_kernel_handler_t private_kernel_handler_t; @@ -31,6 +33,25 @@ struct private_kernel_handler_t { }; +METHOD(kernel_listener_t, acquire, bool, + private_kernel_handler_t *this, u_int32_t reqid, + traffic_selector_t *src_ts, traffic_selector_t *dst_ts) +{ + job_t *job; + if (src_ts && dst_ts) + { + DBG1(DBG_KNL, "creating acquire job for policy %R === %R " + "with reqid {%u}", src_ts, dst_ts, reqid); + } + else + { + DBG1(DBG_KNL, "creating acquire job for policy with reqid {%u}", reqid); + } + job = (job_t*)acquire_job_create(reqid, src_ts, dst_ts); + hydra->processor->queue_job(hydra->processor, job); + return TRUE; +} + METHOD(kernel_handler_t, destroy, void, private_kernel_handler_t *this) { @@ -46,7 +67,7 @@ kernel_handler_t *kernel_handler_create() INIT(this, .public = { .listener = { - .acquire = NULL, + .acquire = _acquire, }, .destroy = _destroy, }, |