4 * @brief Interface of stroke_t.
9 * Copyright (C) 2006 Martin Willi
10 * Hochschule fuer Technik Rapperswil
12 * This program is free software; you can redistribute it and/or modify it
13 * under the terms of the GNU General Public License as published by the
14 * Free Software Foundation; either version 2 of the License, or (at your
15 * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
17 * This program is distributed in the hope that it will be useful, but
18 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
19 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
23 #ifndef STROKE_INTERFACE_H_
24 #define STROKE_INTERFACE_H_
26 #include <config/policies/policy_store.h>
27 #include <config/connections/connection_store.h>
28 #include <config/credentials/credential_store.h>
31 typedef struct stroke_t stroke_t
;
34 * @brief Stroke is a configuration and control interface which
35 * allows other processes to modify charons behavior.
37 * stroke_t allows config manipulation (as whack in pluto).
38 * Messages of type stroke_msg_t's are sent over a unix socket
39 * (/var/run/charon.ctl). stroke_t implements the connections_t
40 * and the policies_t interface, which means it acts as a
41 * configuration backend for those too. stroke_t uses an own
42 * thread to read from the socket.
44 * @warning DO NOT cast stroke_t to any of the implemented interfaces!
45 * stroke_t implements multiple interfaces, so you must use
46 * stroke_t.interface_xy to access the specific interface! You have
49 * @todo Add clean thread cancellation
59 * Implements policy_store_t interface
61 policy_store_t policies
;
64 * Implements credential_store_t interfacce
66 credential_store_t credentials
;
69 * @brief Destroy a stroke_t instance.
71 * @param this stroke_t objec to destroy
73 void (*destroy
) (stroke_t
*this);
78 * @brief Create the stroke interface and listen on the socket.
80 * @return stroke_t object
84 stroke_t
*stroke_create();
86 #endif /* STROKE_INTERFACE_H_ */