All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.quarkus.vault.VaultTransitSecretEngine Maven / Gradle / Ivy

package io.quarkus.vault;

import java.util.List;
import java.util.Map;

import io.quarkus.vault.transit.ClearData;
import io.quarkus.vault.transit.DecryptionRequest;
import io.quarkus.vault.transit.EncryptionRequest;
import io.quarkus.vault.transit.KeyConfigRequestDetail;
import io.quarkus.vault.transit.KeyCreationRequestDetail;
import io.quarkus.vault.transit.RewrappingRequest;
import io.quarkus.vault.transit.SigningInput;
import io.quarkus.vault.transit.SigningRequest;
import io.quarkus.vault.transit.TransitContext;
import io.quarkus.vault.transit.VaultDecryptionBatchException;
import io.quarkus.vault.transit.VaultEncryptionBatchException;
import io.quarkus.vault.transit.VaultRewrappingBatchException;
import io.quarkus.vault.transit.VaultSigningBatchException;
import io.quarkus.vault.transit.VaultTransitKeyExportDetail;
import io.quarkus.vault.transit.VaultVerificationBatchException;
import io.quarkus.vault.transit.VerificationRequest;

/**
 * A service that interacts with Hashicorp's Vault Transit secret engine to encrypt, decrypt and sign arbitrary data.
 *
 * @see Transit Secrets Engine
 */
public interface VaultTransitSecretEngine {

