projects
/
l2tpns.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
include Acct-Session-Time in interim records
[l2tpns.git]
/
throttlectl.c
diff --git
a/throttlectl.c
b/throttlectl.c
index
f9c3d1d
..
7aca35e
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.
2 2004-11-18 05:44:36
bodea Exp $";
+char const *cvs_id = "$Id: throttlectl.c,v 1.
7 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;
@@
-49,18
+32,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)";
@@
-149,3
+128,14
@@
int plugin_control(struct param_control *data)
return PLUGIN_RET_STOP;
}
return PLUGIN_RET_STOP;
}
+
+int plugin_radius_reset(struct param_radius_reset *data)
+{
+ p->throttle(p->get_id_by_session(data->s), 0, 0);
+ return PLUGIN_RET_OK;
+}
+
+int plugin_init(struct pluginfuncs *funcs)
+{
+ return ((p = funcs)) ? 1 : 0;
+}