annotate irccdctl/cli.cpp @ 758:445c071e8efb

Irccd: Javascript API cleanup - Place all related code to `js` namespace, - Import duk.hpp and duk.cpp from libduk.
author David Demelier <markand@malikania.fr>
date Thu, 09 Aug 2018 13:07:19 +0200
parents c216d148558d
children 8c44bbcbbab9
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
754
c216d148558d Irccd: remove service directory
David Demelier <markand@malikania.fr>
parents: 752
diff changeset
27 #include <irccd/daemon/rule_service.hpp>
752
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
758
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
37 template <typename T>
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
38 auto bind() noexcept -> cli::constructor
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
39 {
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
40 return [] () noexcept {
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
41 return std::make_unique<T>();
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
42 };
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
43 }
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
44
752
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
45 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
46 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
47 auto result = option::read(args, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
48 { "-f", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
49 { "--format", true }
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 if (result.count("-f") > 0)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
53 return result.find("-f")->second;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
54 if (result.count("--format") > 0)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
55 return result.find("--format")->second;
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 return "native";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
58 }
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 void onConnect(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
61 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
62 std::cout << "event: onConnect\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
63 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
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 onInvite(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: onInvite\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 onJoin(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: onJoin\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 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
81
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
82 void onKick(const nlohmann::json &v)
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 std::cout << "event: onKick\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
85 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
86 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
87 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
88 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
89 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
90 }
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 void onMessage(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
93 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
94 std::cout << "event: onMessage\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
95 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
96 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
97 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
98 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
99 }
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 void onMe(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
102 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
103 std::cout << "event: onMe\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
104 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
105 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
106 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
107 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
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 onMode(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: onMode\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 << "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
115 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
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 onNames(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: onNames\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 << "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
123 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
124 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
125
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
126 void onNick(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: onNick\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 << "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
132 }
344
4665fffff6f2 Irccdctl: new cli interface
David Demelier <markand@malikania.fr>
parents:
diff changeset
133
752
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
134 void onNotice(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: onNotice\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 << "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
140 }
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 void onPart(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
143 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
144 std::cout << "event: onPart\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
145 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
146 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
147 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
148 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
149 }
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 void onTopic(const nlohmann::json &v)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
152 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
153 std::cout << "event: onTopic\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
154 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
155 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
156 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
157 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
158 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
159
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
160 void onWhois(const nlohmann::json &v)
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 std::cout << "event: onWhois\n";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
163 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
164 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
165 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
166 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
167 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
168 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
169
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
170 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
171 { "onConnect", onConnect },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
172 { "onInvite", onInvite },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
173 { "onJoin", onJoin },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
174 { "onKick", onKick },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
175 { "onMessage", onMessage },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
176 { "onMe", onMe },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
177 { "onMode", onMode },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
178 { "onNames", onNames },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
179 { "onNick", onNick },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
180 { "onNotice", onNotice },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
181 { "onPart", onPart },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
182 { "onTopic", onTopic },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
183 { "onWhois", onWhois }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
184 };
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
185
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
186 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
187 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
188 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
189 if (code)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
190 throw std::system_error(code);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
191
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
192 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
193 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
194
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
195 if (it != events.end()) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
196 if (fmt == "json")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
197 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
198 else {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
199 it->second(message);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
200 std::cout << std::endl;
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 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
203
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
204 get_event(ctl, std::move(fmt));
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
205 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
206 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
207
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
208 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
209 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
210 option::options options{
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
211 { "-c", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
212 { "--command", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
213 { "-n", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
214 { "--nickname", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
215 { "-r", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
216 { "--realname", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
217 { "-S", false },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
218 { "--ssl-verify", false },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
219 { "-s", false },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
220 { "--ssl", false },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
221 { "-u", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
222 { "--username", true }
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
225 return option::read(args, options);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
226 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
227
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
228 } // !namespace
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
229
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
230 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
231
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
232 // {{{ cli
527
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
233
758
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
234 const std::vector<cli::constructor> cli::registry{
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
235 bind<plugin_config_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
236 bind<plugin_info_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
237 bind<plugin_list_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
238 bind<plugin_load_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
239 bind<plugin_reload_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
240 bind<plugin_unload_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
241 bind<rule_add_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
242 bind<rule_edit_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
243 bind<rule_info_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
244 bind<rule_info_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
245 bind<rule_list_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
246 bind<rule_move_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
247 bind<rule_remove_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
248 bind<server_connect_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
249 bind<server_disconnect_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
250 bind<server_info_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
251 bind<server_invite_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
252 bind<server_join_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
253 bind<server_kick_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
254 bind<server_list_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
255 bind<server_me_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
256 bind<server_message_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
257 bind<server_mode_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
258 bind<server_nick_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
259 bind<server_notice_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
260 bind<server_part_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
261 bind<server_reconnect_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
262 bind<server_topic_cli>(),
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
263 bind<watch_cli>()
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
264 };
445c071e8efb Irccd: Javascript API cleanup
David Demelier <markand@malikania.fr>
parents: 754
diff changeset
265
527
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
266 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
267 {
670
95ac3ace1610 Common: introduce new io code
David Demelier <markand@malikania.fr>
parents: 649
diff changeset
268 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
269 if (code)
670
95ac3ace1610 Common: introduce new io code
David Demelier <markand@malikania.fr>
parents: 649
diff changeset
270 throw std::system_error(code);
527
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
271
698
ad1ee47165fa Irccd: create own json_util::document class
David Demelier <markand@malikania.fr>
parents: 670
diff changeset
272 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
273
641
7e2d0739f37c Irccd: import json_util from code
David Demelier <markand@malikania.fr>
parents: 628
diff changeset
274 if (!c) {
527
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
275 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
276 return;
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
277 }
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
278
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
279 if (handler)
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
280 handler(std::move(message));
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
281 });
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
282 }
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
283
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
284 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
285 {
670
95ac3ace1610 Common: introduce new io code
David Demelier <markand@malikania.fr>
parents: 649
diff changeset
286 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
287 if (code)
670
95ac3ace1610 Common: introduce new io code
David Demelier <markand@malikania.fr>
parents: 649
diff changeset
288 throw std::system_error(code);
527
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
289
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
290 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
291 });
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
292 }
a88796ed040a Irccdctl: switch to Boost.Asio, closes #697
David Demelier <markand@malikania.fr>
parents: 521
diff changeset
293
752
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 // {{{ plugin_config_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
297
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
298 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
299 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
300 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
301 { "command", "plugin-config" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
302 { "plugin", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
303 { "variable", args[1] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
304 { "value", args[2] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
305 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
306 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
307
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
308 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
309 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
310 auto json = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
311 { "command", "plugin-config" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
312 { "plugin", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
313 { "variable", args[1] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
314 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
315
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
316 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
317 if (result["variables"].is_object())
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
318 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
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
322 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
323 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
324 const auto json = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
325 { "command", "plugin-config" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
326 { "plugin", args[0] }
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
329 request(ctl, json, [] (auto result) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
330 const auto variables = result["variables"];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
331
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
332 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
333 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
334 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
335 }
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 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
338 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
339 return "plugin-config";
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
342 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
343 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
344 switch (args.size()) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
345 case 3:
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
346 set(ctl, args);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
347 break;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
348 case 2:
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
349 get(ctl, args);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
350 break;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
351 case 1:
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
352 getall(ctl, args);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
353 break;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
354 default:
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
355 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
356 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
357 }
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 // }}}
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 // {{{ plugin_info_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
362
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
363 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
364 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
365 return "plugin-info";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
366 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
367
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
368 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
369 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
370 if (args.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
371 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
372
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
373 const auto json = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
374 { "command", "plugin-info" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
375 { "plugin", args[0] }
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
378 request(ctl, json, [] (auto result) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
379 const json_util::document doc(result);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
380
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
381 std::cout << std::boolalpha;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
382 std::cout << "Author : " <<
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
383 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
384 std::cout << "License : " <<
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
385 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
386 std::cout << "Summary : " <<
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
387 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
388 std::cout << "Version : " <<
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
389 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
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 // }}}
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 // {{{ plugin_list_cli
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 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
398 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
399 return "plugin-list";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
400 }
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 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
403 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
404 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
405 for (const auto& value : result["list"])
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
406 if (value.is_string())
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
407 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
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_load_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_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
416 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
417 return "plugin-load";
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_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
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-load 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-load" },
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 // {{{ plugin_reload_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 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
436 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
437 return "plugin-reload";
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 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
441 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
442 if (args.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
443 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
444
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
445 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
446 { "command", "plugin-reload" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
447 { "plugin", args[0] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
448 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
449 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
450
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
451 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
452
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
453 // {{{ plugin_unload_cli
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 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
456 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
457 return "plugin-unload";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
458 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
459
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
460 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
461 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
462 if (args.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
463 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
464
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
465 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
466 { "command", "plugin-unload" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
467 { "plugin", args[0] }
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 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
470
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
471 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
472
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
473 // {{{ rule_add_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
474
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
475 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
476 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
477 return "rule-add";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
478 }
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 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
481 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
482 static const option::options options{
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
483 { "-c", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
484 { "--add-channel", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
485 { "-e", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
486 { "--add-event", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
487 { "-i", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
488 { "--index", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
489 { "-p", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
490 { "--add-plugin", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
491 { "-s", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
492 { "--add-server", true }
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
495 auto copy = args;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
496 auto result = option::read(copy, options);
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 if (copy.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
499 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
500
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
501 auto json = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
502 { "command", "rule-add" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
503 { "channels", nlohmann::json::array() },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
504 { "events", nlohmann::json::array() },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
505 { "plugins", nlohmann::json::array() },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
506 { "servers", nlohmann::json::array() }
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
509 // All sets.
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
510 for (const auto& pair : result) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
511 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
512 json["channels"].push_back(pair.second);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
513 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
514 json["events"].push_back(pair.second);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
515 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
516 json["plugins"].push_back(pair.second);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
517 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
518 json["servers"].push_back(pair.second);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
519 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
520
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
521 // Index.
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
522 std::optional<unsigned> index;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
523
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
524 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
525 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
526 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
527 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
528
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
529 if (index)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
530 json["index"] = *index;
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 json["action"] = copy[0];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
533
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
534 request(ctl, json);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
535 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
536
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
537 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
538
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
539 // {{{ rule_edit_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
540
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
541 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
542 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
543 return "rule-edit";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
544 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
545
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
546 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
547 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
548 static const option::options options{
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
549 { "-a", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
550 { "--action", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
551 { "-c", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
552 { "--add-channel", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
553 { "-C", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
554 { "--remove-channel", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
555 { "-e", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
556 { "--add-event", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
557 { "-E", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
558 { "--remove-event", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
559 { "-p", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
560 { "--add-plugin", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
561 { "-P", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
562 { "--remove-plugin", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
563 { "-s", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
564 { "--add-server", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
565 { "-S", true },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
566 { "--remove-server", true },
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 auto copy = args;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
570 auto result = option::read(copy, options);
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 (copy.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
573 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
574
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
575 auto json = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
576 { "command", "rule-edit" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
577 { "channels", nlohmann::json::array() },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
578 { "events", nlohmann::json::array() },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
579 { "plugins", nlohmann::json::array() },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
580 { "servers", nlohmann::json::array() }
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
583 for (const auto& pair : result) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
584 // Action.
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
585 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
586 json["action"] = pair.second;
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 // Additions.
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
589 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
590 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
591 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
592 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
593 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
594 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
595 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
596 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
597
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
598 // Removals.
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
599 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
600 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
601 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
602 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
603 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
604 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
605 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
606 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
607 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
608
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
609 // Index.
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
610 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
611
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
612 if (!index)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
613 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
614
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
615 json["index"] = *index;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
616
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
617 request(ctl, json);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
618 }
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
622 // {{{ rule_info_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
623
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
624 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
625 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
626 assert(json.is_object());
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 const auto unjoin = [] (auto array) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
629 std::ostringstream oss;
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 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
632 if (!it->is_string())
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
633 continue;
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 oss << it->template get<std::string>() << " ";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
636 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
637
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
638 return oss.str();
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 const auto unstr = [] (auto action) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
641 if (action.is_string() && action == "accept")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
642 return "accept";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
643 else
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
644 return "drop";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
645 };
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 std::cout << "rule: " << index << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
648 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
649 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
650 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
651 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
652 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
653 std::cout << std::endl;
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
656 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
657 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
658 return "rule-info";
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 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
662 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
663 if (args.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
664 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
665
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
666 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
667
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
668 if (!index)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
669 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
670
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
671 const auto json = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
672 { "command", "rule-info" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
673 { "index", *index }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
674 });
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 request(ctl, json, [index] (auto result) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
677 print(result, *index);
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 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
680
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
681 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
682
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
683 // {{{ rule_list_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
684
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
685 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
686 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
687 return "rule-list";
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
690 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
691 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
692 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
693 auto pos = 0;
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 for (const auto& obj : result["list"]) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
696 if (obj.is_object())
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
697 rule_info_cli::print(obj, pos++);
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 }
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 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
703
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
704 // {{{ rule_move_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
705
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
706 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
707 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
708 return "rule-move";
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
711 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
712 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
713 if (args.size() < 2)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
714 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
715
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
716 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
717 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
718
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
719 if (!from)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
720 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
721 if (!to)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
722 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
723
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
724 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
725 { "command", "rule-move" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
726 { "from", *from },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
727 { "to", *to }
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 }
345
006452e4a997 Irccdctl: unify cli commands
David Demelier <markand@malikania.fr>
parents: 344
diff changeset
730
752
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
733 // {{{ rule_remove_cli
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 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
736 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
737 return "rule-remove";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
738 }
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 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
741 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
742 if (args.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
743 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
744
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
745 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
746
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
747 if (!index)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
748 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
749
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
750 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
751 { "command", "rule-remove" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
752 { "index", *index }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
753 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
754 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
755
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
756 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
757
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
758 // {{{ server_connect_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
759
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
760 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
761 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
762 return "server-connect";
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 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
766 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
767 std::vector<std::string> copy(args);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
768
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
769 option::result result = parse(copy);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
770 option::result::const_iterator it;
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 if (copy.size() < 2)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
773 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
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-connect" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
777 { "name", copy[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
778 { "host", copy[1] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
779 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
780
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
781 if (copy.size() == 3) {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
782 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
783
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
784 if (!port)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
785 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
786
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
787 object["port"] = *port;
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
790 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
791 object["sslVerify"] = true;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
792 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
793 object["ssl"] = true;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
794 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
795 object["nickname"] = it->second;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
796 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
797 object["realname"] = it->second;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
798 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
799 object["username"] = it->second;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
800
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
801 request(ctl, object);
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 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
805
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
806 // {{{ server_disconnect_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
807
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
808 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
809 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
810 return "server-disconnect";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
811 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
812
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
813 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
814 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
815 auto object = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
816 { "command", "server-disconnect" }
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
819 if (args.size() > 0)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
820 object["server"] = args[0];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
821
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
822 request(ctl, object);
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 // {{{ server_info_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
828
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
829 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
830 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
831 return "server-info";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
832 }
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 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
835 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
836 if (args.size() < 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
837 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
838
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
839 auto json = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
840 { "command", "server-info" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
841 { "server", args[0] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
842 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
843
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
844 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
845 std::cout << std::boolalpha;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
846 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
847 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
848 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
849 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
850 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
851 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
852 std::cout << "Channels : ";
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 for (const auto& v : result["channels"])
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
855 if (v.is_string())
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
856 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
857
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
858 std::cout << std::endl;
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
859
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
860 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
861 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
862 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
863 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
864 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
865
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 // {{{ server_invite_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
869
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
870 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
871 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
872 return "server-invite";
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 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
876 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
877 if (args.size() < 3)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
878 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
879
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
880 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
881 { "command", "server-invite" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
882 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
883 { "target", args[1] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
884 { "channel", args[2] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
885 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
886 }
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 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
889
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
890 // {{{ server_join_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
891
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
892 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
893 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
894 return "server-join";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
895 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
896
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
897 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
898 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
899 if (args.size() < 2)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
900 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
901
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
902 auto object = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
903 { "command", "server-join" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
904 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
905 { "channel", args[1] }
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
908 if (args.size() == 3)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
909 object["password"] = args[2];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
910
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
911 request(ctl, object);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
912 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
913
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
914 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
915
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
916 // {{{ server_kick_cli
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 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
919 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
920 return "server-kick";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
921 }
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 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
924 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
925 if (args.size() < 3)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
926 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
927
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
928 auto object = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
929 { "command", "server-kick" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
930 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
931 { "target", args[1] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
932 { "channel", args[2] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
933 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
934
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
935 if (args.size() == 4)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
936 object["reason"] = args[3];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
937
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
938 request(ctl, object);
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_list_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_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
946 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
947 return "server-list";
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_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
951 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
952 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
953 for (const auto& n : result["list"])
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
954 if (n.is_string())
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
955 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
956 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
957 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
958
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
959 // }}}
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 // {{{ server_me_cli
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 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
964 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
965 return "server-me";
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
968 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
969 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
970 if (args.size() < 3)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
971 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
972
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
973 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
974 { "command", "server-me" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
975 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
976 { "target", args[1] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
977 { "message", args[2] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
978 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
979 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
980
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
981 // }}}
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 // {{{ server_message_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
984
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
985 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
986 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
987 return "server-message";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
988 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
989
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
990 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
991 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
992 if (args.size() < 3)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
993 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
994
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
995 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
996 { "command", "server-message" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
997 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
998 { "target", args[1] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
999 { "message", args[2] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1000 });
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 // }}}
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 // {{{ server_mode_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1006
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1007 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
1008 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1009 return "server-mode";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1010 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1011
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1012 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
1013 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1014 if (args.size() < 2)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1015 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
1016
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1017 auto json = nlohmann::json({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1018 { "command", "server-mode" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1019 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1020 { "channel", args[1] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1021 { "mode", args[2] }
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 if (args.size() >= 4)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1025 json["limit"] = args[3];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1026 if (args.size() >= 5)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1027 json["user"] = args[4];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1028 if (args.size() >= 6)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1029 json["mask"] = args[5];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1030
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1031 request(ctl, std::move(json));
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1032 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1033
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 // {{{ server_nick_cli
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 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
1039 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1040 return "server-nick";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1041 }
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 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
1044 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1045 if (args.size() < 2)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1046 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
1047
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1048 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1049 { "command", "server-nick" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1050 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1051 { "nickname", args[1] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1052 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1053 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1054
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 // {{{ server_notice_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1058
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1059 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
1060 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1061 return "server-notice";
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 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
1065 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1066 if (args.size() < 3)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1067 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
1068
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1069 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1070 { "command", "server-notice" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1071 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1072 { "target", args[1] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1073 { "message", args[2] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1074 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1075 }
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1079 // {{{ server_part_cli
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 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
1082 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1083 return "server-part";
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 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
1087 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1088 if (args.size() < 2)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1089 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
1090
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1091 auto object = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1092 { "command", "server-part" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1093 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1094 { "channel", args[1] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1095 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1096
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1097 if (args.size() >= 3)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1098 object["reason"] = args[2];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1099
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1100 request(ctl, object);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1101 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1102
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 // {{{ server_reconnect_cli
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 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
1108 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1109 return "server-reconnect";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1110 }
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 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
1113 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1114 auto object = nlohmann::json::object({
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1115 { "command", "server-reconnect" }
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
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1118 if (args.size() >= 1)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1119 object["server"] = args[0];
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1120
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1121 request(ctl, object);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1122 }
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 // {{{ server_topic_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1127
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1128 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
1129 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1130 return "server-topic";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1131 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1132
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1133 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
1134 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1135 if (args.size() < 3)
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1136 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
1137
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1138 request(ctl, {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1139 { "command", "server-topic" },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1140 { "server", args[0] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1141 { "channel", args[1] },
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1142 { "topic", args[2] }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1143 });
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1144 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1145
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1146 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1147
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1148 // {{{ watch_cli
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1149
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1150 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
1151 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1152 return "watch";
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1153 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1154
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1155 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
1156 {
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1157 auto fmt = format(args);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1158
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1159 if (fmt != "native" && fmt != "json")
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1160 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
1161
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1162 get_event(ctl, fmt);
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1163 }
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1164
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1165 // }}}
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1166
252506d9839b Irccdctl: merge all cli in cli.cpp|hpp
David Demelier <markand@malikania.fr>
parents: 698
diff changeset
1167 } // !irccd::ctl