annotate mcabber/libjabber/rate.c @ 183:c658c131ea10

[/trunk] Changeset 195 by mikael * Fix a small bug (status is uppercase in log files)
author mikael
date Thu, 05 May 2005 15:01:48 +0000
parents bf3d6e241714
children ec86d759ed54
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
25
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
1 /*
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
2 * This program is free software; you can redistribute it and/or modify
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
3 * it under the terms of the GNU General Public License as published by
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
4 * the Free Software Foundation; either version 2 of the License, or
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
5 * (at your option) any later version.
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
6 *
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
7 * This program is distributed in the hope that it will be useful,
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
10 * GNU General Public License for more details.
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
11 *
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
12 * You should have received a copy of the GNU General Public License
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
13 * along with this program; if not, write to the Free Software
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
14 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
15 *
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
16 * Jabber
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
17 * Copyright (C) 1998-1999 The Jabber Team http://jabber.org/
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
18 */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
19
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
20 #include "jabber.h"
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
21
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
22 jlimit jlimit_new(int maxt, int maxp)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
23 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
24 pool p;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
25 jlimit r;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
26
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
27 p = pool_new();
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
28 r = pmalloc(p,sizeof(_jlimit));
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
29 r->key = NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
30 r->start = r->points = 0;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
31 r->maxt = maxt;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
32 r->maxp = maxp;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
33 r->p = p;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
34
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
35 return r;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
36 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
37
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
38 void jlimit_free(jlimit r)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
39 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
40 if(r != NULL)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
41 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
42 if(r->key != NULL) free(r->key);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
43 pool_free(r->p);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
44 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
45 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
46
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
47 int jlimit_check(jlimit r, char *key, int points)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
48 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
49 int now = time(NULL);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
50
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
51 if(r == NULL) return 0;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
52
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
53 /* make sure we didn't go over the time frame or get a null/new key */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
54 if((now - r->start) > r->maxt || key == NULL || j_strcmp(key,r->key) != 0)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
55 { /* start a new key */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
56 free(r->key);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
57 if(key != NULL)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
58 /* We use strdup instead of pstrdup since r->key needs to be free'd before
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
59 and more often than the rest of the rlimit structure */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
60 r->key = strdup(key);
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
61 else
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
62 r->key = NULL;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
63 r->start = now;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
64 r->points = 0;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
65 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
66
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
67 r->points += points;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
68
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
69 /* if we're within the time frame and over the point limit */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
70 if(r->points > r->maxp && (now - r->start) < r->maxt)
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
71 {
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
72 return 1; /* we don't reset the rate here, so that it remains rated until the time runs out */
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
73 }
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
74
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
75 return 0;
bf3d6e241714 [/trunk] Changeset 41 by mikael
mikael
parents:
diff changeset
76 }