projects
/
l2tpns.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Any ping from what we think is the master should force an election.
[l2tpns.git]
/
plugin.h
diff --git
a/plugin.h
b/plugin.h
index
0f2ed0f
..
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
1
+#define PLUGIN_API_VERSION
4
#define MAX_PLUGIN_TYPES 30
enum
#define MAX_PLUGIN_TYPES 30
enum
@@
-21,19
+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);
+ uint16_t (*radiusnew)(sessionidt s);
+ void (*radiussend)(uint16_t r, uint8_t state);
+ void *(*getconfig)(char *key, enum config_typet type);
void (*sessionkill)(sessionidt s, char *reason);
void (*sessionkill)(sessionidt s, char *reason);
-
u16 (*radiusnew)(sessionidt s
);
-
void (*radiussend)(u16 r, u8 state
);
+
void (*throttle)(sessionidt s, int rate_in, int rate_out
);
+
int (*session_changed)(int sid
);
};
struct param_pre_auth
};
struct param_pre_auth
@@
-76,25
+80,14
@@
struct param_timer
time_t time_now;
};
time_t time_now;
};
-struct param_config
-{
- char *key;
- char *value;
-};
-
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