X-Git-Url: http://git.sameswireless.fr/l2tpns.git/blobdiff_plain/b43583c01d146d8cc3cb826937efe3d0f47ec819..faf6701f6b19073b133d5db6f259c2e67f0c6c2b:/plugin.h?ds=inline diff --git a/plugin.h b/plugin.h index b41b16f..8e151be 100644 --- a/plugin.h +++ b/plugin.h @@ -1,7 +1,7 @@ #ifndef __PLUGIN_H__ #define __PLUGIN_H__ -#define PLUGIN_API_VERSION 1 +#define PLUGIN_API_VERSION 4 #define MAX_PLUGIN_TYPES 30 enum @@ -14,24 +14,30 @@ enum PLUGIN_NEW_SESSION, PLUGIN_KILL_SESSION, PLUGIN_CONTROL, - PLUGIN_RADIUS_RESPONSE + PLUGIN_RADIUS_RESPONSE, + PLUGIN_BECOME_MASTER, + PLUGIN_NEW_SESSION_MASTER, }; #define PLUGIN_RET_ERROR 0 #define PLUGIN_RET_OK 1 -#define PLUGIN_RET_STOP 2 +#define PLUGIN_RET_STOP 2 +#define PLUGIN_RET_NOTMASTER 3 struct pluginfuncs { - void (*_log)(int level, ipt address, sessionidt s, tunnelidt t, const char *format, ...); - void (*_log_hex)(int level, ipt address, sessionidt s, tunnelidt t, const char *title, const char *data, int maxsize); - char *(*inet_toa)(unsigned long addr); + 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); 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); + void *(*getconfig)(char *key, enum config_typet type); void (*sessionkill)(sessionidt s, char *reason); - u8 (*radiusnew)(sessionidt s); - void (*radiussend)(u8 r, u8 state); + void (*throttle)(sessionidt s, int rate_in, int rate_out); + int (*session_changed)(int sid); }; struct param_pre_auth @@ -74,25 +80,14 @@ struct param_timer time_t time_now; }; -struct param_config -{ - char *key; - char *value; -}; - struct param_control { - char *buf; - int l; - unsigned int source_ip; - unsigned short source_port; - char *response; - int response_length; - int send_response; - short type; - int id; - char *data; - int data_length; + int iam_master; + int argc; + char **argv; + // output + int response; + char *additional; }; struct param_new_session @@ -115,4 +110,4 @@ struct param_radius_response char *value; }; -#endif +#endif /* __PLUGIN_H__ */