From: AsamK Date: Wed, 12 May 2021 19:26:57 +0000 (+0200) Subject: Add --service-environment to allow testing against sandbox environment X-Git-Tag: v0.8.3~5 X-Git-Url: https://git.nmode.ca/signal-cli/commitdiff_plain/db756bfe10ab302d9991e68ec4b5ed34230d39e2?ds=sidebyside Add --service-environment to allow testing against sandbox environment --- diff --git a/src/main/java/org/asamk/signal/App.java b/src/main/java/org/asamk/signal/App.java index 5c19a403..521e453a 100644 --- a/src/main/java/org/asamk/signal/App.java +++ b/src/main/java/org/asamk/signal/App.java @@ -55,7 +55,7 @@ public class App { parser.addArgument("--config") .help("Set the path, where to store the config (Default: $XDG_DATA_HOME/signal-cli , $HOME/.local/share/signal-cli)."); - parser.addArgument("-u", "--username").help("Specify your phone number, that will be used for verification."); + parser.addArgument("-u", "--username").help("Specify your phone number, that will be your identifier."); var mut = parser.addMutuallyExclusiveGroup(); mut.addArgument("--dbus").help("Make request via user dbus.").action(Arguments.storeTrue()); @@ -66,6 +66,11 @@ public class App { .type(Arguments.enumStringType(OutputType.class)) .setDefault(OutputType.PLAIN_TEXT); + parser.addArgument("--service-environment") + .help("Choose the server environment to use, SANDBOX or LIVE.") + .type(Arguments.enumStringType(ServiceEnvironmentCli.class)) + .setDefault(ServiceEnvironmentCli.LIVE); + var subparsers = parser.addSubparsers().title("subcommands").dest("command"); final var commands = Commands.getCommands(); @@ -88,15 +93,15 @@ public class App { throw new UserErrorException("Command not implemented!"); } - OutputType outputType = ns.get("output"); + var outputType = ns.get("output"); if (!command.getSupportedOutputTypes().contains(outputType)) { throw new UserErrorException("Command doesn't support output type " + outputType.toString()); } var username = ns.getString("username"); - final boolean useDbus = ns.getBoolean("dbus"); - final boolean useDbusSystem = ns.getBoolean("dbus_system"); + final var useDbus = ns.getBoolean("dbus"); + final var useDbusSystem = ns.getBoolean("dbus_system"); if (useDbus || useDbusSystem) { // If username is null, it will connect to the default object path initDbusClient(command, username, useDbusSystem); @@ -111,7 +116,10 @@ public class App { dataPath = getDefaultDataPath(); } - final var serviceEnvironment = ServiceEnvironment.LIVE; + final var serviceEnvironmentCli = ns.get("service_environment"); + final var serviceEnvironment = serviceEnvironmentCli == ServiceEnvironmentCli.LIVE + ? ServiceEnvironment.LIVE + : ServiceEnvironment.SANDBOX; if (!ServiceConfig.getCapabilities().isGv2()) { logger.warn("WARNING: Support for new group V2 is disabled," diff --git a/src/main/java/org/asamk/signal/ServiceEnvironmentCli.java b/src/main/java/org/asamk/signal/ServiceEnvironmentCli.java new file mode 100644 index 00000000..6e8334b0 --- /dev/null +++ b/src/main/java/org/asamk/signal/ServiceEnvironmentCli.java @@ -0,0 +1,16 @@ +package org.asamk.signal; + +public enum ServiceEnvironmentCli { + LIVE { + @Override + public String toString() { + return "live"; + } + }, + SANDBOX { + @Override + public String toString() { + return "sandbox"; + } + }, +}