- private Thread run(
- DBusConnection conn, String objectPath, Manager m, OutputWriter outputWriter, boolean ignoreAttachments
- ) throws DBusException {
- final var signal = new DbusSignalImpl(m, conn, objectPath);
- conn.exportObject(signal);
- final var initThread = new Thread(signal::initObjects);
- initThread.start();
+ private void addDefaultReceiveHandler(Manager m, OutputWriter outputWriter, final boolean isWeakListener) {
+ final var handler = switch (outputWriter) {
+ case PlainTextWriter writer -> new ReceiveMessageHandler(m, writer);
+ case JsonWriter writer -> new JsonReceiveMessageHandler(m, writer);
+ case null -> Manager.ReceiveMessageHandler.EMPTY;
+ };
+ m.addReceiveHandler(handler, isWeakListener);
+ }
+
+ private static abstract class DaemonHandler implements AutoCloseable {
+
+ protected final ReceiveMode receiveMode;
+ protected final List<AutoCloseable> closeables = new ArrayList<>();
+
+ protected DaemonHandler(final ReceiveMode receiveMode) {
+ this.receiveMode = receiveMode;
+ }
+
+ public abstract void runSocket(ServerSocketChannel serverChannel) throws CommandException;
+
+ public abstract void runDbus(boolean isDbusSystem) throws CommandException;
+
+ public abstract void runHttp(InetSocketAddress address) throws CommandException;
+
+ protected final void runSocket(final SocketHandler socketHandler) {
+ socketHandler.init();
+ this.closeables.add(socketHandler);
+ }
+
+ protected final void runDbus(
+ DbusHandler dbusHandler
+ ) throws CommandException {
+ dbusHandler.init();
+ this.closeables.add(dbusHandler);
+ }