    /**
     * Encrypt a regular string with a Vault key configured in the transit secret engine.
     * Equivalent to:
     * {@code encrypt(keyName, ClearData.from(clearData), null);}
     * 

* This method is usually used in conjunction with {@link #decrypt(String, String)} * * @param keyName the key to encrypt the data with * @param clearData the string to encrypt * @return cipher text * @see encrypt data */ String encrypt(String keyName, String clearData); /** * Encrypt a regular string with a Vault key configured in the transit secret engine. * If the key does not exist, and the policy specifies a create capability the key will be lazily created * (i.e. upsert). The key can be further customized by specifying transit encryption-key configuration * properties. * * @param keyName the key to encrypt the data with * @param clearData the data to encrypt * @param transitContext optional transit context used for key derivation * @return cipher text * @see encrypt data */ String encrypt(String keyName, ClearData clearData, TransitContext transitContext); /** * Encrypt a list of elements. This will return a list of cipher texts. * Each element shall specify the data to encrypt, an optional key version * and an optional transit context, used for key derivation if applicable. * If any error occurs, the service will throw a {@link VaultEncryptionBatchException} * * @param keyName the key to encrypt the data with * @param requests the list of elements to encrypt * @return a map of each request and its corresponding cipher text * @see encrypt data */ Map encrypt(String keyName, List requests); /** * Decrypt the encrypted data with the specified key, and return unencrypted data. * * @param keyName the key that was used to encrypt the original data * @param ciphertext the encrypted data * @return the unencrypted data * @see decrypt data */ ClearData decrypt(String keyName, String ciphertext); /** * Decrypt the encrypted data with the specified key and a transit context used for key derivation. * * @param keyName the key that was used to encrypt the original data * @param ciphertext data to decrypt * @param transitContext optional transit context used for key derivation * @return the unencrypted data * @see decrypt data * @see create key derived attribute */ ClearData decrypt(String keyName, String ciphertext, TransitContext transitContext); /** * Decrypt a list of encrypted data items. Each item shall specify the encrypted data plus an optional transit * context used for key derivation (if applicable). * If any error occurs, the service will throw a {@link VaultDecryptionBatchException} * * @param keyName the key that was used to encrypt the original data * @param requests the list of encrypted data items * @return a map of each request with its corresponding decrypted data item * @see decrypt data */ Map decrypt(String keyName, List requests); /** * Reencrypt into a new cipher text a cipher text that was obtained from encryption using an old key version * with the last key version * * @param keyName the encryption key that was used for the previous encryption * @param ciphertext the old cipher text that needs rewrapping * @return the reencrypted cipher text with last key version as a new cipher text * @see rewrap data * @see working set * management */ String rewrap(String keyName, String ciphertext); /** * Reencrypt into a new cipher text a cipher text that was obtained from encryption using an old key version * with the last key version and an optional transit context used for key derivation * * @param keyName the encryption key that was used for the previous encryption * @param ciphertext the old cipher text that needs rewrapping * @param transitContext optional transit context used for key derivation * @return the reencrypted cipher text with last key version as a new cipher text * @see rewrap data * @see working set * management */ String rewrap(String keyName, String ciphertext, TransitContext transitContext); /** * Reencrypt a list of encrypted data items with the last version of the specified key. * Each item shall specify a cipher text to reencrypt, an optional key version, and an optional transit context * used for key derivation, if applicable. * If any error occurs, the service will throw a {@link VaultRewrappingBatchException} * * @param keyName the encryption key that was used for the previous encryptions * @param requests the list of items to reencrypt * @return a map of each request with its corresponding reencrypted data item * @see rewrap data * @see working set * management */ Map rewrap(String keyName, List requests); /** * Sign an input string with the specified key. * * @param keyName the signing key to use * @param input String to sign * @return the signature * @see sign data */ String sign(String keyName, String input); /** * Sign the input with the specified key and an optional transit context used for key derivation, if applicable. * * @param keyName the signing key to use * @param input data to sign * @param transitContext optional transit context used for key derivation * @return the signature * @see sign data */ String sign(String keyName, SigningInput input, TransitContext transitContext); /** * Sign a list of inputs items. Each item shall specify the input to sign, an optional key version, and * an optional transit context used for ky derivation, if applicable. * If any error occurs, the service will throw a {@link VaultSigningBatchException} * * @param keyName the signing key to use * @param requests the list of inputs to sign * @return a map of each request with its corresponding signature item * @see sign data */ Map sign(String keyName, List requests); /** * Checks that the signature was obtained from signing the input with the specified key. * The service will throw a {@link VaultException} if this is not the case. * * @param keyName the key that was used to sign the input * @param signature the signature obtained from one of the sign methods * @param input the original input data * @see verify signed data */ void verifySignature(String keyName, String signature, String input); /** * Checks that the signature was obtained from signing the input with the specified key. * The service will throw a {@link VaultException} if this is not the case. * * @param keyName the key that was used to sign the input * @param signature the signature obtained from one of the sign methods * @param input the original input data * @param transitContext optional transit context used for key derivation * @see verify signed data */ void verifySignature(String keyName, String signature, SigningInput input, TransitContext transitContext); /** * Checks a list of verification requests. Each request shall specify an input and the signature we want to match * against, and an optional transit context used for key derivation, if applicable. * If the signature does not match, or if any other error occurs, * the service will throw a {@link VaultVerificationBatchException} * * @param keyName the key that was used to sign the input * @param requests a list of items specifying an input and a signature to match against * @see verify signed data */ void verifySignature(String keyName, List requests); // --- admin operations /** * Create a new Transit key. * * @param keyName key name * @param detail key creation detail or null * @see create key */ void createKey(String keyName, KeyCreationRequestDetail detail); /** * Update the configuration of a Transit key. The key must exist. * * @param keyName key name * @param detail key configuration detail * @see update key configuration */ void updateKeyConfiguration(String keyName, KeyConfigRequestDetail detail); /** * Delete a Transit key. Key must have been configured with deletion allowed. The key must exist. * * @param keyName key name * @see delete key */ void deleteKey(String keyName); /** * Export a Transit Key. Key must have made exportable through creation or configuration update. * The key must exist. * * @param keyName name of the key * @param keyType key type * @param keyVersion null, "latest" or a valid version number as a String. If null all versions will be returned * @return All specified key versions * @see export key */ VaultTransitKeyExportDetail exportKey(String keyName, VaultTransitExportKeyType keyType, String keyVersion); /** * Read the configuration of a Transit key. * * @param keyName key name * @return key detail, or null if the key does not exist * @see read key */ VaultTransitKeyDetail readKey(String keyName); /** * List all Transit keys. * * @return key names * @see list keys */ List listKeys(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy