forked from RangeNetworks/subscriberRegistry
-
Notifications
You must be signed in to change notification settings - Fork 1
/
servershare.h
executable file
·69 lines (56 loc) · 1.97 KB
/
servershare.h
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
/*
* Copyright 2011 Kestrel Signal Processing, Inc.
* Copyright 2011, 2014 Range Networks, Inc.
*
* This software is distributed under the terms of the GNU Affero Public License.
* See the COPYING file in the main directory for details.
*
* This use of this software may be subject to additional restrictions.
* See the LEGAL file in the main directory for details.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include <string>
#include "sqlite3.h"
using namespace std;
/**
Returns all valid configuration keys for the subscriber registry.
*/
ConfigurationKeyMap getConfigurationKeys();
/**
Generate a 128-bit random number.
@param imsi imsi of subscriber the random number is for
*/
string generateRand(string imsi);
/**
Authenticate
@param imsi imsi of subscriber
@param rand random number
@param sres corresponsing sres
*/
bool authenticate(string imsi, string rand, string sres, string *kc);
/**
Join the strings in strings, separated by separator
@param separator the separator
@param strings the strings to join
*/
string join(string separator, vector<string> &strings);
/**
Split tosplit into strings in fields, using separator
@param separator the separator to look for
@param tosplit the string to split
@param fields the vector result
*/
void split(char separator, string tosplit, vector<string> *fields);
/**
Open the database whose name is in the config table
*/
sqlite3 *openDB();