From cce239c1d535e047d412ec2ad5ed28ff30d5c955 Mon Sep 17 00:00:00 2001 From: Dan Engelbrecht Date: Wed, 7 Dec 2022 11:36:54 +0100 Subject: Zen cmd fixes (#201) * updated drop command to support namespaces * fixed hash command error message * fix output of status (and top) command * Use ZEN_CONSOLE for output in zen commands * changelog --- zen/cmds/cache.cpp | 23 ++++++++++++++++++----- 1 file changed, 18 insertions(+), 5 deletions(-) (limited to 'zen/cmds/cache.cpp') diff --git a/zen/cmds/cache.cpp b/zen/cmds/cache.cpp index f1b953af5..a4fe4da34 100644 --- a/zen/cmds/cache.cpp +++ b/zen/cmds/cache.cpp @@ -16,8 +16,8 @@ ZEN_THIRD_PARTY_INCLUDES_END DropCommand::DropCommand() { m_Options.add_options()("h,help", "Print help"); + m_Options.add_option("", "n", "namespace", "Namnspace name", cxxopts::value(m_NamespaceName), ""); m_Options.add_option("", "b", "bucket", "Bucket name", cxxopts::value(m_BucketName), ""); - m_Options.add_option("", "", "positional", "Positional arguments", cxxopts::value(m_Positional), ""); } DropCommand::~DropCommand() = default; @@ -27,18 +27,31 @@ DropCommand::Run(const ZenCliOptions& GlobalOptions, int argc, char** argv) { ZEN_UNUSED(GlobalOptions, argc, argv); - m_Options.parse_positional({"bucket", "positional"}); + m_Options.parse_positional({"namespace", "bucket"}); m_Options.parse(argc, argv); - ZEN_INFO("Dropping cache bucket '{}' from '{}'", m_BucketName, m_HostName); + if (m_NamespaceName.empty()) + { + throw cxxopts::OptionParseException("Drop command requires a namespace"); + } cpr::Session Session; - Session.SetUrl({fmt::format("{}/z$/{}", m_HostName, m_BucketName)}); + if (m_BucketName.empty()) + { + ZEN_CONSOLE("Dropping cache namespace '{}' from '{}'", m_NamespaceName, m_HostName); + Session.SetUrl({fmt::format("{}/z$/{}", m_HostName, m_NamespaceName)}); + } + else + { + ZEN_CONSOLE("Dropping cache bucket '{}/{}' from '{}'", m_NamespaceName, m_BucketName, m_HostName); + Session.SetUrl({fmt::format("{}/z$/{}/{}", m_HostName, m_NamespaceName, m_BucketName)}); + } + cpr::Response Result = Session.Delete(); if (zen::IsHttpSuccessCode(Result.status_code)) { - ZEN_INFO("OK: dropped cache bucket '{}' from '{}'", m_BucketName, m_HostName); + ZEN_CONSOLE("OK: drop succeeded"); return 0; } -- cgit v1.2.3