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]
/
throttlectl.c
diff --git
a/throttlectl.c
b/throttlectl.c
index
565c4d8
..
7990151
100644
(file)
--- a/
throttlectl.c
+++ b/
throttlectl.c
@@
-5,7
+5,7
@@
/* throttle control */
/* throttle control */
-char const *cvs_id = "$Id: throttlectl.c,v 1.
1 2004/11/17 15:08:1
9 bodea Exp $";
+char const *cvs_id = "$Id: throttlectl.c,v 1.
6 2004/12/01 04:44:2
9 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,8
+16,6
@@
char *plugin_control_help[] = {
0
};
0
};
-static int iam_master = 0;
-
int plugin_init(struct pluginfuncs *funcs)
{
if (!funcs)
int plugin_init(struct pluginfuncs *funcs)
{
if (!funcs)
@@
-27,12
+25,6
@@
int plugin_init(struct pluginfuncs *funcs)
return 1;
}
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;
@@
-49,18
+41,14
@@
int plugin_control(struct param_control *data)
&& strcmp(data->argv[0], "unthrottle"))
return PLUGIN_RET_OK; // not for us
&& strcmp(data->argv[0], "unthrottle"))
return PLUGIN_RET_OK; // not for us
- flag = data->argv[0][0] != 'g';
+ 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] == 't';
if (flag)
{
if (flag)
{
- if (data->argc < 2 || data->argc >
4
)
+ if (data->argc < 2 || data->argc >
6
)
{
data->response = NSCTL_RES_ERR;
data->additional = "requires username or session id and optional rate(s)";
{
data->response = NSCTL_RES_ERR;
data->additional = "requires username or session id and optional rate(s)";
@@
-110,11
+98,11
@@
int plugin_control(struct param_control *data)
int len = strlen(data->argv[i]);
if (!strncmp(data->argv[i], "in", len))
{
int len = strlen(data->argv[i]);
if (!strncmp(data->argv[i], "in", len))
{
- rate_in = atoi(argv[i+1]);
+ rate_in = atoi(
data->
argv[i+1]);
}
else if (!strncmp(data->argv[i], "out", len))
{
}
else if (!strncmp(data->argv[i], "out", len))
{
- rate_out = atoi(argv[i+1]);
+ rate_out = atoi(
data->
argv[i+1]);
}
else
{
}
else
{
@@
-142,7
+130,7
@@
int plugin_control(struct param_control *data)
}
p->throttle(session, rate_in, rate_out);
}
p->throttle(session, rate_in, rate_out);
- p->sess
s
ion_changed(session);
+ p->session_changed(session);
data->response = NSCTL_RES_OK;
data->additional = 0;
data->response = NSCTL_RES_OK;
data->additional = 0;