projects
/
l2tpns.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
clear cluster_master on election so that slaves will accept a new master
[l2tpns.git]
/
plugin.h
diff --git
a/plugin.h
b/plugin.h
index
be92047
..
ca0368f
100644
(file)
--- a/
plugin.h
+++ b/
plugin.h
@@
-1,7
+1,7
@@
#ifndef __PLUGIN_H__
#define __PLUGIN_H__
#ifndef __PLUGIN_H__
#define __PLUGIN_H__
-#define PLUGIN_API_VERSION
2
+#define PLUGIN_API_VERSION
4
#define MAX_PLUGIN_TYPES 30
enum
#define MAX_PLUGIN_TYPES 30
enum
@@
-21,20
+21,23
@@
enum
#define PLUGIN_RET_ERROR 0
#define PLUGIN_RET_OK 1
#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
{
struct pluginfuncs
{
- void (*log)(int level,
ipt address,
sessionidt s, tunnelidt t, const char *format, ...);
+ void (*log)(int level, sessionidt s, tunnelidt t, const char *format, ...);
void (*log_hex)(int level, const char *title, const char *data, int maxsize);
void (*log_hex)(int level, const char *title, const char *data, int maxsize);
- char *(*
inet_toa)(unsigned long addr
);
+ 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);
sessionidt (*get_session_by_username)(char *username);
sessiont *(*get_session_by_id)(sessionidt s);
sessionidt (*get_id_by_session)(sessiont *s);
- void (*sessionkill)(sessionidt s, char *reason);
- 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 *(*getconfig)(char *key, enum config_typet type);
+ void (*sessionkill)(sessionidt s, char *reason);
+ void (*throttle)(sessionidt s, int rate_in, int rate_out);
+ int (*session_changed)(int sid);
};
struct param_pre_auth
};
struct param_pre_auth
@@
-79,17
+82,12
@@
struct param_timer
struct param_control
{
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
};
struct param_new_session