mirror of
https://codeberg.org/PGPainless/sop-java.git
synced 2024-06-26 05:24:56 +02:00
Since picocli 4.7.0, subcommands inherit resources from their parent commands, so we can store shared stuff like error msgs etc. in the parent (sop) resources file. This enables us to rename the parent command downstream (e.g. in pgpainless-cli). Only the help command breaks when renaming the parent command. TODO: Fix
100 lines
3.5 KiB
Java
100 lines
3.5 KiB
Java
// SPDX-FileCopyrightText: 2022 Paul Schaub <vanitasvitae@fsfe.org>
|
|
//
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package sop.cli.picocli.commands;
|
|
|
|
import picocli.CommandLine;
|
|
import sop.Ready;
|
|
import sop.cli.picocli.SopCLI;
|
|
import sop.enums.InlineSignAs;
|
|
import sop.exception.SOPGPException;
|
|
import sop.operation.InlineSign;
|
|
|
|
import java.io.IOException;
|
|
import java.io.InputStream;
|
|
import java.util.ArrayList;
|
|
import java.util.List;
|
|
|
|
@CommandLine.Command(name = "inline-sign",
|
|
resourceBundle = "inline-sign",
|
|
exitCodeOnInvalidInput = 37)
|
|
public class InlineSignCmd extends AbstractSopCmd {
|
|
|
|
@CommandLine.Option(names = "--no-armor",
|
|
descriptionKey = "usage.option.armor",
|
|
negatable = true)
|
|
boolean armor = true;
|
|
|
|
@CommandLine.Option(names = "--as",
|
|
descriptionKey = "usage.option.as",
|
|
paramLabel = "{binary|text|cleartextsigned}")
|
|
InlineSignAs type;
|
|
|
|
@CommandLine.Parameters(descriptionKey = "usage.parameter.keys",
|
|
paramLabel = "KEYS")
|
|
List<String> secretKeyFile = new ArrayList<>();
|
|
|
|
@CommandLine.Option(names = "--with-key-password",
|
|
descriptionKey = "usage.option.with_key_password",
|
|
paramLabel = "PASSWORD")
|
|
List<String> withKeyPassword = new ArrayList<>();
|
|
|
|
@Override
|
|
public void run() {
|
|
InlineSign inlineSign = throwIfUnsupportedSubcommand(
|
|
SopCLI.getSop().inlineSign(), "inline-sign");
|
|
|
|
if (type != null) {
|
|
try {
|
|
inlineSign.mode(type);
|
|
} catch (SOPGPException.UnsupportedOption unsupportedOption) {
|
|
String errorMsg = getMsg("sop.error.feature_support.option_not_supported", "--as");
|
|
throw new SOPGPException.UnsupportedOption(errorMsg, unsupportedOption);
|
|
}
|
|
}
|
|
|
|
if (secretKeyFile.isEmpty()) {
|
|
String errorMsg = getMsg("sop.error.usage.parameter_required", "KEYS");
|
|
throw new SOPGPException.MissingArg(errorMsg);
|
|
}
|
|
|
|
for (String passwordFile : withKeyPassword) {
|
|
try {
|
|
String password = stringFromInputStream(getInput(passwordFile));
|
|
inlineSign.withKeyPassword(password);
|
|
} catch (SOPGPException.UnsupportedOption unsupportedOption) {
|
|
String errorMsg = getMsg("sop.error.feature_support.option_not_supported", "--with-key-password");
|
|
throw new SOPGPException.UnsupportedOption(errorMsg, unsupportedOption);
|
|
} catch (IOException e) {
|
|
throw new RuntimeException(e);
|
|
}
|
|
}
|
|
|
|
for (String keyInput : secretKeyFile) {
|
|
try (InputStream keyIn = getInput(keyInput)) {
|
|
inlineSign.key(keyIn);
|
|
} catch (IOException e) {
|
|
throw new RuntimeException(e);
|
|
} catch (SOPGPException.KeyIsProtected e) {
|
|
String errorMsg = getMsg("sop.error.runtime.cannot_unlock_key", keyInput);
|
|
throw new SOPGPException.KeyIsProtected(errorMsg, e);
|
|
} catch (SOPGPException.BadData badData) {
|
|
String errorMsg = getMsg("sop.error.input.not_a_private_key", keyInput);
|
|
throw new SOPGPException.BadData(errorMsg, badData);
|
|
}
|
|
}
|
|
|
|
if (!armor) {
|
|
inlineSign.noArmor();
|
|
}
|
|
|
|
try {
|
|
Ready ready = inlineSign.data(System.in);
|
|
ready.writeTo(System.out);
|
|
} catch (IOException e) {
|
|
throw new RuntimeException(e);
|
|
}
|
|
}
|
|
}
|