mirror of
https://github.com/AsamK/signal-cli
synced 2025-08-29 10:30:38 +00:00
45 lines
1.8 KiB
Java
45 lines
1.8 KiB
Java
package org.asamk.signal.commands;
|
|
|
|
import net.sourceforge.argparse4j.inf.Namespace;
|
|
import net.sourceforge.argparse4j.inf.Subparser;
|
|
|
|
import org.asamk.signal.commands.exceptions.CommandException;
|
|
import org.asamk.signal.commands.exceptions.IOErrorException;
|
|
import org.asamk.signal.commands.exceptions.UnexpectedErrorException;
|
|
import org.asamk.signal.commands.exceptions.UserErrorException;
|
|
import org.asamk.signal.manager.Manager;
|
|
import org.slf4j.Logger;
|
|
import org.slf4j.LoggerFactory;
|
|
import org.whispersystems.libsignal.InvalidKeyException;
|
|
|
|
import java.io.IOException;
|
|
import java.net.URI;
|
|
import java.net.URISyntaxException;
|
|
|
|
public class AddDeviceCommand implements LocalCommand {
|
|
|
|
private final static Logger logger = LoggerFactory.getLogger(AddDeviceCommand.class);
|
|
|
|
@Override
|
|
public void attachToSubparser(final Subparser subparser) {
|
|
subparser.help("Link another device to this device. Only works, if this is the master device.");
|
|
subparser.addArgument("--uri")
|
|
.required(true)
|
|
.help("Specify the uri contained in the QR code shown by the new device.");
|
|
}
|
|
|
|
@Override
|
|
public void handleCommand(final Namespace ns, final Manager m) throws CommandException {
|
|
try {
|
|
m.addDeviceLink(new URI(ns.getString("uri")));
|
|
} catch (IOException e) {
|
|
logger.error("Add device link failed", e);
|
|
throw new IOErrorException("Add device link failed");
|
|
} catch (URISyntaxException e) {
|
|
throw new UserErrorException("Device link uri has invalid format: {}" + e.getMessage());
|
|
} catch (InvalidKeyException e) {
|
|
logger.error("Add device link failed", e);
|
|
throw new UnexpectedErrorException("Add device link failed.");
|
|
}
|
|
}
|
|
}
|