import org.asamk.signal.commands.exceptions.IOErrorException;
import org.asamk.signal.commands.exceptions.UserErrorException;
import org.asamk.signal.manager.Manager;
+import org.asamk.signal.manager.api.DeviceLimitExceededException;
import org.asamk.signal.manager.api.DeviceLinkUrl;
import org.asamk.signal.manager.api.InvalidDeviceLinkException;
+import org.asamk.signal.manager.api.NotPrimaryDeviceException;
import org.asamk.signal.output.OutputWriter;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class AddDeviceCommand implements JsonRpcLocalCommand {
- private final static Logger logger = LoggerFactory.getLogger(AddDeviceCommand.class);
+ private static final Logger logger = LoggerFactory.getLogger(AddDeviceCommand.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 {
final URI linkUri;
try {
var deviceLinkUrl = DeviceLinkUrl.parseDeviceLinkUri(linkUri);
m.addDeviceLink(deviceLinkUrl);
} catch (IOException e) {
- logger.error("Add device link failed", e);
+ logger.error("Add device link failed: {}", e.getMessage());
throw new IOErrorException("Add device link failed", e);
} catch (InvalidDeviceLinkException e) {
- logger.error("Add device link failed", e);
- throw new UserErrorException("Add device link failed.", e);
+ logger.info("Invalid device link");
+ throw new UserErrorException("Invalid device link", e);
+ } catch (DeviceLimitExceededException e) {
+ throw new UserErrorException("Account has too many linked devices already", e);
+ } catch (NotPrimaryDeviceException e) {
+ throw new UserErrorException("This command doesn't work on linked devices.");
}
}
}