summaryrefslogtreecommitdiffstats
path: root/servers/admin_sys_ctl_server_lin/src
diff options
context:
space:
mode:
Diffstat (limited to 'servers/admin_sys_ctl_server_lin/src')
-rw-r--r--servers/admin_sys_ctl_server_lin/src/admin_sys_ctl.cpp101
-rw-r--r--servers/admin_sys_ctl_server_lin/src/main.cpp2
2 files changed, 66 insertions, 37 deletions
diff --git a/servers/admin_sys_ctl_server_lin/src/admin_sys_ctl.cpp b/servers/admin_sys_ctl_server_lin/src/admin_sys_ctl.cpp
index f0cf958..7418de1 100644
--- a/servers/admin_sys_ctl_server_lin/src/admin_sys_ctl.cpp
+++ b/servers/admin_sys_ctl_server_lin/src/admin_sys_ctl.cpp
@@ -137,7 +137,7 @@ void SysCtlSocket::finishKerberosHandshake() {
masterRealm = "(NULL)";
}
if ((m_authenticatedUserName != masterUser) || (m_authenticatedRealmName != masterRealm)) {
- printf("[DEBUG] Connection from %s closed due to authentication failure (attempted connection as user %s@%s)\n\r", m_remoteHost.ascii(), masterUser.ascii(), masterRealm.ascii());
+ printf("[DEBUG] Connection from %s closed due to authentication failure (attempted connection as user %s@%s)\n\r", m_remoteHost.ascii(), m_authenticatedUserName.ascii(), m_authenticatedRealmName.ascii());
close();
return;
}
@@ -182,48 +182,56 @@ void SysCtlSocket::commandLoop() {
if (subCommand == "TERMINALS") {
clearFrameTail();
ds << TQString("OK");
- writeEndOfFrame();
+ TerminalServiceStatusList list;
TQSqlCursor databaseActivityCursor("sessions", TRUE, m_terminals_database);
databaseActivityCursor.select();
while (databaseActivityCursor.next()) {
- TQ_UINT32 protocolVersion = 1;
- TQDateTime loginStamp;
- TQDateTime activityStamp;
- loginStamp.setTime_t(databaseActivityCursor.value("stamp_start").toInt());
- activityStamp.setTime_t(databaseActivityCursor.value("stamp_statechange").toInt());
-
- ds << protocolVersion;
- ds << databaseActivityCursor.value("pk").toInt();
- ds << databaseActivityCursor.value("username").toString();
- ds << databaseActivityCursor.value("servername").toString();
- ds << databaseActivityCursor.value("server_pid").toInt();
- ds << databaseActivityCursor.value("wm_pid").toInt();
- ds << databaseActivityCursor.value("state").toInt();
- ds << databaseActivityCursor.value("display").toInt();
- ds << loginStamp;
- ds << activityStamp;
+ TerminalServiceStatusType status;
+
+ status.protocolVersion = 1;
+ status.sessionID = databaseActivityCursor.value("pk").toInt();
+ status.username = databaseActivityCursor.value("username").toString();
+ status.serverName = databaseActivityCursor.value("servername").toString();
+ status.serverPID = databaseActivityCursor.value("server_pid").toInt();
+ status.wmPID = databaseActivityCursor.value("wm_pid").toInt();
+ status.state = databaseActivityCursor.value("state").toInt();
+ status.display = databaseActivityCursor.value("display").toInt();
+ status.loginStamp.setTime_t(databaseActivityCursor.value("stamp_start").toLongLong());
+ status.activityStamp.setTime_t(databaseActivityCursor.value("stamp_statechange").toLongLong());
+
+ list.append(status);
}
+ ds << list;
writeEndOfFrame();
}
else if (subCommand == "WORKSPACES") {
clearFrameTail();
ds << TQString("OK");
- writeEndOfFrame();
+ WorkspaceServiceStatusList list;
TQSqlCursor databaseActivityCursor("activity", TRUE, m_workspaces_database);
databaseActivityCursor.select();
while (databaseActivityCursor.next()) {
- TQ_UINT32 protocolVersion = 1;
- TQDateTime loginStamp;
- loginStamp.setTime_t(databaseActivityCursor.value("logontime").toInt());
-
- ds << protocolVersion;
- ds << databaseActivityCursor.value("pk").toInt();
- ds << databaseActivityCursor.value("station").toInt();
- ds << databaseActivityCursor.value("username").toString();
- ds << databaseActivityCursor.value("realmname").toString();
- ds << databaseActivityCursor.value("serverid").toInt();
- ds << loginStamp;
+ WorkspaceServiceStatusType status;
+
+ status.protocolVersion = 1;
+ status.sessionID = databaseActivityCursor.value("pk").toInt();
+ status.stationID = databaseActivityCursor.value("station").toInt();
+ status.username = databaseActivityCursor.value("username").toString();
+ status.realmname = databaseActivityCursor.value("realmname").toString();
+ status.serverID = databaseActivityCursor.value("serverid").toInt();
+ status.serviceID = databaseActivityCursor.value("serviceid").toInt();
+ status.stationID = databaseActivityCursor.value("station").toInt();
+ TQSqlCursor databaseStationsCursor("stations", TRUE, m_workspaces_database);
+ databaseStationsCursor.select(TQString("pk=%1").arg(status.stationID));
+ if (databaseStationsCursor.next()) {
+ status.stationName = databaseStationsCursor.value("name").toString();
+ }
+ status.loginStamp.setTime_t(databaseActivityCursor.value("logontime").toLongLong());
+ status.terminateStamp.setTime_t(databaseActivityCursor.value("terminate").toLongLong());
+
+ list.append(status);
}
+ ds << list;
writeEndOfFrame();
}
else {
@@ -281,19 +289,40 @@ void SysCtlSocket::commandLoop() {
writeEndOfFrame();
}
else if (subCommand == "KILL_WORKSPACE") {
+ TQ_INT32 terminationOffset;
+ ds >> terminationOffset;
clearFrameTail();
+ TQDateTime terminationTime = TQDateTime::currentDateTime();
+ terminationTime = terminationTime.addSecs(terminationOffset*60);
TQSqlCursor databaseActivityCursor("activity", TRUE, m_workspaces_database);
databaseActivityCursor.select(TQString("pk=%1").arg(sessionID));
if (databaseActivityCursor.next()) {
- databaseActivityCursor.select(TQString("pk=%1").arg(sessionID));
- if (databaseActivityCursor.next()) {
- TQSqlRecord *buffer = databaseActivityCursor.primeUpdate();
- buffer->setValue("terminate", true);
- databaseActivityCursor.update();
+ TQSqlRecord *buffer = databaseActivityCursor.primeUpdate();
+ if (terminationOffset > -2) {
+ buffer->setValue("terminate", terminationTime.toTime_t());
+ }
+ else {
+ buffer->setValue("terminate", 0);
}
+ databaseActivityCursor.update();
+
+ ds << TQString("OK");
+ }
+ else {
+ ds << TQString("ERRINVCMD");
+ }
+ writeEndOfFrame();
+ }
+ else if (subCommand == "CANCEL_KILL_WORKSPACE") {
+ clearFrameTail();
+ TQSqlCursor databaseActivityCursor("activity", TRUE, m_workspaces_database);
+ databaseActivityCursor.select(TQString("pk=%1").arg(sessionID));
+ if (databaseActivityCursor.next()) {
+ TQSqlRecord *buffer = databaseActivityCursor.primeUpdate();
+ buffer->setValue("terminate", 0);
+ databaseActivityCursor.update();
ds << TQString("OK");
- writeEndOfFrame();
}
else {
ds << TQString("ERRINVCMD");
diff --git a/servers/admin_sys_ctl_server_lin/src/main.cpp b/servers/admin_sys_ctl_server_lin/src/main.cpp
index 5d793eb..aa2a661 100644
--- a/servers/admin_sys_ctl_server_lin/src/main.cpp
+++ b/servers/admin_sys_ctl_server_lin/src/main.cpp
@@ -56,7 +56,7 @@ int main(int argc, char *argv[])
KStartupInfo::appStarted();
- KSimpleConfig config(TQDir::currentDirPath() + "/remotefpga_adminsysctlserver.conf", false);
+ KSimpleConfig config("remotefpga_adminsysctlserver.conf", false);
config.setGroup("Server");
SysCtlServer fpgasvr(0, config.readNumEntry("port", 4015), &config);
return app.exec();