annotate irccdctl/cli.cpp @ 752:252506d9839b

Irccdctl: merge all cli in cli.cpp|hpp
author David Demelier <markand@malikania.fr>
date Sun, 05 Aug 2018 11:47:00 +0200
parents ad1ee47165fa
children c216d148558d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
344
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
1 /*
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
2 * cli.cpp -- command line for irccdctl
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
3 *
628
27587ff92a64 Misc: update copyrights
David Demelier <markand@malikania.fr>
parents: 569
diff changeset
4 * Copyright (c) 2013-2018 David Demelier <markand@malikania.fr>
344
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
5 *
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
6 * Permission to use, copy, modify, and/or distribute this software for any
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
7 * purpose with or without fee is hereby granted, provided that the above
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
8 * copyright notice and this permission notice appear in all copies.
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
9 *
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
17 */
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
18
752
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
19 #include <iostream>
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
20
527
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
21 #include <irccd/json_util.hpp>
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
22 #include <irccd/options.hpp>
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
23 #include <irccd/string_util.hpp>
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
24
527
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
25 #include <irccd/ctl/controller.hpp>
344
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
26
752
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
27 #include <irccd/daemon/service/rule_service.hpp>
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
28
344
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
29 #include "cli.hpp"
452
2170aa0e38aa Irccdctl: implement rule-add
David Demelier <markand@malikania.fr>
parents: 451
diff changeset
30
752
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
31 namespace irccd::ctl {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
32
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
33 // {{{ helpers
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
34
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
35 namespace {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
36
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
37 auto format(std::vector<std::string> args) -> std::string
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
38 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
39 auto result = option::read(args, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
40 { "-f", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
41 { "--format", true }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
42 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
43
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
44 if (result.count("-f") > 0)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
45 return result.find("-f")->second;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
46 if (result.count("--format") > 0)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
47 return result.find("--format")->second;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
48
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
49 return "native";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
50 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
51
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
52 void onConnect(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
53 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
54 std::cout << "event: onConnect\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
55 std::cout << "server: " << json_util::pretty(v.value("server", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
56 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
57
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
58 void onInvite(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
59 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
60 std::cout << "event: onInvite\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
61 std::cout << "server: " << json_util::pretty(v.value("server", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
62 std::cout << "origin: " << json_util::pretty(v.value("origin", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
63 std::cout << "channel: " << json_util::pretty(v.value("channel", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
64 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
65
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
66 void onJoin(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
67 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
68 std::cout << "event: onJoin\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
69 std::cout << "server: " << json_util::pretty(v.value("server", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
70 std::cout << "origin: " << json_util::pretty(v.value("origin", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
71 std::cout << "channel: " << json_util::pretty(v.value("channel", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
72 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
73
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
74 void onKick(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
75 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
76 std::cout << "event: onKick\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
77 std::cout << "server: " << json_util::pretty(v.value("server", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
78 std::cout << "origin: " << json_util::pretty(v.value("origin", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
79 std::cout << "channel: " << json_util::pretty(v.value("channel", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
80 std::cout << "target: " << json_util::pretty(v.value("target", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
81 std::cout << "reason: " << json_util::pretty(v.value("reason", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
82 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
83
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
84 void onMessage(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
85 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
86 std::cout << "event: onMessage\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
87 std::cout << "server: " << json_util::pretty(v.value("server", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
88 std::cout << "origin: " << json_util::pretty(v.value("origin", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
89 std::cout << "channel: " << json_util::pretty(v.value("channel", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
90 std::cout << "message: " << json_util::pretty(v.value("message", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
91 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
92
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
93 void onMe(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
94 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
95 std::cout << "event: onMe\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
96 std::cout << "server: " << json_util::pretty(v.value("server", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
97 std::cout << "origin: " << json_util::pretty(v.value("origin", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
98 std::cout << "target: " << json_util::pretty(v.value("target", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
99 std::cout << "message: " << json_util::pretty(v.value("message", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
100 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
101
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
102 void onMode(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
103 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
104 std::cout << "event: onMode\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
105 std::cout << "server: " << json_util::pretty(v.value("server", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
106 std::cout << "origin: " << json_util::pretty(v.value("origin", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
107 std::cout << "mode: " << json_util::pretty(v.value("mode", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
108 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
109
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
110 void onNames(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
111 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
112 std::cout << "event: onNames\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
113 std::cout << "server: " << json_util::pretty(v.value("server", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
114 std::cout << "channel: " << json_util::pretty(v.value("channel", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
115 std::cout << "names: " << json_util::pretty(v.value("names", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
116 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
117
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
118 void onNick(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
119 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
120 std::cout << "event: onNick\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
121 std::cout << "server: " << json_util::pretty(v.value("server", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
122 std::cout << "origin: " << json_util::pretty(v.value("origin", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
123 std::cout << "nickname: " << json_util::pretty(v.value("nickname", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
124 }
344
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
125
752
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
126 void onNotice(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
127 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
128 std::cout << "event: onNotice\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
129 std::cout << "server: " << json_util::pretty(v.value("server", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
130 std::cout << "origin: " << json_util::pretty(v.value("origin", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
131 std::cout << "message: " << json_util::pretty(v.value("message", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
132 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
133
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
134 void onPart(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
135 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
136 std::cout << "event: onPart\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
137 std::cout << "server: " << json_util::pretty(v.value("server", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
138 std::cout << "origin: " << json_util::pretty(v.value("origin", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
139 std::cout << "channel: " << json_util::pretty(v.value("channel", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
140 std::cout << "reason: " << json_util::pretty(v.value("reason", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
141 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
142
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
143 void onTopic(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
144 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
145 std::cout << "event: onTopic\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
146 std::cout << "server: " << json_util::pretty(v.value("server", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
147 std::cout << "origin: " << json_util::pretty(v.value("origin", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
148 std::cout << "channel: " << json_util::pretty(v.value("channel", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
149 std::cout << "topic: " << json_util::pretty(v.value("topic", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
150 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
151
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
152 void onWhois(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
153 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
154 std::cout << "event: onWhois\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
155 std::cout << "server: " << json_util::pretty(v.value("server", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
156 std::cout << "nickname: " << json_util::pretty(v.value("nickname", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
157 std::cout << "username: " << json_util::pretty(v.value("username", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
158 std::cout << "host: " << json_util::pretty(v.value("host", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
159 std::cout << "realname: " << json_util::pretty(v.value("realname", "(unknown)")) << "\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
160 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
161
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
162 const std::unordered_map<std::string_view, std::function<void (const nlohmann::json&)>> events{
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
163 { "onConnect", onConnect },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
164 { "onInvite", onInvite },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
165 { "onJoin", onJoin },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
166 { "onKick", onKick },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
167 { "onMessage", onMessage },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
168 { "onMe", onMe },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
169 { "onMode", onMode },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
170 { "onNames", onNames },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
171 { "onNick", onNick },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
172 { "onNotice", onNotice },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
173 { "onPart", onPart },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
174 { "onTopic", onTopic },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
175 { "onWhois", onWhois }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
176 };
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
177
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
178 void get_event(ctl::controller& ctl, std::string fmt)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
179 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
180 ctl.read([&ctl, fmt] (auto code, auto message) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
181 if (code)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
182 throw std::system_error(code);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
183
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
184 const auto event = json_util::document(message).get<std::string>("event");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
185 const auto it = events.find(event ? *event : "");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
186
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
187 if (it != events.end()) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
188 if (fmt == "json")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
189 std::cout << message.dump(4) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
190 else {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
191 it->second(message);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
192 std::cout << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
193 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
194 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
195
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
196 get_event(ctl, std::move(fmt));
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
197 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
198 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
199
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
200 auto parse(std::vector<std::string> &args) -> option::result
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
201 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
202 option::options options{
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
203 { "-c", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
204 { "--command", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
205 { "-n", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
206 { "--nickname", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
207 { "-r", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
208 { "--realname", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
209 { "-S", false },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
210 { "--ssl-verify", false },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
211 { "-s", false },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
212 { "--ssl", false },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
213 { "-u", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
214 { "--username", true }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
215 };
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
216
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
217 return option::read(args, options);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
218 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
219
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
220 } // !namespace
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
221
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
222 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
223
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
224 // {{{ cli
527
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
225
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
226 void cli::recv_response(ctl::controller& ctl, nlohmann::json req, handler_t handler)
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
227 {
670
95ac3ace1610 Common: introduce new io code
David Demelier <markand@malikania.fr>
parents: 649
diff changeset
228 ctl.read([&ctl, req, handler, this] (auto code, auto message) {
527
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
229 if (code)
670
95ac3ace1610 Common: introduce new io code
David Demelier <markand@malikania.fr>
parents: 649
diff changeset
230 throw std::system_error(code);
527
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
231
698
ad1ee47165fa Irccd: create own json_util::document class
David Demelier <markand@malikania.fr>
parents: 670
diff changeset
232 const auto c = json_util::document(message).get<std::string>("command");
527
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
233
641
7e2d0739f37c Irccd: import json_util from code
David Demelier <markand@malikania.fr>
parents: 628
diff changeset
234 if (!c) {
527
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
235 recv_response(ctl, std::move(req), std::move(handler));
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
236 return;
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
237 }
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
238
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
239 if (handler)
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
240 handler(std::move(message));
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
241 });
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
242 }
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
243
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
244 void cli::request(ctl::controller& ctl, nlohmann::json req, handler_t handler)
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
245 {
670
95ac3ace1610 Common: introduce new io code
David Demelier <markand@malikania.fr>
parents: 649
diff changeset
246 ctl.write(req, [&ctl, req, handler, this] (auto code) {
527
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
247 if (code)
670
95ac3ace1610 Common: introduce new io code
David Demelier <markand@malikania.fr>
parents: 649
diff changeset
248 throw std::system_error(code);
527
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
249
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
250 recv_response(ctl, std::move(req), std::move(handler));
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
251 });
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
252 }
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
253
752
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
254 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
255
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
256 // {{{ plugin_config_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
257
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
258 void plugin_config_cli::set(ctl::controller& ctl, const std::vector<std::string>&args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
259 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
260 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
261 { "command", "plugin-config" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
262 { "plugin", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
263 { "variable", args[1] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
264 { "value", args[2] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
265 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
266 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
267
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
268 void plugin_config_cli::get(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
269 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
270 auto json = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
271 { "command", "plugin-config" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
272 { "plugin", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
273 { "variable", args[1] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
274 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
275
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
276 request(ctl, std::move(json), [args] (auto result) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
277 if (result["variables"].is_object())
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
278 std::cout << json_util::pretty(result["variables"][args[1]]) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
279 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
280 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
281
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
282 void plugin_config_cli::getall(ctl::controller& ctl, const std::vector<std::string> &args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
283 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
284 const auto json = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
285 { "command", "plugin-config" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
286 { "plugin", args[0] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
287 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
288
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
289 request(ctl, json, [] (auto result) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
290 const auto variables = result["variables"];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
291
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
292 for (auto v = variables.begin(); v != variables.end(); ++v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
293 std::cout << std::setw(16) << std::left << v.key() << " : " << json_util::pretty(v.value()) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
294 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
295 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
296
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
297 auto plugin_config_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
298 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
299 return "plugin-config";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
300 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
301
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
302 void plugin_config_cli::exec(ctl::controller& ctl, const std::vector<std::string> &args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
303 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
304 switch (args.size()) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
305 case 3:
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
306 set(ctl, args);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
307 break;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
308 case 2:
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
309 get(ctl, args);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
310 break;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
311 case 1:
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
312 getall(ctl, args);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
313 break;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
314 default:
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
315 throw std::invalid_argument("plugin-config requires at least 1 argument");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
316 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
317 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
318
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
319 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
320
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
321 // {{{ plugin_info_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
322
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
323 auto plugin_info_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
324 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
325 return "plugin-info";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
326 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
327
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
328 void plugin_info_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
329 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
330 if (args.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
331 throw std::invalid_argument("plugin-info requires 1 argument");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
332
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
333 const auto json = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
334 { "command", "plugin-info" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
335 { "plugin", args[0] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
336 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
337
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
338 request(ctl, json, [] (auto result) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
339 const json_util::document doc(result);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
340
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
341 std::cout << std::boolalpha;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
342 std::cout << "Author : " <<
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
343 doc.get<std::string>("author").value_or("(unknown)") << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
344 std::cout << "License : " <<
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
345 doc.get<std::string>("license").value_or("(unknown)") << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
346 std::cout << "Summary : " <<
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
347 doc.get<std::string>("summary").value_or("(unknown)") << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
348 std::cout << "Version : " <<
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
349 doc.get<std::string>("version").value_or("(unknown)") << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
350 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
351 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
352
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
353 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
354
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
355 // {{{ plugin_list_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
356
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
357 auto plugin_list_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
358 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
359 return "plugin-list";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
360 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
361
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
362 void plugin_list_cli::exec(ctl::controller& ctl, const std::vector<std::string>&)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
363 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
364 request(ctl, {{ "command", "plugin-list" }}, [] (auto result) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
365 for (const auto& value : result["list"])
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
366 if (value.is_string())
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
367 std::cout << value.template get<std::string>() << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
368 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
369 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
370
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
371 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
372
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
373 // {{{ plugin_load_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
374
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
375 auto plugin_load_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
376 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
377 return "plugin-load";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
378 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
379
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
380 void plugin_load_cli::exec(ctl::controller& ctl, const std::vector<std::string> &args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
381 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
382 if (args.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
383 throw std::invalid_argument("plugin-load requires 1 argument");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
384
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
385 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
386 { "command", "plugin-load" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
387 { "plugin", args[0] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
388 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
389 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
390
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
391 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
392
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
393 // {{{ plugin_reload_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
394
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
395 auto plugin_reload_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
396 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
397 return "plugin-reload";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
398 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
399
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
400 void plugin_reload_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
401 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
402 if (args.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
403 throw std::invalid_argument("plugin-reload requires 1 argument");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
404
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
405 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
406 { "command", "plugin-reload" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
407 { "plugin", args[0] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
408 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
409 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
410
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
411 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
412
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
413 // {{{ plugin_unload_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
414
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
415 auto plugin_unload_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
416 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
417 return "plugin-unload";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
418 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
419
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
420 void plugin_unload_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
421 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
422 if (args.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
423 throw std::invalid_argument("plugin-unload requires 1 argument");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
424
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
425 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
426 { "command", "plugin-unload" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
427 { "plugin", args[0] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
428 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
429 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
430
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
431 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
432
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
433 // {{{ rule_add_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
434
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
435 auto rule_add_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
436 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
437 return "rule-add";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
438 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
439
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
440 void rule_add_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
441 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
442 static const option::options options{
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
443 { "-c", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
444 { "--add-channel", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
445 { "-e", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
446 { "--add-event", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
447 { "-i", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
448 { "--index", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
449 { "-p", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
450 { "--add-plugin", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
451 { "-s", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
452 { "--add-server", true }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
453 };
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
454
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
455 auto copy = args;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
456 auto result = option::read(copy, options);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
457
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
458 if (copy.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
459 throw std::invalid_argument("rule-add requires at least 1 argument");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
460
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
461 auto json = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
462 { "command", "rule-add" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
463 { "channels", nlohmann::json::array() },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
464 { "events", nlohmann::json::array() },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
465 { "plugins", nlohmann::json::array() },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
466 { "servers", nlohmann::json::array() }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
467 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
468
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
469 // All sets.
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
470 for (const auto& pair : result) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
471 if (pair.first == "-c" || pair.first == "--add-channel")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
472 json["channels"].push_back(pair.second);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
473 if (pair.first == "-e" || pair.first == "--add-event")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
474 json["events"].push_back(pair.second);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
475 if (pair.first == "-p" || pair.first == "--add-plugin")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
476 json["plugins"].push_back(pair.second);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
477 if (pair.first == "-s" || pair.first == "--add-server")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
478 json["servers"].push_back(pair.second);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
479 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
480
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
481 // Index.
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
482 std::optional<unsigned> index;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
483
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
484 if (result.count("-i") > 0 && !(index = string_util::to_uint(result.find("-i")->second)))
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
485 throw std::invalid_argument("invalid index argument");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
486 if (result.count("--index") > 0 && !(index = string_util::to_uint(result.find("--index")->second)))
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
487 throw std::invalid_argument("invalid index argument");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
488
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
489 if (index)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
490 json["index"] = *index;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
491
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
492 json["action"] = copy[0];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
493
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
494 request(ctl, json);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
495 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
496
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
497 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
498
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
499 // {{{ rule_edit_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
500
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
501 auto rule_edit_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
502 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
503 return "rule-edit";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
504 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
505
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
506 void rule_edit_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
507 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
508 static const option::options options{
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
509 { "-a", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
510 { "--action", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
511 { "-c", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
512 { "--add-channel", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
513 { "-C", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
514 { "--remove-channel", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
515 { "-e", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
516 { "--add-event", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
517 { "-E", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
518 { "--remove-event", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
519 { "-p", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
520 { "--add-plugin", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
521 { "-P", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
522 { "--remove-plugin", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
523 { "-s", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
524 { "--add-server", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
525 { "-S", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
526 { "--remove-server", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
527 };
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
528
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
529 auto copy = args;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
530 auto result = option::read(copy, options);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
531
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
532 if (copy.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
533 throw std::invalid_argument("rule-edit requires at least 1 argument");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
534
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
535 auto json = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
536 { "command", "rule-edit" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
537 { "channels", nlohmann::json::array() },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
538 { "events", nlohmann::json::array() },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
539 { "plugins", nlohmann::json::array() },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
540 { "servers", nlohmann::json::array() }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
541 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
542
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
543 for (const auto& pair : result) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
544 // Action.
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
545 if (pair.first == "-a" || pair.first == "--action")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
546 json["action"] = pair.second;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
547
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
548 // Additions.
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
549 if (pair.first == "-c" || pair.first == "--add-channel")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
550 json["add-channels"].push_back(pair.second);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
551 if (pair.first == "-e" || pair.first == "--add-event")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
552 json["add-events"].push_back(pair.second);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
553 if (pair.first == "-p" || pair.first == "--add-plugin")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
554 json["add-plugins"].push_back(pair.second);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
555 if (pair.first == "-s" || pair.first == "--add-server")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
556 json["add-servers"].push_back(pair.second);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
557
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
558 // Removals.
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
559 if (pair.first == "-C" || pair.first == "--remove-channel")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
560 json["remove-channels"].push_back(pair.second);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
561 if (pair.first == "-E" || pair.first == "--remove-event")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
562 json["remove-events"].push_back(pair.second);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
563 if (pair.first == "-P" || pair.first == "--remove-plugin")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
564 json["remove-plugins"].push_back(pair.second);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
565 if (pair.first == "-S" || pair.first == "--remove-server")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
566 json["remove-servers"].push_back(pair.second);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
567 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
568
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
569 // Index.
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
570 const auto index = string_util::to_uint(copy[0]);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
571
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
572 if (!index)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
573 throw rule_error(rule_error::invalid_index);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
574
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
575 json["index"] = *index;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
576
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
577 request(ctl, json);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
578 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
579
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
580 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
581
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
582 // {{{ rule_info_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
583
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
584 void rule_info_cli::print(const nlohmann::json& json, int index)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
585 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
586 assert(json.is_object());
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
587
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
588 const auto unjoin = [] (auto array) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
589 std::ostringstream oss;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
590
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
591 for (auto it = array.begin(); it != array.end(); ++it) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
592 if (!it->is_string())
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
593 continue;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
594
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
595 oss << it->template get<std::string>() << " ";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
596 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
597
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
598 return oss.str();
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
599 };
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
600 const auto unstr = [] (auto action) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
601 if (action.is_string() && action == "accept")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
602 return "accept";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
603 else
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
604 return "drop";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
605 };
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
606
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
607 std::cout << "rule: " << index << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
608 std::cout << "servers: " << unjoin(json["servers"]) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
609 std::cout << "channels: " << unjoin(json["channels"]) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
610 std::cout << "plugins: " << unjoin(json["plugins"]) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
611 std::cout << "events: " << unjoin(json["events"]) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
612 std::cout << "action: " << unstr(json["action"]) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
613 std::cout << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
614 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
615
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
616 auto rule_info_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
617 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
618 return "rule-info";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
619 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
620
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
621 void rule_info_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
622 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
623 if (args.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
624 throw std::invalid_argument("rule-info requires 1 argument");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
625
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
626 const auto index = string_util::to_int(args[0]);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
627
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
628 if (!index)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
629 throw rule_error(rule_error::invalid_index);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
630
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
631 const auto json = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
632 { "command", "rule-info" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
633 { "index", *index }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
634 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
635
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
636 request(ctl, json, [index] (auto result) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
637 print(result, *index);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
638 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
639 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
640
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
641 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
642
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
643 // {{{ rule_list_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
644
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
645 auto rule_list_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
646 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
647 return "rule-list";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
648 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
649
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
650 void rule_list_cli::exec(ctl::controller& ctl, const std::vector<std::string>&)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
651 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
652 request(ctl, {{ "command", "rule-list" }}, [] (auto result) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
653 auto pos = 0;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
654
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
655 for (const auto& obj : result["list"]) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
656 if (obj.is_object())
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
657 rule_info_cli::print(obj, pos++);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
658 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
659 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
660 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
661
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
662 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
663
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
664 // {{{ rule_move_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
665
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
666 auto rule_move_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
667 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
668 return "rule-move";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
669 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
670
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
671 void rule_move_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
672 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
673 if (args.size() < 2)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
674 throw std::invalid_argument("rule-move requires 2 arguments");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
675
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
676 const auto from = string_util::to_int<int>(args[0]);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
677 const auto to = string_util::to_int<int>(args[1]);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
678
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
679 if (!from)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
680 throw rule_error(rule_error::invalid_index);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
681 if (!to)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
682 throw rule_error(rule_error::invalid_index);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
683
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
684 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
685 { "command", "rule-move" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
686 { "from", *from },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
687 { "to", *to }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
688 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
689 }
345
006452e4a997 Irccdctl: unify cli commands
David Demelier <markand@malikania.fr>
parents: 344
diff changeset
690
752
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
691 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
692
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
693 // {{{ rule_remove_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
694
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
695 auto rule_remove_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
696 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
697 return "rule-remove";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
698 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
699
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
700 void rule_remove_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
701 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
702 if (args.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
703 throw std::invalid_argument("rule-remove requires 1 argument");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
704
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
705 const auto index = string_util::to_int(args[0]);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
706
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
707 if (!index)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
708 throw rule_error(rule_error::invalid_index);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
709
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
710 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
711 { "command", "rule-remove" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
712 { "index", *index }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
713 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
714 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
715
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
716 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
717
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
718 // {{{ server_connect_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
719
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
720 auto server_connect_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
721 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
722 return "server-connect";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
723 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
724
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
725 void server_connect_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
726 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
727 std::vector<std::string> copy(args);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
728
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
729 option::result result = parse(copy);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
730 option::result::const_iterator it;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
731
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
732 if (copy.size() < 2)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
733 throw std::invalid_argument("server-connect requires at least 2 arguments");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
734
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
735 auto object = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
736 { "command", "server-connect" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
737 { "name", copy[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
738 { "host", copy[1] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
739 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
740
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
741 if (copy.size() == 3) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
742 const auto port = string_util::to_int(copy[2]);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
743
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
744 if (!port)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
745 throw std::invalid_argument("invalid port given");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
746
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
747 object["port"] = *port;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
748 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
749
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
750 if (result.count("-S") > 0 || result.count("--ssl-verify") > 0)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
751 object["sslVerify"] = true;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
752 if (result.count("-s") > 0 || result.count("--ssl") > 0)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
753 object["ssl"] = true;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
754 if ((it = result.find("-n")) != result.end() || (it = result.find("--nickname")) != result.end())
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
755 object["nickname"] = it->second;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
756 if ((it = result.find("-r")) != result.end() || (it = result.find("--realname")) != result.end())
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
757 object["realname"] = it->second;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
758 if ((it = result.find("-u")) != result.end() || (it = result.find("--username")) != result.end())
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
759 object["username"] = it->second;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
760
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
761 request(ctl, object);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
762 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
763
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
764 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
765
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
766 // {{{ server_disconnect_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
767
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
768 auto server_disconnect_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
769 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
770 return "server-disconnect";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
771 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
772
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
773 void server_disconnect_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
774 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
775 auto object = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
776 { "command", "server-disconnect" }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
777 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
778
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
779 if (args.size() > 0)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
780 object["server"] = args[0];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
781
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
782 request(ctl, object);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
783 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
784
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
785 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
786
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
787 // {{{ server_info_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
788
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
789 auto server_info_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
790 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
791 return "server-info";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
792 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
793
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
794 void server_info_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
795 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
796 if (args.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
797 throw std::invalid_argument("server-info requires 1 argument");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
798
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
799 auto json = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
800 { "command", "server-info" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
801 { "server", args[0] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
802 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
803
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
804 request(ctl, std::move(json), [] (auto result) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
805 std::cout << std::boolalpha;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
806 std::cout << "Name : " << json_util::pretty(result["name"]) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
807 std::cout << "Host : " << json_util::pretty(result["host"]) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
808 std::cout << "Port : " << json_util::pretty(result["port"]) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
809 std::cout << "Ipv6 : " << json_util::pretty(result["ipv6"]) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
810 std::cout << "SSL : " << json_util::pretty(result["ssl"]) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
811 std::cout << "SSL verified : " << json_util::pretty(result["sslVerify"]) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
812 std::cout << "Channels : ";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
813
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
814 for (const auto& v : result["channels"])
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
815 if (v.is_string())
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
816 std::cout << v.template get<std::string>() << " ";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
817
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
818 std::cout << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
819
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
820 std::cout << "Nickname : " << json_util::pretty(result["nickname"]) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
821 std::cout << "User name : " << json_util::pretty(result["username"]) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
822 std::cout << "Real name : " << json_util::pretty(result["realname"]) << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
823 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
824 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
825
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
826 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
827
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
828 // {{{ server_invite_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
829
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
830 auto server_invite_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
831 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
832 return "server-invite";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
833 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
834
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
835 void server_invite_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
836 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
837 if (args.size() < 3)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
838 throw std::invalid_argument("server-invite requires 3 arguments");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
839
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
840 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
841 { "command", "server-invite" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
842 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
843 { "target", args[1] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
844 { "channel", args[2] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
845 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
846 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
847
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
848 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
849
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
850 // {{{ server_join_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
851
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
852 auto server_join_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
853 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
854 return "server-join";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
855 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
856
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
857 void server_join_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
858 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
859 if (args.size() < 2)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
860 throw std::invalid_argument("server-join requires at least 2 arguments");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
861
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
862 auto object = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
863 { "command", "server-join" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
864 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
865 { "channel", args[1] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
866 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
867
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
868 if (args.size() == 3)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
869 object["password"] = args[2];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
870
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
871 request(ctl, object);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
872 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
873
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
874 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
875
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
876 // {{{ server_kick_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
877
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
878 auto server_kick_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
879 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
880 return "server-kick";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
881 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
882
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
883 void server_kick_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
884 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
885 if (args.size() < 3)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
886 throw std::invalid_argument("server-kick requires at least 3 arguments ");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
887
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
888 auto object = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
889 { "command", "server-kick" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
890 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
891 { "target", args[1] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
892 { "channel", args[2] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
893 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
894
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
895 if (args.size() == 4)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
896 object["reason"] = args[3];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
897
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
898 request(ctl, object);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
899 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
900
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
901 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
902
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
903 // {{{ server_list_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
904
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
905 auto server_list_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
906 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
907 return "server-list";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
908 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
909
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
910 void server_list_cli::exec(ctl::controller& ctl, const std::vector<std::string>&)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
911 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
912 request(ctl, {{ "command", "server-list" }}, [] (auto result) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
913 for (const auto& n : result["list"])
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
914 if (n.is_string())
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
915 std::cout << n.template get<std::string>() << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
916 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
917 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
918
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
919 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
920
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
921 // {{{ server_me_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
922
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
923 auto server_me_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
924 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
925 return "server-me";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
926 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
927
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
928 void server_me_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
929 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
930 if (args.size() < 3)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
931 throw std::runtime_error("server-me requires 3 arguments");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
932
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
933 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
934 { "command", "server-me" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
935 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
936 { "target", args[1] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
937 { "message", args[2] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
938 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
939 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
940
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
941 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
942
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
943 // {{{ server_message_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
944
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
945 auto server_message_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
946 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
947 return "server-message";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
948 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
949
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
950 void server_message_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
951 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
952 if (args.size() < 3)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
953 throw std::invalid_argument("server-message requires 3 arguments");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
954
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
955 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
956 { "command", "server-message" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
957 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
958 { "target", args[1] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
959 { "message", args[2] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
960 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
961 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
962
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
963 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
964
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
965 // {{{ server_mode_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
966
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
967 auto server_mode_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
968 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
969 return "server-mode";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
970 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
971
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
972 void server_mode_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
973 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
974 if (args.size() < 2)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
975 throw std::invalid_argument("server-mode requires at least 3 arguments");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
976
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
977 auto json = nlohmann::json({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
978 { "command", "server-mode" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
979 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
980 { "channel", args[1] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
981 { "mode", args[2] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
982 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
983
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
984 if (args.size() >= 4)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
985 json["limit"] = args[3];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
986 if (args.size() >= 5)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
987 json["user"] = args[4];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
988 if (args.size() >= 6)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
989 json["mask"] = args[5];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
990
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
991 request(ctl, std::move(json));
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
992 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
993
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
994 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
995
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
996 // {{{ server_nick_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
997
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
998 auto server_nick_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
999 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1000 return "server-nick";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1001 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1002
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1003 void server_nick_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1004 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1005 if (args.size() < 2)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1006 throw std::invalid_argument("server-nick requires 2 arguments");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1007
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1008 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1009 { "command", "server-nick" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1010 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1011 { "nickname", args[1] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1012 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1013 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1014
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1015 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1016
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1017 // {{{ server_notice_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1018
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1019 auto server_notice_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1020 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1021 return "server-notice";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1022 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1023
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1024 void server_notice_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1025 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1026 if (args.size() < 3)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1027 throw std::invalid_argument("server-notice requires 3 arguments");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1028
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1029 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1030 { "command", "server-notice" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1031 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1032 { "target", args[1] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1033 { "message", args[2] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1034 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1035 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1036
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1037 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1038
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1039 // {{{ server_part_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1040
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1041 auto server_part_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1042 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1043 return "server-part";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1044 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1045
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1046 void server_part_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1047 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1048 if (args.size() < 2)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1049 throw std::invalid_argument("server-part requires at least 2 arguments");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1050
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1051 auto object = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1052 { "command", "server-part" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1053 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1054 { "channel", args[1] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1055 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1056
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1057 if (args.size() >= 3)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1058 object["reason"] = args[2];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1059
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1060 request(ctl, object);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1061 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1062
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1063 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1064
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1065 // {{{ server_reconnect_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1066
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1067 auto server_reconnect_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1068 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1069 return "server-reconnect";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1070 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1071
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1072 void server_reconnect_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1073 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1074 auto object = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1075 { "command", "server-reconnect" }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1076 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1077
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1078 if (args.size() >= 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1079 object["server"] = args[0];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1080
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1081 request(ctl, object);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1082 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1083
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1084 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1085
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1086 // {{{ server_topic_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1087
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1088 auto server_topic_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1089 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1090 return "server-topic";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1091 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1092
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1093 void server_topic_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1094 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1095 if (args.size() < 3)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1096 throw std::invalid_argument("server-topic requires 3 arguments");
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1097
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1098 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1099 { "command", "server-topic" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1100 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1101 { "channel", args[1] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1102 { "topic", args[2] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1103 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1104 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1105
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1106 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1107
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1108 // {{{ watch_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1109
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1110 auto watch_cli::get_name() const noexcept -> std::string_view
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1111 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1112 return "watch";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1113 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1114
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1115 void watch_cli::exec(ctl::controller& ctl, const std::vector<std::string>& args)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1116 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1117 auto fmt = format(args);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1118
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1119 if (fmt != "native" && fmt != "json")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1120 throw std::invalid_argument("invalid format given: " + fmt);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1121
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1122 get_event(ctl, fmt);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1123 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1124
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1125 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1126
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1127 } // !irccd::ctl