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
14 pub json_rpc_tcp: Option<Option<SocketAddr>>,
16 /// UNIX socket address and port of signal-cli daemon
18 pub json_rpc_socket: Option<Option<OsString>>,
20 #[arg(value_enum, long, default_value_t = OutputTypes::Json)]
21 pub output: OutputTypes,
26 #[command(subcommand)]
27 pub command: CliCommands,
30 #[derive(ValueEnum, Clone, Debug)]
31 #[value(rename_all = "kebab-case")]
32 pub enum OutputTypes {
37 #[allow(clippy::large_enum_variant)]
38 #[derive(Subcommand, Debug)]
39 #[command(rename_all = "camelCase", version=crate_version!())]
40 pub enum CliCommands {
45 #[command(rename_all = "kebab-case")]
47 recipient: Vec<String>,
49 #[arg(short = 'g', long)]
50 group_id: Vec<String>,
52 DeleteLocalAccountData {
53 #[arg(long = "ignore-registered")]
54 ignore_registered: Option<bool>,
57 recipient: Vec<String>,
64 #[arg(short = 'n', long)]
69 recipient: Vec<String>,
70 #[arg(short = 'a', long = "all-recipients")]
73 blocked: Option<bool>,
79 #[arg(short = 'd', long)]
81 #[arg(short = 'g', long = "group-id")]
82 group_id: Vec<String>,
85 #[arg(short = 'n', long)]
86 number: Option<String>,
90 #[arg(short = 'g', long = "group-id")]
98 #[arg(short = 't', long, default_value_t = 3.0)]
102 #[arg(short = 'v', long)]
105 captcha: Option<String>,
113 #[arg(short = 'd', long = "device-id")]
118 #[arg(short = 't', long = "target-timestamp")]
119 target_timestamp: u64,
121 recipient: Vec<String>,
123 #[arg(short = 'g', long = "group-id")]
124 group_id: Vec<String>,
126 #[arg(long = "note-to-self")]
129 #[command(rename_all = "kebab-case")]
131 recipient: Vec<String>,
133 #[arg(short = 'g', long)]
134 group_id: Vec<String>,
139 #[arg(short = 'e', long)]
142 #[arg(short = 'm', long)]
143 message: Option<String>,
145 #[arg(short = 'a', long)]
146 attachment: Vec<String>,
149 mention: Vec<String>,
152 quote_timestamp: Option<u64>,
155 quote_author: Option<String>,
158 quote_message: Option<String>,
161 quote_mention: Vec<String>,
164 sticker: Option<String>,
167 story_timestamp: Option<u64>,
170 story_author: Option<String>,
173 SendPaymentNotification {
183 recipient: Vec<String>,
185 #[arg(short = 'g', long = "group-id")]
186 group_id: Vec<String>,
188 #[arg(long = "note-to-self")]
191 #[arg(short = 'e', long)]
194 #[arg(short = 'a', long = "target-author")]
195 target_author: String,
197 #[arg(short = 't', long = "target-timestamp")]
198 target_timestamp: u64,
200 #[arg(short = 'r', long)]
209 #[arg(short = 't', long = "target-timestamp")]
210 target_timestamp: Vec<u64>,
212 #[arg(value_enum, long)]
217 recipient: Vec<String>,
219 #[arg(short = 'g', long = "group-id")]
220 group_id: Vec<String>,
222 #[arg(short = 's', long)]
228 SubmitRateLimitChallenge {
235 #[arg(short = 'a', long = "trust-all-known-keys")]
236 trust_all_known_keys: bool,
238 #[arg(short = 'v', long = "verified-safety-number")]
239 verified_safety_number: Option<String>,
241 #[command(rename_all = "kebab-case")]
243 recipient: Vec<String>,
245 #[arg(short = 'g', long)]
246 group_id: Vec<String>,
249 #[arg(long = "delete-account")]
250 delete_account: bool,
253 #[arg(short = 'n', long = "device-name")]
254 device_name: Option<String>,
256 UpdateConfiguration {
257 #[arg(long = "read-receipts")]
258 read_receipts: Option<bool>,
260 #[arg(long = "unidentified-delivery-indicators")]
261 unidentified_delivery_indicators: Option<bool>,
263 #[arg(long = "typing-indicators")]
264 typing_indicators: Option<bool>,
266 #[arg(long = "link-previews")]
267 link_previews: Option<bool>,
272 #[arg(short = 'e', long)]
273 expiration: Option<u32>,
275 #[arg(short = 'n', long)]
276 name: Option<String>,
279 #[arg(short = 'g', long = "group-id")]
280 group_id: Option<String>,
282 #[arg(short = 'n', long)]
283 name: Option<String>,
285 #[arg(short = 'd', long)]
286 description: Option<String>,
288 #[arg(short = 'a', long)]
289 avatar: Option<String>,
291 #[arg(short = 'm', long)]
294 #[arg(short = 'r', long = "remove-member")]
295 remove_member: Vec<String>,
300 #[arg(long = "remove-admin")]
301 remove_admin: Vec<String>,
309 #[arg(long = "reset-link")]
312 #[arg(value_enum, long)]
313 link: Option<LinkState>,
315 #[arg(value_enum, long = "set-permission-add-member")]
316 set_permission_add_member: Option<GroupPermission>,
318 #[arg(value_enum, long = "set-permission-edit-details")]
319 set_permission_edit_details: Option<GroupPermission>,
321 #[arg(value_enum, long = "set-permission-send-messages")]
322 set_permission_send_messages: Option<GroupPermission>,
324 #[arg(short = 'e', long)]
325 expiration: Option<u32>,
328 #[arg(long = "given-name")]
329 given_name: Option<String>,
331 #[arg(long = "family-name")]
332 family_name: Option<String>,
335 about: Option<String>,
337 #[arg(long = "about-emoji")]
338 about_emoji: Option<String>,
340 #[arg(long = "mobile-coin-address")]
341 mobile_coin_address: Option<String>,
344 avatar: Option<String>,
346 #[arg(long = "remove-avatar")]
353 verification_code: String,
355 #[arg(short = 'p', long)]
361 #[derive(ValueEnum, Clone, Debug)]
362 #[value(rename_all = "kebab-case")]
363 pub enum ReceiptType {
368 #[derive(ValueEnum, Clone, Debug)]
369 #[value(rename_all = "kebab-case")]
376 #[derive(ValueEnum, Clone, Debug)]
377 #[value(rename_all = "kebab-case")]
378 pub enum GroupPermission {