]> nmode's Git Repositories - signal-cli/blob - src/main/java/org/asamk/signal/commands/UnblockCommand.java
e931a60ee543958ef638931be21c0d1c9b6a6025
[signal-cli] / src / main / java / org / asamk / signal / commands / UnblockCommand.java
1 package org.asamk.signal.commands;
2
3 import net.sourceforge.argparse4j.inf.Namespace;
4 import net.sourceforge.argparse4j.inf.Subparser;
5
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.GroupNotFoundException;
12 import org.asamk.signal.util.CommandUtil;
13 import org.slf4j.Logger;
14 import org.slf4j.LoggerFactory;
15
16 public class UnblockCommand implements JsonRpcLocalCommand {
17
18 private final static Logger logger = LoggerFactory.getLogger(UnblockCommand.class);
19
20 @Override
21 public String getName() {
22 return "unblock";
23 }
24
25 @Override
26 public void attachToSubparser(final Subparser subparser) {
27 subparser.help("Unblock the given contacts or groups (messages will be received again)");
28 subparser.addArgument("recipient").help("Contact number").nargs("*");
29 subparser.addArgument("-g", "--group-id", "--group").help("Group ID").nargs("*");
30 }
31
32 @Override
33 public void handleCommand(
34 final Namespace ns, final Manager m, final OutputWriter outputWriter
35 ) throws CommandException {
36 for (var contactNumber : CommandUtil.getSingleRecipientIdentifiers(ns.getList("recipient"), m.getUsername())) {
37 try {
38 m.setContactBlocked(contactNumber, false);
39 } catch (NotMasterDeviceException e) {
40 throw new UserErrorException("This command doesn't work on linked devices.");
41 }
42 }
43
44 final var groupIdStrings = ns.<String>getList("group-id");
45 for (var groupId : CommandUtil.getGroupIds(groupIdStrings)) {
46 try {
47 m.setGroupBlocked(groupId, false);
48 } catch (GroupNotFoundException e) {
49 logger.warn("Unknown group id: {}", groupId);
50 }
51 }
52 }
53 }