X-Git-Url: https://git.nmode.ca/signal-cli/blobdiff_plain/8c661c23be6e2232af902f0d20cd7e747077ab9d..43face8ead95344e3d0dcbc94c6cf85959f26203:/src/main/java/org/asamk/signal/commands/JsonRpcLocalCommand.java diff --git a/src/main/java/org/asamk/signal/commands/JsonRpcLocalCommand.java b/src/main/java/org/asamk/signal/commands/JsonRpcLocalCommand.java index 24b45ee8..d87b97cd 100644 --- a/src/main/java/org/asamk/signal/commands/JsonRpcLocalCommand.java +++ b/src/main/java/org/asamk/signal/commands/JsonRpcLocalCommand.java @@ -5,73 +5,27 @@ import com.fasterxml.jackson.core.type.TypeReference; import net.sourceforge.argparse4j.inf.Namespace; import org.asamk.signal.OutputType; -import org.asamk.signal.OutputWriter; import org.asamk.signal.commands.exceptions.CommandException; import org.asamk.signal.manager.Manager; -import org.asamk.signal.util.Util; +import org.asamk.signal.output.JsonWriter; import java.util.List; import java.util.Map; -public interface JsonRpcLocalCommand extends JsonRpcCommand>, LocalCommand { +public interface JsonRpcLocalCommand extends JsonRpcSingleCommand>, LocalCommand { default TypeReference> getRequestType() { - return new TypeReference<>() { - }; + return new TypeReference<>() {}; } default void handleCommand( - Map request, Manager m, OutputWriter outputWriter + Map request, Manager m, JsonWriter jsonWriter ) throws CommandException { Namespace commandNamespace = new JsonRpcNamespace(request == null ? Map.of() : request); - handleCommand(commandNamespace, m, outputWriter); + handleCommand(commandNamespace, m, jsonWriter); } default List getSupportedOutputTypes() { return List.of(OutputType.PLAIN_TEXT, OutputType.JSON); } - - /** - * Namepace implementation, that defaults booleans to false and converts camel case keys to dashed strings - */ - final class JsonRpcNamespace extends Namespace { - - public JsonRpcNamespace(final Map attrs) { - super(attrs); - } - - @Override - public T get(String dest) { - final T value = super.get(dest); - if (value != null) { - return value; - } - - final var camelCaseString = Util.dashSeparatedToCamelCaseString(dest); - return super.get(camelCaseString); - } - - @Override - public List getList(final String dest) { - try { - final List value = super.getList(dest); - if (value != null) { - return value; - } - } catch (ClassCastException e) { - return List.of(this.get(dest)); - } - - return super.getList(dest + "s"); - } - - @Override - public Boolean getBoolean(String dest) { - Boolean maybeGotten = this.get(dest); - if (maybeGotten == null) { - maybeGotten = false; - } - return maybeGotten; - } - } }