1 use clap::{crate_version, Parser, Subcommand, ValueEnum};
2 use std::{ffi::OsString, net::SocketAddr};
4 /// JSON-RPC client for signal-cli
5 #[derive(Parser, Debug)]
6 #[command(rename_all = "kebab-case", version=crate_version!())]
8 /// Account to use (for daemon in multi-account mode)
9 #[arg(short = 'a', long)]
10 pub account: Option<String>,
12 /// TCP host and port of signal-cli daemon
13 #[arg(long, conflicts_with = "json_rpc_http")]
14 pub json_rpc_tcp: Option<Option<SocketAddr>>,
16 /// UNIX socket address and port of signal-cli daemon
17 #[arg(long, conflicts_with = "json_rpc_tcp")]
18 pub json_rpc_socket: Option<Option<OsString>>,
20 /// HTTP URL of signal-cli daemon
21 #[arg(long, conflicts_with = "json_rpc_socket")]
22 pub json_rpc_http: Option<Option<String>>,
24 #[arg(value_enum, long, default_value_t = OutputTypes::Json)]
25 pub output: OutputTypes,
30 #[command(subcommand)]
31 pub command: CliCommands,
34 #[derive(ValueEnum, Clone, Debug)]
35 #[value(rename_all = "kebab-case")]
36 pub enum OutputTypes {
41 #[allow(clippy::large_enum_variant)]
42 #[derive(Subcommand, Debug)]
43 #[command(rename_all = "camelCase", version=crate_version!())]
44 pub enum CliCommands {
49 #[command(rename_all = "kebab-case")]
51 recipient: Vec<String>,
53 #[arg(short = 'g', long)]
54 group_id: Vec<String>,
56 DeleteLocalAccountData {
57 #[arg(long = "ignore-registered")]
58 ignore_registered: Option<bool>,
61 recipient: Vec<String>,
68 #[arg(short = 'n', long)]
73 recipient: Vec<String>,
74 #[arg(short = 'a', long = "all-recipients")]
77 blocked: Option<bool>,
83 #[arg(short = 'd', long)]
85 #[arg(short = 'g', long = "group-id")]
86 group_id: Vec<String>,
89 #[arg(short = 'n', long)]
90 number: Option<String>,
94 #[arg(short = 'g', long = "group-id")]
102 #[arg(short = 't', long, default_value_t = 3.0)]
106 #[arg(short = 'v', long)]
109 captcha: Option<String>,
117 #[arg(short = 'd', long = "device-id")]
122 #[arg(short = 't', long = "target-timestamp")]
123 target_timestamp: u64,
125 recipient: Vec<String>,
127 #[arg(short = 'g', long = "group-id")]
128 group_id: Vec<String>,
130 #[arg(long = "note-to-self")]
133 #[command(rename_all = "kebab-case")]
135 recipient: Vec<String>,
137 #[arg(short = 'g', long)]
138 group_id: Vec<String>,
143 #[arg(short = 'e', long)]
146 #[arg(short = 'm', long)]
147 message: Option<String>,
149 #[arg(short = 'a', long)]
150 attachment: Vec<String>,
153 mention: Vec<String>,
156 quote_timestamp: Option<u64>,
159 quote_author: Option<String>,
162 quote_message: Option<String>,
165 quote_mention: Vec<String>,
168 quote_attachment: Vec<String>,
171 sticker: Option<String>,
174 story_timestamp: Option<u64>,
177 story_author: Option<String>,
180 SendPaymentNotification {
190 recipient: Vec<String>,
192 #[arg(short = 'g', long = "group-id")]
193 group_id: Vec<String>,
195 #[arg(long = "note-to-self")]
198 #[arg(short = 'e', long)]
201 #[arg(short = 'a', long = "target-author")]
202 target_author: String,
204 #[arg(short = 't', long = "target-timestamp")]
205 target_timestamp: u64,
207 #[arg(short = 'r', long)]
216 #[arg(short = 't', long = "target-timestamp")]
217 target_timestamp: Vec<u64>,
219 #[arg(value_enum, long)]
224 recipient: Vec<String>,
226 #[arg(short = 'g', long = "group-id")]
227 group_id: Vec<String>,
229 #[arg(short = 's', long)]
235 SubmitRateLimitChallenge {
242 #[arg(short = 'a', long = "trust-all-known-keys")]
243 trust_all_known_keys: bool,
245 #[arg(short = 'v', long = "verified-safety-number")]
246 verified_safety_number: Option<String>,
248 #[command(rename_all = "kebab-case")]
250 recipient: Vec<String>,
252 #[arg(short = 'g', long)]
253 group_id: Vec<String>,
256 #[arg(long = "delete-account")]
257 delete_account: bool,
260 #[arg(short = 'n', long = "device-name")]
261 device_name: Option<String>,
263 UpdateConfiguration {
264 #[arg(long = "read-receipts")]
265 read_receipts: Option<bool>,
267 #[arg(long = "unidentified-delivery-indicators")]
268 unidentified_delivery_indicators: Option<bool>,
270 #[arg(long = "typing-indicators")]
271 typing_indicators: Option<bool>,
273 #[arg(long = "link-previews")]
274 link_previews: Option<bool>,
279 #[arg(short = 'e', long)]
280 expiration: Option<u32>,
282 #[arg(short = 'n', long)]
283 name: Option<String>,
286 #[arg(short = 'g', long = "group-id")]
287 group_id: Option<String>,
289 #[arg(short = 'n', long)]
290 name: Option<String>,
292 #[arg(short = 'd', long)]
293 description: Option<String>,
295 #[arg(short = 'a', long)]
296 avatar: Option<String>,
298 #[arg(short = 'm', long)]
301 #[arg(short = 'r', long = "remove-member")]
302 remove_member: Vec<String>,
307 #[arg(long = "remove-admin")]
308 remove_admin: Vec<String>,
316 #[arg(long = "reset-link")]
319 #[arg(value_enum, long)]
320 link: Option<LinkState>,
322 #[arg(value_enum, long = "set-permission-add-member")]
323 set_permission_add_member: Option<GroupPermission>,
325 #[arg(value_enum, long = "set-permission-edit-details")]
326 set_permission_edit_details: Option<GroupPermission>,
328 #[arg(value_enum, long = "set-permission-send-messages")]
329 set_permission_send_messages: Option<GroupPermission>,
331 #[arg(short = 'e', long)]
332 expiration: Option<u32>,
335 #[arg(long = "given-name")]
336 given_name: Option<String>,
338 #[arg(long = "family-name")]
339 family_name: Option<String>,
342 about: Option<String>,
344 #[arg(long = "about-emoji")]
345 about_emoji: Option<String>,
347 #[arg(long = "mobile-coin-address")]
348 mobile_coin_address: Option<String>,
351 avatar: Option<String>,
353 #[arg(long = "remove-avatar")]
360 verification_code: String,
362 #[arg(short = 'p', long)]
368 #[derive(ValueEnum, Clone, Debug)]
369 #[value(rename_all = "kebab-case")]
370 pub enum ReceiptType {
375 #[derive(ValueEnum, Clone, Debug)]
376 #[value(rename_all = "kebab-case")]
383 #[derive(ValueEnum, Clone, Debug)]
384 #[value(rename_all = "kebab-case")]
385 pub enum GroupPermission {