X-Git-Url: http://git.sameswireless.fr/l2tpns.git/blobdiff_plain/bc5b25832a728dea4346782d84d63128035bcfaf..6fb1f18fb03c15e9e907d55c117281dca2b8b72a:/plugin.h?ds=inline

diff --git a/plugin.h b/plugin.h
index 8e151be..faf3a5e 100644
--- a/plugin.h
+++ b/plugin.h
@@ -1,7 +1,7 @@
 #ifndef __PLUGIN_H__
 #define __PLUGIN_H__
 
-#define PLUGIN_API_VERSION	4
+#define PLUGIN_API_VERSION	6
 #define MAX_PLUGIN_TYPES	30
 
 enum
@@ -15,6 +15,7 @@ enum
 	PLUGIN_KILL_SESSION,
 	PLUGIN_CONTROL,
 	PLUGIN_RADIUS_RESPONSE,
+	PLUGIN_RADIUS_RESET,
 	PLUGIN_BECOME_MASTER,
 	PLUGIN_NEW_SESSION_MASTER,
 };
@@ -27,14 +28,15 @@ enum
 struct pluginfuncs
 {
 	void (*log)(int level, sessionidt s, tunnelidt t, const char *format, ...);
-	void (*log_hex)(int level, const char *title, const char *data, int maxsize);
-	char *(*fmtaddr)(ipt addr, int n);
+	void (*log_hex)(int level, const char *title, const uint8_t *data, int maxsize);
+	char *(*fmtaddr)(in_addr_t addr, int n);
 	sessionidt (*get_session_by_username)(char *username);
 	sessiont *(*get_session_by_id)(sessionidt s);
 	sessionidt (*get_id_by_session)(sessiont *s);
-	u16 (*radiusnew)(sessionidt s);
-	void (*radiussend)(u16 r, u8 state);
+	uint16_t (*radiusnew)(sessionidt s);
+	void (*radiussend)(uint16_t r, uint8_t state);
 	void *(*getconfig)(char *key, enum config_typet type);
+	void (*sessionshutdown)(sessionidt s, char *reason, int result, int error);
 	void (*sessionkill)(sessionidt s, char *reason);
 	void (*throttle)(sessionidt s, int rate_in, int rate_out);
 	int (*session_changed)(int sid);
@@ -110,4 +112,10 @@ struct param_radius_response
 	char *value;
 };
 
+struct param_radius_reset
+{
+	tunnelt *t;
+	sessiont *s;
+};
+
 #endif /* __PLUGIN_H__ */