import org.asamk.signal.commands.exceptions.CommandException;
import org.asamk.signal.jsonrpc.SignalJsonRpcDispatcherHandler;
import org.asamk.signal.manager.Manager;
-import org.asamk.signal.manager.api.ReceiveConfig;
+import org.asamk.signal.manager.MultiAccountManager;
import org.asamk.signal.output.JsonWriter;
import org.asamk.signal.output.OutputWriter;
import org.asamk.signal.util.IOUtils;
import java.util.List;
import java.util.function.Supplier;
-public class JsonRpcDispatcherCommand implements LocalCommand {
+import static org.asamk.signal.util.CommandUtil.getReceiveConfig;
+
+public class JsonRpcDispatcherCommand implements LocalCommand, MultiLocalCommand {
private final static Logger logger = LoggerFactory.getLogger(JsonRpcDispatcherCommand.class);
handler.handleConnection(m);
}
- private static ReceiveConfig getReceiveConfig(final Namespace ns) {
- final var ignoreAttachments = Boolean.TRUE.equals(ns.getBoolean("ignore-attachments"));
- final var ignoreStories = Boolean.TRUE.equals(ns.getBoolean("ignore-stories"));
- final var sendReadReceipts = Boolean.TRUE.equals(ns.getBoolean("send-read-receipts"));
- return new ReceiveConfig(ignoreAttachments, ignoreStories, sendReadReceipts);
+ @Override
+ public void handleCommand(
+ final Namespace ns, final MultiAccountManager c, final OutputWriter outputWriter
+ ) throws CommandException {
+ final var receiveMode = ns.<ReceiveMode>get("receive-mode");
+ final var receiveConfig = getReceiveConfig(ns);
+ c.getManagers().forEach(m -> m.setReceiveConfig(receiveConfig));
+ c.addOnManagerAddedHandler(m -> m.setReceiveConfig(receiveConfig));
+
+ final var jsonOutputWriter = (JsonWriter) outputWriter;
+ final var lineSupplier = getLineSupplier();
+
+ final var handler = new SignalJsonRpcDispatcherHandler(jsonOutputWriter,
+ lineSupplier,
+ receiveMode == ReceiveMode.MANUAL);
+ handler.handleConnection(c);
}
private static Supplier<String> getLineSupplier() {