X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/d13d150fe1c6b21dd53617cf7996d2876bc5db58..101c217ef86aefcc42b5de588812ce8ce9bb0143:/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 b86a9989..d637f22e 100644 --- a/src/main/java/org/asamk/signal/util/CommandUtil.java +++ b/src/main/java/org/asamk/signal/util/CommandUtil.java @@ -2,10 +2,12 @@ package org.asamk.signal.util; 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.RecipientIdentifier; -import org.asamk.signal.manager.groups.GroupId; -import org.asamk.signal.manager.groups.GroupIdFormatException; import java.util.Collection; import java.util.HashSet; @@ -96,4 +98,28 @@ public class CommandUtil { throw new UserErrorException("Invalid phone number '" + recipientString + "': " + e.getMessage(), e); } } + + 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; + } }