mirror of
https://codeberg.org/PGPainless/sop-java.git
synced 2024-06-18 01:25:06 +02:00
50 lines
1.5 KiB
Java
50 lines
1.5 KiB
Java
// SPDX-FileCopyrightText: 2021 Paul Schaub <vanitasvitae@fsfe.org>
|
|
//
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package sop.operation;
|
|
|
|
import sop.Ready;
|
|
import sop.exception.SOPGPException;
|
|
import sop.util.UTF8Util;
|
|
|
|
import java.io.InputStream;
|
|
|
|
public interface RevokeKey {
|
|
|
|
/**
|
|
* Disable ASCII armor encoding.
|
|
*
|
|
* @return builder instance
|
|
*/
|
|
RevokeKey noArmor();
|
|
|
|
/**
|
|
* Provide the decryption password for the secret key.
|
|
*
|
|
* @param password password
|
|
* @return builder instance
|
|
* @throws SOPGPException.UnsupportedOption if the implementation does not support key passwords
|
|
* @throws SOPGPException.PasswordNotHumanReadable if the password is not human-readable
|
|
*/
|
|
default RevokeKey withKeyPassword(String password)
|
|
throws SOPGPException.UnsupportedOption,
|
|
SOPGPException.PasswordNotHumanReadable {
|
|
return withKeyPassword(password.getBytes(UTF8Util.UTF8));
|
|
}
|
|
|
|
/**
|
|
* Provide the decryption password for the secret key.
|
|
*
|
|
* @param password password
|
|
* @return builder instance
|
|
* @throws SOPGPException.UnsupportedOption if the implementation does not support key passwords
|
|
* @throws SOPGPException.PasswordNotHumanReadable if the password is not human-readable
|
|
*/
|
|
RevokeKey withKeyPassword(byte[] password)
|
|
throws SOPGPException.UnsupportedOption,
|
|
SOPGPException.PasswordNotHumanReadable;
|
|
|
|
Ready keys(InputStream keys);
|
|
}
|