* implement max lengths for input dialogs that are sent to the server * missed a double setMaxLength * implement max string lengths server side * add custom getText dialog with max length * fix deck storage tab and miscellaneous server side * add max size for deck uploads * final pass on client side limits
350 lines
13 KiB
C++
350 lines
13 KiB
C++
#include "tab_logs.h"
|
|
|
|
#include "abstractclient.h"
|
|
#include "customlineedit.h"
|
|
#include "dlg_manage_sets.h"
|
|
#include "pb/moderator_commands.pb.h"
|
|
#include "pb/response_viewlog_history.pb.h"
|
|
#include "pending_command.h"
|
|
#include "stringsizes.h"
|
|
|
|
#include <QCheckBox>
|
|
#include <QDialogButtonBox>
|
|
#include <QGroupBox>
|
|
#include <QHBoxLayout>
|
|
#include <QLabel>
|
|
#include <QMessageBox>
|
|
#include <QPushButton>
|
|
#include <QRadioButton>
|
|
#include <QSpinBox>
|
|
#include <QTabWidget>
|
|
#include <QtGui>
|
|
#include <QtWidgets>
|
|
|
|
TabLog::TabLog(TabSupervisor *_tabSupervisor, AbstractClient *_client, QWidget *parent)
|
|
: Tab(_tabSupervisor, parent), client(_client)
|
|
{
|
|
roomTable = new QTableWidget();
|
|
roomTable->setColumnCount(6);
|
|
roomTable->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
|
|
roomTable->setHorizontalHeaderLabels(
|
|
QString(tr("Time;SenderName;SenderIP;Message;TargetID;TargetName")).split(";"));
|
|
|
|
gameTable = new QTableWidget();
|
|
gameTable->setColumnCount(6);
|
|
gameTable->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
|
|
gameTable->setHorizontalHeaderLabels(
|
|
QString(tr("Time;SenderName;SenderIP;Message;TargetID;TargetName")).split(";"));
|
|
|
|
chatTable = new QTableWidget();
|
|
chatTable->setColumnCount(6);
|
|
chatTable->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
|
|
chatTable->setHorizontalHeaderLabels(
|
|
QString(tr("Time;SenderName;SenderIP;Message;TargetID;TargetName")).split(";"));
|
|
|
|
QTabWidget *tabManager = new QTabWidget();
|
|
tabManager->addTab(roomTable, tr("Room Logs"));
|
|
tabManager->addTab(gameTable, tr("Game Logs"));
|
|
tabManager->addTab(chatTable, tr("Chat Logs"));
|
|
setCentralWidget(tabManager);
|
|
|
|
createDock();
|
|
restartLayout();
|
|
clearClicked();
|
|
retranslateUi();
|
|
}
|
|
|
|
TabLog::~TabLog()
|
|
{
|
|
}
|
|
|
|
void TabLog::retranslateUi()
|
|
{
|
|
}
|
|
|
|
void TabLog::getClicked()
|
|
{
|
|
if (findUsername->text().isEmpty() && findIPAddress->text().isEmpty() && findGameName->text().isEmpty() &&
|
|
findGameID->text().isEmpty() && findMessage->text().isEmpty()) {
|
|
QMessageBox::critical(this, tr("Error"), tr("You must select at least one filter."));
|
|
return;
|
|
}
|
|
|
|
if (!lastHour->isChecked() && !today->isChecked() && !pastDays->isChecked()) {
|
|
pastDays->setChecked(true);
|
|
pastXDays->setValue(20);
|
|
}
|
|
|
|
if (pastDays->isChecked() && pastXDays->value() == 0) {
|
|
QMessageBox::critical(this, tr("Error"), tr("You have to select a valid number of days to locate."));
|
|
return;
|
|
}
|
|
|
|
if (!mainRoom->isChecked() && !gameRoom->isChecked() && !privateChat->isChecked()) {
|
|
mainRoom->setChecked(true);
|
|
gameRoom->setChecked(true);
|
|
privateChat->setChecked(true);
|
|
}
|
|
|
|
if (maximumResults->value() == 0)
|
|
maximumResults->setValue(1000);
|
|
|
|
int dateRange;
|
|
if (lastHour->isChecked())
|
|
dateRange = 1;
|
|
|
|
if (today->isChecked())
|
|
dateRange = 24;
|
|
|
|
if (pastDays->isChecked())
|
|
dateRange = pastXDays->value() * 24;
|
|
|
|
Command_ViewLogHistory cmd;
|
|
cmd.set_user_name(findUsername->text().toStdString());
|
|
cmd.set_ip_address(findIPAddress->text().toStdString());
|
|
cmd.set_game_name(findGameName->text().toStdString());
|
|
cmd.set_game_id(findGameID->text().toStdString());
|
|
cmd.set_message(findMessage->text().toStdString());
|
|
if (mainRoom->isChecked()) {
|
|
cmd.add_log_location("room");
|
|
};
|
|
if (gameRoom->isChecked()) {
|
|
cmd.add_log_location("game");
|
|
};
|
|
if (privateChat->isChecked()) {
|
|
cmd.add_log_location("chat");
|
|
};
|
|
cmd.set_date_range(dateRange);
|
|
cmd.set_maximum_results(maximumResults->value());
|
|
PendingCommand *pend = client->prepareModeratorCommand(cmd);
|
|
connect(pend, SIGNAL(finished(Response, CommandContainer, QVariant)), this,
|
|
SLOT(viewLogHistory_processResponse(Response)));
|
|
client->sendCommand(pend);
|
|
}
|
|
|
|
void TabLog::clearClicked()
|
|
{
|
|
findUsername->clear();
|
|
findIPAddress->clear();
|
|
findGameName->clear();
|
|
findGameID->clear();
|
|
findMessage->clear();
|
|
pastXDays->clear();
|
|
maximumResults->clear();
|
|
mainRoom->setChecked(false);
|
|
gameRoom->setChecked(false);
|
|
privateChat->setChecked(false);
|
|
pastDays->setAutoExclusive(false);
|
|
pastDays->setChecked(false);
|
|
today->setAutoExclusive(false);
|
|
today->setChecked(false);
|
|
lastHour->setAutoExclusive(false);
|
|
lastHour->setChecked(false);
|
|
pastDays->setAutoExclusive(true);
|
|
today->setAutoExclusive(true);
|
|
lastHour->setAutoExclusive(true);
|
|
}
|
|
|
|
void TabLog::createDock()
|
|
{
|
|
labelFindUserName = new QLabel(tr("Username: "));
|
|
findUsername = new LineEditUnfocusable("");
|
|
findUsername->setMaxLength(MAX_NAME_LENGTH);
|
|
findUsername->setAlignment(Qt::AlignCenter);
|
|
labelFindIPAddress = new QLabel(tr("IP Address: "));
|
|
findIPAddress = new LineEditUnfocusable("");
|
|
findIPAddress->setMaxLength(MAX_NAME_LENGTH);
|
|
findIPAddress->setAlignment(Qt::AlignCenter);
|
|
labelFindGameName = new QLabel(tr("Game Name: "));
|
|
findGameName = new LineEditUnfocusable("");
|
|
findGameName->setMaxLength(MAX_NAME_LENGTH);
|
|
findGameName->setAlignment(Qt::AlignCenter);
|
|
labelFindGameID = new QLabel(tr("GameID: "));
|
|
findGameID = new LineEditUnfocusable("");
|
|
findGameID->setMaxLength(MAX_NAME_LENGTH);
|
|
findGameID->setAlignment(Qt::AlignCenter);
|
|
labelMessage = new QLabel(tr("Message: "));
|
|
findMessage = new LineEditUnfocusable("");
|
|
findMessage->setMaxLength(MAX_TEXT_LENGTH);
|
|
findMessage->setAlignment(Qt::AlignCenter);
|
|
|
|
mainRoom = new QCheckBox(tr("Main Room"));
|
|
gameRoom = new QCheckBox(tr("Game Room"));
|
|
privateChat = new QCheckBox(tr("Private Chat"));
|
|
|
|
pastDays = new QRadioButton(tr("Past X Days: "));
|
|
today = new QRadioButton(tr("Today"));
|
|
lastHour = new QRadioButton(tr("Last Hour"));
|
|
pastXDays = new QSpinBox;
|
|
pastXDays->setMaximum(20);
|
|
|
|
labelMaximum = new QLabel(tr("Maximum Results: "));
|
|
maximumResults = new QSpinBox;
|
|
maximumResults->setMaximum(1000);
|
|
|
|
labelDescription = new QLabel(tr(
|
|
"At least one filter is required.\nThe more information you put in, the more specific your results will be."));
|
|
|
|
getButton = new QPushButton(tr("Get User Logs"));
|
|
getButton->setAutoDefault(true);
|
|
connect(getButton, SIGNAL(clicked()), this, SLOT(getClicked()));
|
|
|
|
clearButton = new QPushButton(tr("Clear Filters"));
|
|
clearButton->setAutoDefault(true);
|
|
connect(clearButton, SIGNAL(clicked()), this, SLOT(clearClicked()));
|
|
|
|
criteriaGrid = new QGridLayout;
|
|
criteriaGrid->addWidget(labelFindUserName, 0, 0);
|
|
criteriaGrid->addWidget(findUsername, 0, 1);
|
|
criteriaGrid->addWidget(labelFindIPAddress, 1, 0);
|
|
criteriaGrid->addWidget(findIPAddress, 1, 1);
|
|
criteriaGrid->addWidget(labelFindGameName, 2, 0);
|
|
criteriaGrid->addWidget(findGameName, 2, 1);
|
|
criteriaGrid->addWidget(labelFindGameID, 3, 0);
|
|
criteriaGrid->addWidget(findGameID, 3, 1);
|
|
criteriaGrid->addWidget(labelMessage, 4, 0);
|
|
criteriaGrid->addWidget(findMessage, 4, 1);
|
|
|
|
criteriaGroupBox = new QGroupBox(tr("Filters"));
|
|
criteriaGroupBox->setLayout(criteriaGrid);
|
|
criteriaGroupBox->setMaximumSize(500, 300);
|
|
criteriaGroupBox->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
|
|
|
|
locationGrid = new QGridLayout;
|
|
locationGrid->addWidget(mainRoom, 0, 0);
|
|
locationGrid->addWidget(gameRoom, 0, 1);
|
|
locationGrid->addWidget(privateChat, 0, 2);
|
|
|
|
locationGroupBox = new QGroupBox(tr("Log Locations"));
|
|
locationGroupBox->setLayout(locationGrid);
|
|
|
|
rangeGrid = new QGridLayout;
|
|
rangeGrid->addWidget(pastDays, 0, 0);
|
|
rangeGrid->addWidget(pastXDays, 0, 1);
|
|
rangeGrid->addWidget(today, 0, 2);
|
|
rangeGrid->addWidget(lastHour, 0, 3);
|
|
|
|
rangeGroupBox = new QGroupBox(tr("Date Range"));
|
|
rangeGroupBox->setLayout(rangeGrid);
|
|
|
|
maxResultsGrid = new QGridLayout;
|
|
maxResultsGrid->addWidget(labelMaximum, 0, 0);
|
|
maxResultsGrid->addWidget(maximumResults, 0, 1);
|
|
|
|
maxResultsGroupBox = new QGroupBox(tr("Maximum Results"));
|
|
maxResultsGroupBox->setLayout(maxResultsGrid);
|
|
|
|
descriptionGrid = new QGridLayout;
|
|
descriptionGrid->addWidget(labelDescription, 0, 0);
|
|
|
|
descriptionGroupBox = new QGroupBox(tr(""));
|
|
descriptionGroupBox->setLayout(descriptionGrid);
|
|
|
|
buttonGrid = new QGridLayout;
|
|
buttonGrid->addWidget(getButton, 0, 0);
|
|
buttonGrid->addWidget(clearButton, 0, 1);
|
|
|
|
buttonGroupBox = new QGroupBox(tr(""));
|
|
buttonGroupBox->setLayout(buttonGrid);
|
|
|
|
mainLayout = new QVBoxLayout(this);
|
|
mainLayout->addWidget(criteriaGroupBox);
|
|
mainLayout->addWidget(locationGroupBox);
|
|
mainLayout->addWidget(rangeGroupBox);
|
|
mainLayout->addWidget(maxResultsGroupBox);
|
|
mainLayout->addWidget(descriptionGroupBox);
|
|
mainLayout->addWidget(buttonGroupBox);
|
|
mainLayout->setAlignment(Qt::AlignCenter);
|
|
|
|
searchDockContents = new QWidget(this);
|
|
searchDockContents->setLayout(mainLayout);
|
|
|
|
searchDock = new QDockWidget(this);
|
|
searchDock->setFeatures(QDockWidget::DockWidgetFloatable | QDockWidget::DockWidgetMovable);
|
|
searchDock->setWidget(searchDockContents);
|
|
}
|
|
|
|
void TabLog::viewLogHistory_processResponse(const Response &resp)
|
|
{
|
|
const Response_ViewLogHistory &response = resp.GetExtension(Response_ViewLogHistory::ext);
|
|
if (resp.response_code() != Response::RespOk) {
|
|
QMessageBox::critical(static_cast<QWidget *>(parent()), tr("Message History"),
|
|
tr("Failed to collect message history information."));
|
|
return;
|
|
}
|
|
|
|
if (response.log_message_size() == 0) {
|
|
QMessageBox::information(static_cast<QWidget *>(parent()), tr("Message History"),
|
|
tr("There are no messages for the selected filters."));
|
|
return;
|
|
}
|
|
|
|
int roomCounter = 0, gameCounter = 0, chatCounter = 0;
|
|
roomTable->setRowCount(roomCounter);
|
|
gameTable->setRowCount(gameCounter);
|
|
chatTable->setRowCount(chatCounter);
|
|
|
|
for (int i = 0; i < response.log_message_size(); ++i) {
|
|
ServerInfo_ChatMessage message = response.log_message(i);
|
|
if (QString::fromStdString(message.target_type()) == "room") {
|
|
roomTable->insertRow(roomCounter);
|
|
roomTable->setItem(roomCounter, 0, new QTableWidgetItem(QString::fromStdString(message.time())));
|
|
roomTable->setItem(roomCounter, 1, new QTableWidgetItem(QString::fromStdString(message.sender_name())));
|
|
roomTable->setItem(roomCounter, 2, new QTableWidgetItem(QString::fromStdString(message.sender_ip())));
|
|
roomTable->setItem(roomCounter, 3, new QTableWidgetItem(QString::fromStdString(message.message())));
|
|
roomTable->setItem(roomCounter, 4, new QTableWidgetItem(QString::fromStdString(message.target_id())));
|
|
roomTable->setItem(roomCounter, 5, new QTableWidgetItem(QString::fromStdString(message.target_name())));
|
|
++roomCounter;
|
|
}
|
|
|
|
if (QString::fromStdString(message.target_type()) == "game") {
|
|
gameTable->insertRow(gameCounter);
|
|
gameTable->setItem(gameCounter, 0, new QTableWidgetItem(QString::fromStdString(message.time())));
|
|
gameTable->setItem(gameCounter, 1, new QTableWidgetItem(QString::fromStdString(message.sender_name())));
|
|
gameTable->setItem(gameCounter, 2, new QTableWidgetItem(QString::fromStdString(message.sender_ip())));
|
|
gameTable->setItem(gameCounter, 3, new QTableWidgetItem(QString::fromStdString(message.message())));
|
|
gameTable->setItem(gameCounter, 4, new QTableWidgetItem(QString::fromStdString(message.target_id())));
|
|
gameTable->setItem(gameCounter, 5, new QTableWidgetItem(QString::fromStdString(message.target_name())));
|
|
++gameCounter;
|
|
}
|
|
|
|
if (QString::fromStdString(message.target_type()) == "chat") {
|
|
chatTable->insertRow(chatCounter);
|
|
chatTable->setItem(chatCounter, 0, new QTableWidgetItem(QString::fromStdString(message.time())));
|
|
chatTable->setItem(chatCounter, 1, new QTableWidgetItem(QString::fromStdString(message.sender_name())));
|
|
chatTable->setItem(chatCounter, 2, new QTableWidgetItem(QString::fromStdString(message.sender_ip())));
|
|
chatTable->setItem(chatCounter, 3, new QTableWidgetItem(QString::fromStdString(message.message())));
|
|
chatTable->setItem(chatCounter, 4, new QTableWidgetItem(QString::fromStdString(message.target_id())));
|
|
chatTable->setItem(chatCounter, 5, new QTableWidgetItem(QString::fromStdString(message.target_name())));
|
|
++chatCounter;
|
|
}
|
|
}
|
|
|
|
if (roomCounter) {
|
|
roomTable->show();
|
|
roomTable->resizeColumnsToContents();
|
|
} else {
|
|
roomTable->hide();
|
|
}
|
|
|
|
if (gameCounter) {
|
|
gameTable->resizeColumnsToContents();
|
|
gameTable->show();
|
|
} else {
|
|
gameTable->hide();
|
|
}
|
|
|
|
if (chatCounter) {
|
|
chatTable->resizeColumnsToContents();
|
|
chatTable->show();
|
|
} else {
|
|
chatTable->hide();
|
|
}
|
|
}
|
|
|
|
void TabLog::restartLayout()
|
|
{
|
|
searchDock->setFloating(false);
|
|
addDockWidget(Qt::LeftDockWidgetArea, searchDock);
|
|
searchDock->setVisible(true);
|
|
}
|