com.mongodb.internal.crypt.capi.MongoCryptContext Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of mongodb-crypt Show documentation
Show all versions of mongodb-crypt Show documentation
MongoDB client-side crypto support
/*
* Copyright 2008-present MongoDB, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
package com.mongodb.internal.crypt.capi;
import com.mongodb.crypt.capi.MongoCryptException;
import org.bson.BsonDocument;
import org.bson.RawBsonDocument;
import java.io.Closeable;
/**
* An interface representing the lifecycle of an encryption or decryption request. It's modelled as a state machine.
*/
public interface MongoCryptContext extends Closeable {
/**
* The possible states.
*/
enum State {
/**
* Needs collection information from the cluster encrypting to
*/
NEED_MONGO_COLLINFO(CAPI.MONGOCRYPT_CTX_NEED_MONGO_COLLINFO),
/**
* Need to mark command with encryption markers
*/
NEED_MONGO_MARKINGS(CAPI.MONGOCRYPT_CTX_NEED_MONGO_MARKINGS),
/**
* Need keys from the key vault
*/
NEED_MONGO_KEYS(CAPI.MONGOCRYPT_CTX_NEED_MONGO_KEYS),
/**
* Need the key management service
*/
NEED_KMS(CAPI.MONGOCRYPT_CTX_NEED_KMS),
/**
* Need to fetch/renew KMS credentials
* @since 1.4
*/
NEED_KMS_CREDENTIALS(CAPI.MONGOCRYPT_CTX_NEED_KMS_CREDENTIALS),
/**
* Ready for encryption/decryption
*/
READY(CAPI.MONGOCRYPT_CTX_READY),
/**
* Done
*/
DONE(CAPI.MONGOCRYPT_CTX_DONE);
private final int index;
State(final int index) {
this.index = index;
}
static State fromIndex(final int index) {
for (State state : State.values()) {
if (state.index == index) {
return state;
}
}
throw new MongoCryptException("Unknown context state " + index);
}
}
/**
* Gets the current state.
*
* @return the current state
*/
State getState();
/**
*
* @return the operation to execute
*/
RawBsonDocument getMongoOperation();
/**
*
* @param document a result of the operation
*/
void addMongoOperationResult(BsonDocument document);
/**
* Signal completion of the operation
*/
void completeMongoOperation();
/**
* Provide KMS credentials on demand, in response to NEED_KMS_CREDENTIALS state
*
* @param credentialsDocument document containing all credentials
* @since 1.4
*/
void provideKmsProviderCredentials(BsonDocument credentialsDocument);
/**
*
* @return the next key decryptor, or null if there are no more
*/
MongoKeyDecryptor nextKeyDecryptor();
/**
* Indicate that all key decryptors have been completed
*/
void completeKeyDecryptors();
/**
*
* @return the encrypted or decrypted document
*/
RawBsonDocument finish();
@Override
void close();
}