X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/c88c92086efcf5c0ad417589db997ef1a034e775..HEAD:/src/main/java/org/asamk/signal/commands/RemoveContactCommand.java diff --git a/src/main/java/org/asamk/signal/commands/RemoveContactCommand.java b/src/main/java/org/asamk/signal/commands/RemoveContactCommand.java index c4a3d7d8..253cb7ad 100644 --- a/src/main/java/org/asamk/signal/commands/RemoveContactCommand.java +++ b/src/main/java/org/asamk/signal/commands/RemoveContactCommand.java @@ -20,20 +20,29 @@ public class RemoveContactCommand implements JsonRpcLocalCommand { public void attachToSubparser(final Subparser subparser) { subparser.help("Remove the details of a given contact"); subparser.addArgument("recipient").help("Contact number"); - subparser.addArgument("--forget") + final var mut = subparser.addMutuallyExclusiveGroup(); + mut.addArgument("--hide") + .action(Arguments.storeTrue()) + .help("Hide the contact in the contact list, but keep the data."); + mut.addArgument("--forget") .action(Arguments.storeTrue()) .help("Delete all data associated with this contact, including identity keys and sessions."); } @Override public void handleCommand( - final Namespace ns, final Manager m, final OutputWriter outputWriter + final Namespace ns, + final Manager m, + final OutputWriter outputWriter ) throws CommandException { var recipientString = ns.getString("recipient"); var recipient = CommandUtil.getSingleRecipientIdentifier(recipientString, m.getSelfNumber()); + var hide = Boolean.TRUE == ns.getBoolean("hide"); var forget = Boolean.TRUE == ns.getBoolean("forget"); - if (forget) { + if (hide) { + m.hideRecipient(recipient); + } else if (forget) { m.deleteRecipient(recipient); } else { m.deleteContact(recipient);