forked from voipmonitor/sniffer
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathregcache.cpp
126 lines (105 loc) · 2.77 KB
/
regcache.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <getopt.h>
#include <time.h>
#include <signal.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <net/ethernet.h>
#include "voipmonitor.h"
#ifdef FREEBSD
#include <machine/endian.h>
#else
#include <malloc.h>
#include <endian.h>
#endif
#include <sys/times.h>
#include <sys/param.h>
#include <sys/signal.h>
#include <netinet/in.h>
#include <netinet/ip.h>
#include <netinet/tcp.h>
#include <syslog.h>
#include <semaphore.h>
#include <sstream>
#include <pcap.h>
#include "tools.h"
#include "regcache.h"
#include "voipmonitor.h"
#include "sql_db.h"
using namespace std;
extern MySqlStore *sqlStore;
extern int opt_mysqlstore_max_threads_register;
int
regcache::check(unsigned int saddr, unsigned int daddr, unsigned int timestamp, unsigned int *count) {
lock();
char buf[32];
sprintf(buf, "%uD%u", saddr, daddr);
string key = buf;
t_regcache_buffer::iterator iter;
iter = regcache_buffer.find(key);
if(iter != regcache_buffer.end()) {
//found
iter->second.counter++;
*count = iter->second.counter;
if(iter->second.timestamp + 60 <= timestamp) {
iter->second.counter = 0;
iter->second.timestamp = timestamp;
unlock();
return 0;
} else {
unlock();
return 1;
}
} else {
//not found
regcachenode_t regcachenode;
regcachenode.timestamp = timestamp;
regcachenode.counter = 1;
regcache_buffer[key] = regcachenode;
*count = 1;
unlock();
return 0;
}
unlock();
return 0;
}
void
regcache::prune(unsigned int timestamp) {
lock();
t_regcache_buffer::iterator iter;
for(iter = regcache_buffer.begin(); iter != regcache_buffer.end();) {
if(timestamp == 0 or timestamp > iter->second.timestamp + 300) {
vector<std::string> res = split(iter->first, 'D');
stringstream ts, cntr;
ts << iter->second.timestamp;
cntr << iter->second.counter;
string query = string("UPDATE register_failed SET created_at = FROM_UNIXTIME(") + ts.str() + "), counter = counter + " + cntr.str() + " WHERE sipcallerip = " + res[0].c_str() + " AND sipcalledip = " + res[1].c_str() + " AND created_at >= SUBTIME(FROM_UNIXTIME(" + ts.str() + "), '01:00:00')";
static unsigned int counterSqlStore = 0;
int storeId = STORE_PROC_ID_REGISTER_1 +
(opt_mysqlstore_max_threads_register > 1 &&
sqlStore->getSize(STORE_PROC_ID_REGISTER_1) > 1000 ?
counterSqlStore % opt_mysqlstore_max_threads_register :
0);
++counterSqlStore;
sqlStore->query_lock(query.c_str(), storeId);
regcache_buffer.erase(iter++);
} else {
iter++;
}
}
unlock();
}
void
regcache::prunecheck(unsigned int timestamp) {
if(lastprune + 10 < timestamp) {
prune(timestamp);
lastprune = timestamp;
}
}
regcache::~regcache() {
prune(0);
pthread_mutex_destroy(&buf_lock);
}