com.facebook.presto.orc.TestingEncryptionLibrary Maven / Gradle / Ivy
The newest version!
/*
* 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.facebook.presto.orc;
import java.nio.Buffer;
import java.nio.ByteBuffer;
import java.util.Arrays;
import java.util.Base64;
import java.util.Base64.Decoder;
import static com.google.common.base.Verify.verify;
public class TestingEncryptionLibrary
implements EncryptionLibrary
{
private static final Base64.Encoder ENCODER = Base64.getUrlEncoder();
private static final Decoder DECODER = Base64.getUrlDecoder();
@Override
public byte[] generateDataEncryptionKey(byte[] intermediateKeyMetadata)
{
return intermediateKeyMetadata;
}
@Override
public byte[] encryptKey(byte[] keyMetadata, byte[] input, int offset, int length)
{
return encrypt(keyMetadata, input, offset, length);
}
@Override
public byte[] encryptData(byte[] keyMetadata, byte[] input, int offset, int length)
{
return encrypt(keyMetadata, input, offset, length);
}
@Override
public byte[] decryptKey(byte[] keyMetadata, byte[] input, int offset, int length)
{
return decrypt(keyMetadata, input, offset, length);
}
@Override
public byte[] decryptData(byte[] keyMetadata, byte[] input, int offset, int length)
{
return decrypt(keyMetadata, input, offset, length);
}
private byte[] encrypt(byte[] keyMetadata, byte[] input, int offset, int length)
{
ByteBuffer inputBuffer = ByteBuffer.wrap(input, offset, length);
ByteBuffer encoded = ENCODER.encode(inputBuffer);
ByteBuffer output = ByteBuffer.allocate(keyMetadata.length + encoded.remaining());
output.put(keyMetadata);
output.put(encoded);
((Buffer) output).flip();
byte[] encrypted = new byte[output.remaining()];
output.get(encrypted);
return encrypted;
}
private byte[] decrypt(byte[] keyMetadata, byte[] input, int offset, int length)
{
ByteBuffer inputBuffer = ByteBuffer.wrap(input, offset, length);
byte[] key = new byte[keyMetadata.length];
inputBuffer.get(key);
verify(Arrays.equals(keyMetadata, key), "keys do not match");
ByteBuffer encoded = ByteBuffer.allocate(inputBuffer.remaining());
encoded.put(inputBuffer);
((Buffer) encoded).flip();
ByteBuffer decodedByteBuffer = DECODER.decode(encoded);
byte[] decoded = new byte[decodedByteBuffer.remaining()];
decodedByteBuffer.get(decoded);
return decoded;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy