2 * Copyright (C) 2014 Martin Willi
4 * Copyright (C) secunet Security Networks AG
6 * This program is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the
8 * Free Software Foundation; either version 2 of the License, or (at your
9 * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
11 * This program is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
13 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
17 #include "connmark_plugin.h"
18 #include "connmark_listener.h"
22 typedef struct private_connmark_plugin_t private_connmark_plugin_t
;
25 * private data of connmark plugin
27 struct private_connmark_plugin_t
{
30 * implements plugin interface
32 connmark_plugin_t
public;
35 * Listener installing netfilter rules
37 connmark_listener_t
*listener
;
40 METHOD(plugin_t
, get_name
, char*,
41 private_connmark_plugin_t
*this)
49 static bool plugin_cb(private_connmark_plugin_t
*this,
50 plugin_feature_t
*feature
, bool reg
, void *cb_data
)
54 charon
->bus
->add_listener(charon
->bus
, &this->listener
->listener
);
58 charon
->bus
->remove_listener(charon
->bus
, &this->listener
->listener
);
63 METHOD(plugin_t
, get_features
, int,
64 private_connmark_plugin_t
*this, plugin_feature_t
*features
[])
66 static plugin_feature_t f
[] = {
67 PLUGIN_CALLBACK((plugin_feature_callback_t
)plugin_cb
, NULL
),
68 PLUGIN_PROVIDE(CUSTOM
, "connmark"),
74 METHOD(plugin_t
, destroy
, void,
75 private_connmark_plugin_t
*this)
77 this->listener
->destroy(this->listener
);
84 plugin_t
*connmark_plugin_create()
86 private_connmark_plugin_t
*this;
88 if (!lib
->caps
->keep(lib
->caps
, CAP_NET_ADMIN
))
90 DBG1(DBG_NET
, "connmark plugin requires CAP_NET_ADMIN capability");
94 if (!lib
->caps
->keep(lib
->caps
, CAP_NET_RAW
))
96 DBG1(DBG_NET
, "connmark plugin requires CAP_NET_RAW capability");
103 .get_name
= _get_name
,
104 .get_features
= _get_features
,
108 .listener
= connmark_listener_create(),
111 return &this->public.plugin
;