2020-03-03 17:38:50 +08:00
|
|
|
#include <gflags/gflags.h>
|
|
|
|
|
|
|
|
#include "communication/bolt/client.hpp"
|
|
|
|
#include "io/network/endpoint.hpp"
|
|
|
|
#include "io/network/utils.hpp"
|
2021-01-21 22:47:56 +08:00
|
|
|
#include "utils/logging.hpp"
|
2020-03-03 17:38:50 +08:00
|
|
|
|
|
|
|
DEFINE_string(address, "127.0.0.1", "Server address");
|
|
|
|
DEFINE_int32(port, 7687, "Server port");
|
|
|
|
DEFINE_string(username, "", "Username for the database");
|
|
|
|
DEFINE_string(password, "", "Password for the database");
|
|
|
|
DEFINE_bool(use_ssl, false, "Set to true to connect with SSL to the server.");
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Executes "DUMP DATABASE" and outputs all results to stdout. On any errors it
|
|
|
|
* exits with a non-zero exit code.
|
|
|
|
*/
|
|
|
|
// NOLINTNEXTLINE(bugprone-exception-escape)
|
|
|
|
int main(int argc, char **argv) {
|
|
|
|
gflags::ParseCommandLineFlags(&argc, &argv, true);
|
2021-01-21 22:47:56 +08:00
|
|
|
logging::RedirectToStderr();
|
2020-03-03 17:38:50 +08:00
|
|
|
|
2020-10-20 18:55:13 +08:00
|
|
|
communication::SSLInit sslInit;
|
2020-03-03 17:38:50 +08:00
|
|
|
|
|
|
|
io::network::Endpoint endpoint(io::network::ResolveHostname(FLAGS_address),
|
|
|
|
FLAGS_port);
|
|
|
|
|
|
|
|
communication::ClientContext context(FLAGS_use_ssl);
|
|
|
|
communication::bolt::Client client(&context);
|
|
|
|
|
|
|
|
client.Connect(endpoint, FLAGS_username, FLAGS_password);
|
|
|
|
auto ret = client.Execute("DUMP DATABASE", {});
|
|
|
|
for (const auto &row : ret.records) {
|
2021-01-21 22:47:56 +08:00
|
|
|
MG_ASSERT(row.size() == 1,
|
|
|
|
"Too much entries in query dump row (got {}, expected 1)!",
|
|
|
|
row.size());
|
2020-03-03 17:38:50 +08:00
|
|
|
std::cout << row[0].ValueString() << std::endl;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|