]> nmode's Git Repositories - signal-cli/blob - src/main/java/org/asamk/signal/commands/SendReactionCommand.java
Reformat files
[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,
57 final Manager m,
58 final OutputWriter outputWriter
59 ) throws CommandException {
60 final var isNoteToSelf = Boolean.TRUE.equals(ns.getBoolean("note-to-self"));
61 final var recipientStrings = ns.<String>getList("recipient");
62 final var groupIdStrings = ns.<String>getList("group-id");
63 final var usernameStrings = ns.<String>getList("username");
64
65 final var recipientIdentifiers = CommandUtil.getRecipientIdentifiers(m,
66 isNoteToSelf,
67 recipientStrings,
68 groupIdStrings,
69 usernameStrings);
70
71 final var emoji = ns.getString("emoji");
72 final var isRemove = Boolean.TRUE.equals(ns.getBoolean("remove"));
73 final var targetAuthor = ns.getString("target-author");
74 final var targetTimestamp = ns.getLong("target-timestamp");
75 final var isStory = Boolean.TRUE.equals(ns.getBoolean("story"));
76
77 try {
78 final var results = m.sendMessageReaction(emoji,
79 isRemove,
80 CommandUtil.getSingleRecipientIdentifier(targetAuthor, m.getSelfNumber()),
81 targetTimestamp,
82 recipientIdentifiers,
83 isStory);
84 outputResult(outputWriter, results);
85 } catch (GroupNotFoundException | NotAGroupMemberException | GroupSendingNotAllowedException e) {
86 throw new UserErrorException(e.getMessage());
87 } catch (IOException e) {
88 throw new UnexpectedErrorException("Failed to send message: " + e.getMessage() + " (" + e.getClass()
89 .getSimpleName() + ")", e);
90 } catch (UnregisteredRecipientException e) {
91 throw new UserErrorException("The user " + e.getSender().getIdentifier() + " is not registered.");
92 }
93 }
94 }