X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/55dde93811ac137741b49d3fab2483e689592038..22add1cbee357e988ca9c85d9d161fc783fd5fa3:/src/main/java/org/asamk/signal/commands/DeleteLocalAccountDataCommand.java diff --git a/src/main/java/org/asamk/signal/commands/DeleteLocalAccountDataCommand.java b/src/main/java/org/asamk/signal/commands/DeleteLocalAccountDataCommand.java new file mode 100644 index 00000000..51c8582d --- /dev/null +++ b/src/main/java/org/asamk/signal/commands/DeleteLocalAccountDataCommand.java @@ -0,0 +1,68 @@ +package org.asamk.signal.commands; + +import com.fasterxml.jackson.core.type.TypeReference; + +import net.sourceforge.argparse4j.impl.Arguments; +import net.sourceforge.argparse4j.inf.Namespace; +import net.sourceforge.argparse4j.inf.Subparser; + +import org.asamk.signal.OutputType; +import org.asamk.signal.commands.exceptions.CommandException; +import org.asamk.signal.commands.exceptions.IOErrorException; +import org.asamk.signal.commands.exceptions.UserErrorException; +import org.asamk.signal.manager.RegistrationManager; +import org.asamk.signal.output.JsonWriter; + +import java.io.IOException; +import java.util.List; +import java.util.Map; + +public class DeleteLocalAccountDataCommand implements RegistrationCommand, JsonRpcRegistrationCommand> { + + @Override + public String getName() { + return "deleteLocalAccountData"; + } + + @Override + public void attachToSubparser(final Subparser subparser) { + subparser.help( + "Delete all local data for this account. Data should only be deleted if the account is unregistered. CAUTION: This cannot be undone."); + subparser.addArgument("--ignore-registered") + .help("Delete the account data even though the account is still registered on the Signal servers.") + .action(Arguments.storeTrue()); + } + + @Override + public void handleCommand(final Namespace ns, final RegistrationManager m) throws CommandException { + try { + final var ignoreRegistered = Boolean.TRUE.equals(ns.getBoolean("ignore-registered")); + if (m.isRegistered() && !ignoreRegistered) { + throw new UserErrorException( + "Not deleting account, it is still registered. Use --ignore-registered to delete it anyway."); + } + + m.deleteLocalAccountData(); + } catch (IOException e) { + throw new IOErrorException("Deletion error: " + e.getMessage(), e); + } + } + + @Override + public TypeReference> getRequestType() { + return new TypeReference<>() {}; + } + + @Override + public List getSupportedOutputTypes() { + return List.of(OutputType.PLAIN_TEXT, OutputType.JSON); + } + + @Override + public void handleCommand( + Map request, RegistrationManager m, JsonWriter jsonWriter + ) throws CommandException { + Namespace commandNamespace = new JsonRpcNamespace(request == null ? Map.of() : request); + handleCommand(commandNamespace, m); + } +}