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