// SPDX-FileCopyrightText: 2023 Paul Schaub // // SPDX-License-Identifier: Apache-2.0 package sop.external.operation; import sop.Ready; import sop.enums.InlineSignAs; import sop.exception.SOPGPException; import sop.external.ExternalSOP; import sop.operation.InlineSign; import javax.annotation.Nonnull; import java.io.IOException; import java.io.InputStream; import java.util.ArrayList; import java.util.List; import java.util.Properties; /** * Implementation of the {@link InlineSign} operation using an external SOP binary. */ public class InlineSignExternal implements InlineSign { private final List commandList = new ArrayList<>(); private final List envList; private int keyCounter = 0; private int withKeyPasswordCounter = 0; public InlineSignExternal(String binary, Properties environment) { commandList.add(binary); commandList.add("inline-sign"); envList = ExternalSOP.propertiesToEnv(environment); } @Override @Nonnull public InlineSign noArmor() { commandList.add("--no-armor"); return this; } @Override @Nonnull public InlineSign key(@Nonnull InputStream key) throws SOPGPException.KeyCannotSign, SOPGPException.BadData, SOPGPException.UnsupportedAsymmetricAlgo, IOException { String envVar = "KEY_" + keyCounter++; commandList.add("@ENV:" + envVar); envList.add(envVar + "=" + ExternalSOP.readString(key)); return this; } @Override @Nonnull public InlineSign withKeyPassword(@Nonnull byte[] password) throws SOPGPException.UnsupportedOption, SOPGPException.PasswordNotHumanReadable { String envVar = "WITH_KEY_PASSWORD_" + withKeyPasswordCounter++; commandList.add("--with-key-password=@ENV:" + envVar); envList.add(envVar + "=" + new String(password)); return this; } @Override @Nonnull public InlineSign mode(@Nonnull InlineSignAs mode) throws SOPGPException.UnsupportedOption { commandList.add("--as=" + mode); return this; } @Override @Nonnull public Ready data(@Nonnull InputStream data) throws SOPGPException.KeyIsProtected, SOPGPException.ExpectedText { return ExternalSOP.executeTransformingOperation(Runtime.getRuntime(), commandList, envList, data); } }