]> nmode's Git Repositories - signal-cli/blob - src/main/java/org/asamk/signal/commands/SendReactionCommand.java
56fa81f2b83ff75b2dafe237f9d7aa5705f8a140
[signal-cli] / src / main / java / org / asamk / signal / commands / SendReactionCommand.java
1 package org.asamk.signal.commands;
2
3 import net.sourceforge.argparse4j.impl.Arguments;
4 import net.sourceforge.argparse4j.inf.Namespace;
5 import net.sourceforge.argparse4j.inf.Subparser;
6
7 import org.asamk.signal.commands.exceptions.CommandException;
8 import org.asamk.signal.commands.exceptions.UnexpectedErrorException;
9 import org.asamk.signal.commands.exceptions.UserErrorException;
10 import org.asamk.signal.manager.Manager;
11 import org.asamk.signal.manager.api.GroupNotFoundException;
12 import org.asamk.signal.manager.api.GroupSendingNotAllowedException;
13 import org.asamk.signal.manager.api.NotAGroupMemberException;
14 import org.asamk.signal.manager.api.UnregisteredRecipientException;
15 import org.asamk.signal.output.OutputWriter;
16 import org.asamk.signal.util.CommandUtil;
17
18 import java.io.IOException;
19
20 import static org.asamk.signal.util.SendMessageResultUtils.outputResult;
21
22 public class SendReactionCommand implements JsonRpcLocalCommand {
23
24 @Override
25 public String getName() {
26 return "sendReaction";
27 }
28
29 @Override
30 public void attachToSubparser(final Subparser subparser) {
31 subparser.help("Send reaction to a previously received or sent message.");
32 subparser.addArgument("-g", "--group-id", "--group").help("Specify the recipient group ID.").nargs("*");
33 subparser.addArgument("recipient").help("Specify the recipients' phone number.").nargs("*");
34 subparser.addArgument("-u", "--username").help("Specify the recipient username or username link.").nargs("*");
35 subparser.addArgument("--note-to-self")
36 .help("Send the reaction to self without notification.")
37 .action(Arguments.storeTrue());
38 subparser.addArgument("-e", "--emoji")
39 .required(true)
40 .help("Specify the emoji, should be a single unicode grapheme cluster.");
41 subparser.addArgument("-a", "--target-author")
42 .required(true)
43 .help("Specify the number of the author of the message to which to react.");
44 subparser.addArgument("-t", "--target-timestamp")
45 .required(true)
46 .type(long.class)
47 .help("Specify the timestamp of the message to which to react.");
48 subparser.addArgument("-r", "--remove").help("Remove a reaction.").action(Arguments.storeTrue());
49 subparser.addArgument("--story")
50 .help("React to a story instead of a normal message")
51 .action(Arguments.storeTrue());
52 }
53
54 @Override
55 public void handleCommand(
56 final Namespace ns, final Manager m, final OutputWriter outputWriter
57 ) throws CommandException {
58 final var isNoteToSelf = Boolean.TRUE.equals(ns.getBoolean("note-to-self"));
59 final var recipientStrings = ns.<String>getList("recipient");
60 final var groupIdStrings = ns.<String>getList("group-id");
61 final var usernameStrings = ns.<String>getList("username");
62
63 final var recipientIdentifiers = CommandUtil.getRecipientIdentifiers(m,
64 isNoteToSelf,
65 recipientStrings,
66 groupIdStrings,
67 usernameStrings);
68
69 final var emoji = ns.getString("emoji");
70 final var isRemove = Boolean.TRUE.equals(ns.getBoolean("remove"));
71 final var targetAuthor = ns.getString("target-author");
72 final var targetTimestamp = ns.getLong("target-timestamp");
73 final var isStory = Boolean.TRUE.equals(ns.getBoolean("story"));
74
75 try {
76 final var results = m.sendMessageReaction(emoji,
77 isRemove,
78 CommandUtil.getSingleRecipientIdentifier(targetAuthor, m.getSelfNumber()),
79 targetTimestamp,
80 recipientIdentifiers,
81 isStory);
82 outputResult(outputWriter, results);
83 } catch (GroupNotFoundException | NotAGroupMemberException | GroupSendingNotAllowedException e) {
84 throw new UserErrorException(e.getMessage());
85 } catch (IOException e) {
86 throw new UnexpectedErrorException("Failed to send message: " + e.getMessage() + " (" + e.getClass()
87 .getSimpleName() + ")", e);
88 } catch (UnregisteredRecipientException e) {
89 throw new UserErrorException("The user " + e.getSender().getIdentifier() + " is not registered.");
90 }
91 }
92 }