1 package org
.asamk
.signal
.commands
;
3 import net
.sourceforge
.argparse4j
.inf
.Namespace
;
4 import net
.sourceforge
.argparse4j
.inf
.Subparser
;
6 import org
.asamk
.signal
.OutputWriter
;
7 import org
.asamk
.signal
.commands
.exceptions
.CommandException
;
8 import org
.asamk
.signal
.commands
.exceptions
.UserErrorException
;
9 import org
.asamk
.signal
.manager
.Manager
;
10 import org
.asamk
.signal
.manager
.NotMasterDeviceException
;
11 import org
.asamk
.signal
.manager
.groups
.GroupIdFormatException
;
12 import org
.asamk
.signal
.manager
.groups
.GroupNotFoundException
;
13 import org
.asamk
.signal
.util
.Util
;
14 import org
.slf4j
.Logger
;
15 import org
.slf4j
.LoggerFactory
;
16 import org
.whispersystems
.signalservice
.api
.util
.InvalidNumberException
;
18 public class UnblockCommand
implements JsonRpcLocalCommand
{
20 private final static Logger logger
= LoggerFactory
.getLogger(UnblockCommand
.class);
23 public String
getName() {
28 public void attachToSubparser(final Subparser subparser
) {
29 subparser
.help("Unblock the given contacts or groups (messages will be received again)");
30 subparser
.addArgument("contact").help("Contact number").nargs("*");
31 subparser
.addArgument("-g", "--group-id", "--group").help("Group ID").nargs("*");
35 public void handleCommand(
36 final Namespace ns
, final Manager m
, final OutputWriter outputWriter
37 ) throws CommandException
{
38 for (var contactNumber
: ns
.<String
>getList("contact")) {
40 m
.setContactBlocked(contactNumber
, false);
41 } catch (InvalidNumberException e
) {
42 logger
.warn("Invalid number: {}", contactNumber
);
43 } catch (NotMasterDeviceException e
) {
44 throw new UserErrorException("This command doesn't work on linked devices.");
48 if (ns
.<String
>getList("group-id") != null) {
49 for (var groupIdString
: ns
.<String
>getList("group-id")) {
51 var groupId
= Util
.decodeGroupId(groupIdString
);
52 m
.setGroupBlocked(groupId
, false);
53 } catch (GroupIdFormatException e
) {
54 logger
.warn("Invalid group id: {}", groupIdString
);
55 } catch (GroupNotFoundException e
) {
56 logger
.warn("Unknown group id: {}", groupIdString
);