aboutsummaryrefslogtreecommitdiffstats
path: root/src/libcharon/kernel/kernel_handler.c
diff options
context:
space:
mode:
authorTobias Brunner <tobias@strongswan.org>2010-07-06 11:50:43 +0200
committerTobias Brunner <tobias@strongswan.org>2010-09-02 19:01:23 +0200
commit81f6ec276b1322d79428e6195c03065259482a50 (patch)
treeb5cb627a457329290bebf6e7e5e056cfa5b8cd36 /src/libcharon/kernel/kernel_handler.c
parent09ae31f13a65e4946d5e71ffd635af62b1695e1c (diff)
downloadstrongswan-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.c23
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,
},