forked from bmuller/mod_auth_openid
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSessionManager.h
67 lines (52 loc) · 2.29 KB
/
SessionManager.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
/*
Copyright (C) 2007-2010 Butterfat, LLC (http://butterfat.net)
Permission is hereby granted, free of charge, to any person
obtaining a copy of this software and associated documentation
files (the "Software"), to deal in the Software without
restriction, including without limitation the rights to use,
copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the
Software is furnished to do so, subject to the following
conditions:
The above copyright notice and this permission notice shall be
included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
OTHER DEALINGS IN THE SOFTWARE.
Created by bmuller <[email protected]>
*/
namespace modauthopenid {
using namespace opkele;
using namespace std;
// This class keeps track of cookie based sessions
class SessionManager {
public:
// storage_location is db location
SessionManager(const string& storage_location);
~SessionManager() { close(); };
// get session with id session_id and set values in session
// if session doesn't exist, don't do anything
void get_session(const string& session_id, session_t& session);
// store given session information in a new session entry
// if lifespan is 0, let it expire in a day. otherwise, expire in "lifespan" seconds
// See issue 16 - http://trac.butterfat.net/public/mod_auth_openid/ticket/16
void store_session(const string& session_id, const string& hostname, const string& path, const string& identity, int lifespan);
// print session table to stdout
void print_table();
// close database
void close();
private:
sqlite3 *db;
// delete all expired sessions
void ween_expired();
// db status
bool is_closed;
// test sqlite query result - print any errors to stderr
bool test_result(int result, const string& context);
};
}