import net.sourceforge.argparse4j.inf.Subparser;
import org.asamk.signal.OutputType;
+import org.asamk.signal.Shutdown;
import org.asamk.signal.commands.exceptions.CommandException;
import org.asamk.signal.jsonrpc.SignalJsonRpcDispatcherHandler;
import org.asamk.signal.manager.Manager;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
+import java.io.FileDescriptor;
+import java.io.FileInputStream;
import java.io.InputStreamReader;
+import java.nio.channels.Channels;
import java.util.List;
import java.util.function.Supplier;
public class JsonRpcDispatcherCommand implements LocalCommand, MultiLocalCommand {
- private final static Logger logger = LoggerFactory.getLogger(JsonRpcDispatcherCommand.class);
+ private static final Logger logger = LoggerFactory.getLogger(JsonRpcDispatcherCommand.class);
@Override
public String getName() {
@Override
public void handleCommand(
- final Namespace ns, final Manager m, final OutputWriter outputWriter
+ final Namespace ns,
+ final Manager m,
+ final OutputWriter outputWriter
) throws CommandException {
+ Shutdown.installHandler();
final var receiveMode = ns.<ReceiveMode>get("receive-mode");
final var receiveConfig = getReceiveConfig(ns);
m.setReceiveConfig(receiveConfig);
final var handler = new SignalJsonRpcDispatcherHandler(jsonOutputWriter,
lineSupplier,
receiveMode == ReceiveMode.MANUAL);
+ final var thread = Thread.currentThread();
+ Shutdown.registerShutdownListener(thread::interrupt);
handler.handleConnection(m);
}
@Override
public void handleCommand(
- final Namespace ns, final MultiAccountManager c, final OutputWriter outputWriter
+ final Namespace ns,
+ final MultiAccountManager c,
+ final OutputWriter outputWriter
) throws CommandException {
+ Shutdown.installHandler();
final var receiveMode = ns.<ReceiveMode>get("receive-mode");
final var receiveConfig = getReceiveConfig(ns);
c.getManagers().forEach(m -> m.setReceiveConfig(receiveConfig));
final var handler = new SignalJsonRpcDispatcherHandler(jsonOutputWriter,
lineSupplier,
receiveMode == ReceiveMode.MANUAL);
+ final var thread = Thread.currentThread();
+ Shutdown.registerShutdownListener(thread::interrupt);
handler.handleConnection(c);
}
private static Supplier<String> getLineSupplier() {
- return IOUtils.getLineSupplier(new InputStreamReader(System.in, IOUtils.getConsoleCharset()));
+ // Use FileChannel for stdin, because System.in is uninterruptible
+ final var stdInCh = Channels.newInputStream((new FileInputStream(FileDescriptor.in)).getChannel());
+ return IOUtils.getLineSupplier(new InputStreamReader(stdInCh, IOUtils.getConsoleCharset()));
}
}