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 java.util.List;
import java.util.Map;
-import java.util.Set;
-public interface JsonRpcLocalCommand extends JsonRpcCommand<Map<String, Object>> {
-
- void handleCommand(Namespace ns, Manager m) throws CommandException;
+public interface JsonRpcLocalCommand extends JsonRpcCommand<Map<String, Object>>, LocalCommand {
default TypeReference<Map<String, Object>> getRequestType() {
return new TypeReference<>() {
};
}
- default void handleCommand(Map<String, Object> request, Manager m) throws CommandException {
+ default void handleCommand(
+ Map<String, Object> request, Manager m, OutputWriter outputWriter
+ ) throws CommandException {
Namespace commandNamespace = new JsonRpcNamespace(request == null ? Map.of() : request);
- handleCommand(commandNamespace, m);
+ handleCommand(commandNamespace, m, outputWriter);
}
- default Set<OutputType> getSupportedOutputTypes() {
- return Set.of(OutputType.PLAIN_TEXT, OutputType.JSON);
+ default List<OutputType> getSupportedOutputTypes() {
+ return List.of(OutputType.PLAIN_TEXT, OutputType.JSON);
}
/**
super(attrs);
}
+ @Override
public <T> T get(String dest) {
final T value = super.get(dest);
if (value != null) {
@Override
public <E> List<E> getList(final String dest) {
- final List<E> value = super.getList(dest);
- if (value != null) {
- return value;
+ try {
+ final List<E> value = super.getList(dest);
+ if (value != null) {
+ return value;
+ }
+ } catch (ClassCastException e) {
+ return List.of(this.<E>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;
- }
}
}