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
127
128
129
130
131
132
133
134
135
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set et sw=2 ts=2: */
/***************************************************************************
* admin_connection.cc
*
* Thu Feb 3 09:33:44 CET 2011
* Copyright 2011 Bent Bisballe Nyeng
* deva@aasimon.org
****************************************************************************/
/*
* This file is part of Pracro.
*
* Pracro is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* Pracro 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Pracro; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
*/
#include "admin_connection.h"
#include "admin_rc.h"
#include "debug.h"
#include "configuration.h"
static std::string admin_sessionunlock(Environment &env, std::string id)
{
Session *session = env.sessions.session(id);
if(session) {
if(session->isreadonly) {
env.sessions.deleteSession(id);
return "Session " + id + " was 'readonly' and has been discarded.";
} else {
session->setActive(false);
return "Session " + id + " has been deactivated (set to idle).";
}
}
return "Session " + id + " does not exist or has been committed.";
}
static std::string admin_listactivesessions(Environment &env)
{
std::string str;
std::vector<std::string> act = env.sessions.activeSessions();
std::vector<std::string>::iterator i = act.begin();
while(i != act.end()) {
str += "Session " + *i + "\n";
i++;
}
return str;
}
static std::string admin_header(std::string uri)
{
return admin_rc("header1") + uri + admin_rc("header2");
}
static std::string admin_flush(Environment &env)
{
env.sessions.store();
return "All sessions flushed to disc in " + Conf::session_path + ".";
}
AdminConnection::AdminConnection(Environment &e, headers_t a, std::string u)
: env(e), args(a), uri(u) {}
AdminConnection::~AdminConnection() {}
bool AdminConnection::handle(const char *data, size_t size)
{
if(data == NULL && size == 0) {
DEBUG(admin, "URI: %s\n", uri.c_str());
if(uri == "/") {
reply = admin_header(uri) +
"Command list:\n"
"<strong>/sessionunlock?id=<em>[ID]</em></strong> unlock session with [ID] as its session id.\n"
"<strong>/listactivesessions</strong> lists all active sessions on the server.\n"
"<strong>/flushsessions</strong> flushes all active sessions to disc.\n"
+ admin_rc("footer");
return true;
}
if(uri == "/sessionunlock" && args.find("id") != args.end()) {
reply = admin_header(uri) + admin_sessionunlock(env, args["id"])
+ admin_rc("footer");
return true;
}
if(uri == "/listactivesessions") {
reply = admin_header(uri) + admin_listactivesessions(env)
+ admin_rc("footer");
return true;
}
if(uri == "/flushsessions") {
reply = admin_header(uri) + admin_flush(env)
+ admin_rc("footer");
return true;
}
if(uri == "/favicon.ico") {
reply = admin_rc("favicon");
return true;
}
reply = "'" + uri + "' not recognised as a valid command.";
return true;
}
return true;
}
void AdminConnection::getReply(Httpd::Reply &r)
{
headers_t hdrs;
if(uri == "/favicon.ico") hdrs["Content-Type"] = "image/ico";
else hdrs["Content-Type"] = "text/html; charset=UTF-8";
r.data = reply;
r.headers = hdrs;
r.status = 200; // http 'OK'
}
|