Knightly 7ab909ee47 Standardize Licensing
- License was intended to be GPLv3 per earlier commit of GPLv3 LICENSE FILE
- This is confirmed by the inclusion of libraries that are incompatible with GPLv2
- This is also confirmed by KLS and the agreement of KLS's predecessors
- Added GPLv3 license headers to the compilable source files
- Removed Folly licensing in strings.h since the string functions do not match the Folly functions and are standard functions - this must have been left over from previous implementations
- Removed individual contributor license headers since the project has been under the "developer" mantle for many years
- Removed comments on files that were previously automatically generated since they've been manually modified multiple times and there are no automatic scripts referencing them (removed in 2023)
2026-04-01 17:09:57 -07:00

103 lines
2.6 KiB
C++
Executable File

/* EQEmu: EQEmulator
Copyright (C) 2001-2026 EQEmu Development Team
This program 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 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "zone/client.h"
void command_mysql(Client *c, const Seperator *sep)
{
int arguments = sep->argnum;
if (!arguments) {
c->Message(Chat::White, "Usage: #mysql [Help|Query] [SQL Query]");
return;
}
bool is_help = !strcasecmp(sep->arg[1], "help");
bool is_query = !strcasecmp(sep->arg[1], "query");
if (
!is_help &&
!is_query
) {
c->Message(Chat::White, "Usage: #mysql [Help|Query] [SQL Query]");
return;
}
if (is_help) {
c->Message(Chat::White, "Usage: #mysql query \"Query goes here quoted\"");
c->Message(Chat::White, "Note: To use 'LIKE \"%%something%%\" replace the %% with a #");
c->Message(Chat::White, "Example: #mysql query \"SELECT * FROM items WHERE `name` LIKE \"#Apple#\"");
return;
} else if (is_query) {
if (arguments < 2) {
c->Message(Chat::White, "Usage: #mysql query \"Query goes here quoted\"");
c->Message(Chat::White, "Note: To use 'LIKE \"%%something%%\" replace the %% with a #");
c->Message(Chat::White, "Example: #mysql query \"SELECT * FROM items WHERE `name` LIKE \"#Apple#\"");
return;
}
std::string query = sep->arg[2];
Strings::FindReplace(query, "#", "%");
auto results = database.QueryDatabase(query);
if (!results.Success()) {
return;
}
query = sep->arg[2];
Strings::FindReplace(query, "#", "%%");
c->Message(
Chat::White,
fmt::format(
"Running Query: '{}'",
query
).c_str()
);
std::vector<std::string> lines;
for (auto row : results) {
for (
int row_index = 0;
row_index < results.ColumnCount();
row_index++
) {
lines.emplace_back(
fmt::format(
"{} | {} ",
results.FieldName(row_index),
(
row[row_index] ?
(
strlen(row[row_index]) ?
row[row_index] :
"Empty String"
) :
"NULL"
)
)
);
}
}
for (auto line : lines) {
c->Message(
Chat::White,
line.c_str()
);
}
}
}