X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/2c0ad7feb7c2cfcacf40d7aa9192a654d11ab059..d84362eb0f022d8bd22321afb5f082b3881f316c:/src/main/java/org/asamk/signal/commands/SendMessageRequestResponseCommand.java diff --git a/src/main/java/org/asamk/signal/commands/SendMessageRequestResponseCommand.java b/src/main/java/org/asamk/signal/commands/SendMessageRequestResponseCommand.java new file mode 100644 index 00000000..146ebaf2 --- /dev/null +++ b/src/main/java/org/asamk/signal/commands/SendMessageRequestResponseCommand.java @@ -0,0 +1,49 @@ +package org.asamk.signal.commands; + +import net.sourceforge.argparse4j.impl.Arguments; +import net.sourceforge.argparse4j.inf.Namespace; +import net.sourceforge.argparse4j.inf.Subparser; + +import org.asamk.signal.commands.exceptions.CommandException; +import org.asamk.signal.manager.Manager; +import org.asamk.signal.manager.api.MessageEnvelope.Sync.MessageRequestResponse.Type; +import org.asamk.signal.output.OutputWriter; +import org.asamk.signal.util.CommandUtil; + +public class SendMessageRequestResponseCommand implements JsonRpcLocalCommand { + + @Override + public String getName() { + return "sendMessageRequestResponse"; + } + + @Override + public void attachToSubparser(final Subparser subparser) { + subparser.help("Send response to a message request to linked devices."); + subparser.addArgument("-g", "--group-id", "--group").help("Specify the recipient group ID.").nargs("*"); + subparser.addArgument("recipient").help("Specify the recipients' phone number.").nargs("*"); + subparser.addArgument("-u", "--username").help("Specify the recipient username or username link.").nargs("*"); + subparser.addArgument("--type") + .help("Type of message request response") + .type(Arguments.enumStringType(MessageRequestResponseType.class)) + .required(true); + } + + @Override + public void handleCommand( + final Namespace ns, final Manager m, final OutputWriter outputWriter + ) throws CommandException { + final var recipientStrings = ns.getList("recipient"); + final var groupIdStrings = ns.getList("group-id"); + final var usernameStrings = ns.getList("username"); + final var type = ns.get("type"); + + final var recipientIdentifiers = CommandUtil.getRecipientIdentifiers(m, + false, + recipientStrings, + groupIdStrings, + usernameStrings); + m.sendMessageRequestResponse(type == MessageRequestResponseType.ACCEPT ? Type.ACCEPT : Type.DELETE, + recipientIdentifiers); + } +}