X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/33c4e17c0d295d437438f6e1d8fbfd1ae6640f3c..5e16123632d839bc0fa0648d8fabbec48c03a7f9:/src/main/java/org/asamk/signal/util/CommandUtil.java diff --git a/src/main/java/org/asamk/signal/util/CommandUtil.java b/src/main/java/org/asamk/signal/util/CommandUtil.java index 3fa9aecd..61f5013e 100644 --- a/src/main/java/org/asamk/signal/util/CommandUtil.java +++ b/src/main/java/org/asamk/signal/util/CommandUtil.java @@ -1,5 +1,7 @@ package org.asamk.signal.util; +import net.sourceforge.argparse4j.inf.Namespace; + import org.asamk.signal.commands.exceptions.UserErrorException; import org.asamk.signal.manager.Manager; import org.asamk.signal.manager.api.CaptchaRequiredException; @@ -7,6 +9,7 @@ import org.asamk.signal.manager.api.GroupId; import org.asamk.signal.manager.api.GroupIdFormatException; import org.asamk.signal.manager.api.InvalidNumberException; import org.asamk.signal.manager.api.RateLimitException; +import org.asamk.signal.manager.api.ReceiveConfig; import org.asamk.signal.manager.api.RecipientIdentifier; import java.util.Collection; @@ -23,7 +26,8 @@ public class CommandUtil { final Manager m, final boolean isNoteToSelf, final List recipientStrings, - final List groupIdStrings + final List groupIdStrings, + final List usernameStrings ) throws UserErrorException { final var recipientIdentifiers = new HashSet(); if (isNoteToSelf) { @@ -36,6 +40,9 @@ public class CommandUtil { if (groupIdStrings != null) { recipientIdentifiers.addAll(CommandUtil.getGroupIdentifiers(groupIdStrings)); } + if (usernameStrings != null) { + recipientIdentifiers.addAll(CommandUtil.getUsernameIdentifiers(usernameStrings)); + } if (recipientIdentifiers.isEmpty()) { throw new UserErrorException("No recipients given"); @@ -77,7 +84,8 @@ public class CommandUtil { } public static Set getSingleRecipientIdentifiers( - final Collection recipientStrings, final String localNumber + final Collection recipientStrings, + final String localNumber ) throws UserErrorException { if (recipientStrings == null) { return Set.of(); @@ -90,7 +98,8 @@ public class CommandUtil { } public static RecipientIdentifier.Single getSingleRecipientIdentifier( - final String recipientString, final String localNumber + final String recipientString, + final String localNumber ) throws UserErrorException { try { return RecipientIdentifier.Single.fromString(recipientString, localNumber); @@ -99,14 +108,24 @@ public class CommandUtil { } } + public static Set getUsernameIdentifiers(Collection usernameIdStrings) { + if (usernameIdStrings == null) { + return Set.of(); + } + final var usernameIds = new HashSet(); + for (final var usernameIdString : usernameIdStrings) { + usernameIds.add(new RecipientIdentifier.Username(usernameIdString)); + } + return usernameIds; + } + public static String getCaptchaRequiredMessage(final CaptchaRequiredException e, final boolean captchaProvided) { String message; if (!captchaProvided) { message = """ Captcha required for verification, use --captcha CAPTCHA To get the token, go to https://signalcaptchas.org/registration/generate.html - Check the developer tools (F12) console for a failed redirect to signalcaptcha:// - Everything after signalcaptcha:// is the captcha token."""; + After solving the captcha, right-click on the "Open Signal" link and copy the link."""; } else { message = "Invalid captcha given."; } @@ -123,4 +142,12 @@ public class CommandUtil { } return message; } + + public static ReceiveConfig getReceiveConfig(final Namespace ns) { + final var ignoreAttachments = Boolean.TRUE.equals(ns.getBoolean("ignore-attachments")); + final var ignoreStories = Boolean.TRUE.equals(ns.getBoolean("ignore-stories")); + final var sendReadReceipts = Boolean.TRUE.equals(ns.getBoolean("send-read-receipts")); + + return new ReceiveConfig(ignoreAttachments, ignoreStories, sendReadReceipts); + } }