projects
/
l2tpns.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
bug fix
[l2tpns.git]
/
snoopctl.c
diff --git
a/snoopctl.c
b/snoopctl.c
index
3d79ab0
..
5fabe24
100644
(file)
--- a/
snoopctl.c
+++ b/
snoopctl.c
@@
-5,7
+5,7
@@
/* snoop control */
/* snoop control */
-char const *cvs_id = "$Id: snoopctl.c,v 1.
2 2004/11/18 05:44:36
bodea Exp $";
+char const *cvs_id = "$Id: snoopctl.c,v 1.
5 2005/06/28 14:48:28
bodea Exp $";
int plugin_api_version = PLUGIN_API_VERSION;
static struct pluginfuncs *p = 0;
int plugin_api_version = PLUGIN_API_VERSION;
static struct pluginfuncs *p = 0;
@@
-16,23
+16,6
@@
char *plugin_control_help[] = {
0
};
0
};
-static int iam_master = 0;
-
-int plugin_init(struct pluginfuncs *funcs)
-{
- if (!funcs)
- return 0;
-
- p = funcs;
- return 1;
-}
-
-int plugin_become_master(void)
-{
- iam_master = 1;
- return PLUGIN_RET_OK;
-}
-
int plugin_control(struct param_control *data)
{
sessionidt session;
int plugin_control(struct param_control *data)
{
sessionidt session;
@@
-46,14
+29,10
@@
int plugin_control(struct param_control *data)
if (strcmp(data->argv[0], "snoop") && strcmp(data->argv[0], "unsnoop"))
return PLUGIN_RET_OK; // not for us
if (strcmp(data->argv[0], "snoop") && strcmp(data->argv[0], "unsnoop"))
return PLUGIN_RET_OK; // not for us
- flag = data->argv[0][0] != 'u';
+ if (!data->iam_master)
+ return PLUGIN_RET_NOTMASTER;
- if (!iam_master)
- {
- data->response = NSCTL_RES_ERR;
- data->additional = "must be run on the cluster master";
- return PLUGIN_RET_STOP;
- }
+ flag = data->argv[0][0] != 'u';
if (flag)
{
if (flag)
{
@@
-89,8
+68,8
@@
int plugin_control(struct param_control *data)
if (flag)
{
if (flag)
{
- i
p
t ip = inet_addr(data->argv[2]);
- u
16
port = atoi(data->argv[3]);
+ i
n_addr_
t ip = inet_addr(data->argv[2]);
+ u
int16_t
port = atoi(data->argv[3]);
if (!ip || ip == INADDR_NONE)
{
if (!ip || ip == INADDR_NONE)
{
@@
-136,3
+115,15
@@
int plugin_control(struct param_control *data)
return PLUGIN_RET_STOP;
}
return PLUGIN_RET_STOP;
}
+
+int plugin_radius_reset(struct param_radius_reset *data)
+{
+ data->s->snoop_ip = 0;
+ data->s->snoop_port = 0;
+ return PLUGIN_RET_OK;
+}
+
+int plugin_init(struct pluginfuncs *funcs)
+{
+ return ((p = funcs)) ? 1 : 0;
+}