Cleanups and proper logging.

This commit is contained in:
infra 2021-04-28 01:15:53 -04:00
parent ee99815918
commit 9d3dc8f735

View file

@ -8,9 +8,13 @@ import net.sourceforge.argparse4j.inf.Namespace;
import net.sourceforge.argparse4j.inf.Subparser; import net.sourceforge.argparse4j.inf.Subparser;
import org.asamk.signal.JsonReceiveMessageHandler; import org.asamk.signal.JsonReceiveMessageHandler;
import org.asamk.signal.JsonWriter;
import org.asamk.signal.OutputType;
import org.asamk.signal.ReceiveMessageHandler; import org.asamk.signal.ReceiveMessageHandler;
import org.asamk.signal.manager.AttachmentInvalidException; import org.asamk.signal.manager.AttachmentInvalidException;
import org.asamk.signal.manager.Manager; import org.asamk.signal.manager.Manager;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.whispersystems.signalservice.api.push.exceptions.EncapsulatedExceptions; import org.whispersystems.signalservice.api.push.exceptions.EncapsulatedExceptions;
import org.whispersystems.signalservice.api.util.InvalidNumberException; import org.whispersystems.signalservice.api.util.InvalidNumberException;
@ -19,6 +23,7 @@ import java.io.IOException;
import java.io.InputStreamReader; import java.io.InputStreamReader;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.Set;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
import static org.asamk.signal.util.ErrorUtils.handleAssertionError; import static org.asamk.signal.util.ErrorUtils.handleAssertionError;
@ -32,6 +37,7 @@ class JsonInterface {
} }
class InputReader implements Runnable { class InputReader implements Runnable {
private final static Logger logger = LoggerFactory.getLogger(InputReader.class);
private volatile boolean alive = true; private volatile boolean alive = true;
private final Manager m; private final Manager m;
@ -66,11 +72,11 @@ class InputReader implements Runnable {
} }
try { try {
// verbosity flag? better yet, json acknowledgement with timestamp or message id? // verbosity flag? better yet, json acknowledgement with timestamp or message id?
System.out.println("sentMessage '" + command.content + "' to " + command.recipient);
this.m.sendMessage(command.content, attachments, recipients); this.m.sendMessage(command.content, attachments, recipients);
logger.info("sentMessage '" + command.content + "' to " + command.recipient);
} catch (AssertionError | AttachmentInvalidException | InvalidNumberException e) { } catch (AssertionError | AttachmentInvalidException | InvalidNumberException e) {
System.err.println("error in sending message"); logger.error("Error in sending message", e);
e.printStackTrace(System.out); logger.error(e.getMessage(), e);
} }
} /* elif (command.commandName == "sendTyping") { } /* elif (command.commandName == "sendTyping") {
getMessageSender().sendTyping(signalServiceAddress?, ....) getMessageSender().sendTyping(signalServiceAddress?, ....)
@ -87,19 +93,26 @@ class InputReader implements Runnable {
} }
public class StdioCommand implements LocalCommand { public class StdioCommand implements LocalCommand {
private final static Logger logger = LoggerFactory.getLogger(StdioCommand.class);
@Override @Override
public void attachToSubparser(final Subparser subparser) { public void attachToSubparser(final Subparser subparser) {
subparser.addArgument("--ignore-attachments") subparser.addArgument("--ignore-attachments")
.help("Dont download attachments of received messages.") .help("Dont download attachments of received messages.")
.action(Arguments.storeTrue()); .action(Arguments.storeTrue());
subparser.addArgument("--json") // should maybe remove this subparser.addArgument("--json")
.help("Output received messages in json format, one json object per line.") .help("WARNING: This parameter is now deprecated! Please use the global \"--output=json\" option instead.\n\nOutput received messages in json format, one json object per line.")
.action(Arguments.storeTrue()); .action(Arguments.storeTrue());
} }
@Override
public Set<OutputType> getSupportedOutputTypes() {
return Set.of(OutputType.PLAIN_TEXT, OutputType.JSON);
}
@Override @Override
public void handleCommand(final Namespace ns, final Manager m) { public void handleCommand(final Namespace ns, final Manager m) {
var inJson = ns.get("output") == OutputType.JSON || ns.getBoolean("json");
boolean ignoreAttachments = ns.getBoolean("ignore_attachments"); boolean ignoreAttachments = ns.getBoolean("ignore_attachments");
InputReader reader = new InputReader(m); InputReader reader = new InputReader(m);
Thread readerThread = new Thread(reader); Thread readerThread = new Thread(reader);
@ -109,7 +122,7 @@ public class StdioCommand implements LocalCommand {
TimeUnit.HOURS, TimeUnit.HOURS,
false, false,
ignoreAttachments, ignoreAttachments,
ns.getBoolean("json") ? new JsonReceiveMessageHandler(m) : new ReceiveMessageHandler(m) inJson ? new JsonReceiveMessageHandler(m) : new ReceiveMessageHandler(m)
/*true*/); /*true*/);
} catch (IOException e) { } catch (IOException e) {
System.err.println("Error while receiving messages: " + e.getMessage()); System.err.println("Error while receiving messages: " + e.getMessage());