X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/7c9fd9d0fb7b303e8194a6de9aed852c488afc25..41726d339f570ed89f5aa0aefd8466d793ab1909:/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 18b38a2a..039ac2a7 100644 --- a/src/main/java/org/asamk/signal/util/CommandUtil.java +++ b/src/main/java/org/asamk/signal/util/CommandUtil.java @@ -1,11 +1,16 @@ 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; +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 org.asamk.signal.manager.groups.GroupId; -import org.asamk.signal.manager.groups.GroupIdFormatException; -import org.whispersystems.signalservice.api.util.InvalidNumberException; import java.util.Collection; import java.util.HashSet; @@ -21,19 +26,23 @@ 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) { recipientIdentifiers.add(RecipientIdentifier.NoteToSelf.INSTANCE); } if (recipientStrings != null) { - final var localNumber = m.getUsername(); + final var localNumber = m.getSelfNumber(); recipientIdentifiers.addAll(CommandUtil.getSingleRecipientIdentifiers(recipientStrings, localNumber)); } 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"); @@ -93,7 +102,50 @@ public class CommandUtil { try { return RecipientIdentifier.Single.fromString(recipientString, localNumber); } catch (InvalidNumberException e) { - throw new UserErrorException("Invalid phone number '" + recipientString + "': " + e.getMessage()); + throw new UserErrorException("Invalid phone number '" + recipientString + "': " + e.getMessage(), e); } } + + 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 + After solving the captcha, right-click on the "Open Signal" link and copy the link."""; + } else { + message = "Invalid captcha given."; + } + if (e.getNextAttemptTimestamp() > 0) { + message += "\nNext Captcha may be provided at " + DateUtils.formatTimestamp(e.getNextAttemptTimestamp()); + } + return message; + } + + public static String getRateLimitMessage(final RateLimitException e) { + String message = "Rate limit reached"; + if (e.getNextAttemptTimestamp() > 0) { + message += "\nNext attempt may be tried at " + DateUtils.formatTimestamp(e.getNextAttemptTimestamp()); + } + 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); + } }