X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/8c6fa3fbaccc22127280bf77a48fab5a3ee0716e..46b0747592074017ff0ea4b33d4a7194235886e5:/projects/sgconf/services.cpp diff --git a/projects/sgconf/services.cpp b/projects/sgconf/services.cpp deleted file mode 100644 index e2bf9bf6..00000000 --- a/projects/sgconf/services.cpp +++ /dev/null @@ -1,170 +0,0 @@ -#include "services.h" - -#include "api_action.h" -#include "options.h" -#include "config.h" -#include "utils.h" - -#include "stg/servconf.h" -#include "stg/servconf_types.h" -#include "stg/service_conf.h" -#include "stg/common.h" - -#include -#include -#include - -namespace -{ - -std::string Indent(size_t level, bool dash = false) -{ -if (level == 0) - return ""; -return dash ? std::string(level * 4 - 2, ' ') + "- " : std::string(level * 4, ' '); -} - -void PrintService(const STG::GET_SERVICE::INFO & info, size_t level = 0) -{ -std::cout << Indent(level, true) << "name: " << info.name << "\n" - << Indent(level) << "cost: " << info.cost << "\n" - << Indent(level) << "payment day: " << static_cast(info.payDay) << "\n" - << Indent(level) << "comment: " << info.comment << "\n"; -} - -std::vector GetServiceParams() -{ -std::vector params; -params.push_back(SGCONF::API_ACTION::PARAM("cost", "", "\tcost of the service")); -params.push_back(SGCONF::API_ACTION::PARAM("pay-day", "", "payment day")); -params.push_back(SGCONF::API_ACTION::PARAM("comment", "", "comment")); -return params; -} - -void SimpleCallback(bool result, - const std::string & reason, - void * /*data*/) -{ -if (!result) - { - std::cerr << "Operation failed. Reason: '" << reason << "'." << std::endl; - return; - } -std::cout << "Success.\n"; -} - -void GetServicesCallback(bool result, - const std::string & reason, - const std::vector & info, - void * /*data*/) -{ -if (!result) - { - std::cerr << "Failed to get service list. Reason: '" << reason << "'." << std::endl; - return; - } -std::cout << "Services:\n"; -for (size_t i = 0; i < info.size(); ++i) - PrintService(info[i], 1); -} - -void GetServiceCallback(bool result, - const std::string & reason, - const STG::GET_SERVICE::INFO & info, - void * /*data*/) -{ -if (!result) - { - std::cerr << "Failed to get service. Reason: '" << reason << "'." << std::endl; - return; - } -PrintService(info); -} - -bool GetServicesFunction(const SGCONF::CONFIG & config, - const std::string & /*arg*/, - const std::map & /*options*/) -{ -STG::SERVCONF proto(config.server.data(), - config.port.data(), - config.localAddress.data(), - config.localPort.data(), - config.userName.data(), - config.userPass.data()); -return proto.GetServices(GetServicesCallback, NULL) == STG::st_ok; -} - -bool GetServiceFunction(const SGCONF::CONFIG & config, - const std::string & arg, - const std::map & /*options*/) -{ -STG::SERVCONF proto(config.server.data(), - config.port.data(), - config.localAddress.data(), - config.localPort.data(), - config.userName.data(), - config.userPass.data()); -return proto.GetService(arg, GetServiceCallback, NULL) == STG::st_ok; -} - -bool DelServiceFunction(const SGCONF::CONFIG & config, - const std::string & arg, - const std::map & /*options*/) -{ -STG::SERVCONF proto(config.server.data(), - config.port.data(), - config.localAddress.data(), - config.localPort.data(), - config.userName.data(), - config.userPass.data()); -return proto.DelService(arg, SimpleCallback, NULL) == STG::st_ok; -} - -bool AddServiceFunction(const SGCONF::CONFIG & config, - const std::string & arg, - const std::map & options) -{ -SERVICE_CONF_RES conf; -conf.name = arg; -SGCONF::MaybeSet(options, "cost", conf.cost); -SGCONF::MaybeSet(options, "pay-day", conf.payDay); -SGCONF::MaybeSet(options, "comment", conf.comment); -STG::SERVCONF proto(config.server.data(), - config.port.data(), - config.localAddress.data(), - config.localPort.data(), - config.userName.data(), - config.userPass.data()); -return proto.AddService(arg, conf, SimpleCallback, NULL) == STG::st_ok; -} - -bool ChgServiceFunction(const SGCONF::CONFIG & config, - const std::string & arg, - const std::map & options) -{ -SERVICE_CONF_RES conf; -conf.name = arg; -SGCONF::MaybeSet(options, "cost", conf.cost); -SGCONF::MaybeSet(options, "pay-day", conf.payDay); -SGCONF::MaybeSet(options, "comment", conf.comment); -STG::SERVCONF proto(config.server.data(), - config.port.data(), - config.localAddress.data(), - config.localPort.data(), - config.userName.data(), - config.userPass.data()); -return proto.ChgService(conf, SimpleCallback, NULL) == STG::st_ok; -} - -} // namespace anonymous - -void SGCONF::AppendServicesOptionBlock(COMMANDS & commands, OPTION_BLOCKS & blocks) -{ -std::vector params(GetServiceParams()); -blocks.Add("Service management options") - .Add("get-services", SGCONF::MakeAPIAction(commands, GetServicesFunction), "\tget service list") - .Add("get-service", SGCONF::MakeAPIAction(commands, "", GetServiceFunction), "get service") - .Add("add-service", SGCONF::MakeAPIAction(commands, "", params, AddServiceFunction), "add service") - .Add("del-service", SGCONF::MakeAPIAction(commands, "", DelServiceFunction), "delete service") - .Add("chg-service", SGCONF::MakeAPIAction(commands, "", params, ChgServiceFunction), "change service"); -}