com.amazon.titan.diskstorage.dynamodb.builder.AbstractBuilder Maven / Gradle / Ivy
/*
* Copyright 2014-2015 Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file 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.amazon.titan.diskstorage.dynamodb.builder;
import java.nio.ByteBuffer;
import java.util.Arrays;
import java.util.Map;
import org.apache.commons.codec.DecoderException;
import org.apache.commons.codec.binary.Hex;
import com.amazon.titan.diskstorage.dynamodb.Constants;
import com.amazonaws.services.dynamodbv2.model.AttributeValue;
import com.thinkaurelius.titan.diskstorage.StaticBuffer;
import com.thinkaurelius.titan.diskstorage.util.BufferUtil;
import com.thinkaurelius.titan.diskstorage.util.StaticArrayBuffer;
/**
* AbstractBuilder is responsible for some of the StaticBuffer to String and
* visa-versa required for working with the database.
*
* @author Matthew Sowders
* @author Alexander Patrikalakis
*
*/
public abstract class AbstractBuilder {
protected AttributeValue encodeKeyAsAttributeValue(StaticBuffer input) {
return new AttributeValue().withS(encodeKeyBuffer(input));
}
public static String encodeKeyBuffer(StaticBuffer input) {
if (input == null || input.length() == 0) {
return null;
}
ByteBuffer buf = input.asByteBuffer();
byte[] bytes = Arrays.copyOf(buf.array(), buf.limit());
return Hex.encodeHexString(bytes);
}
protected AttributeValue encodeValue(StaticBuffer value) {
// Dynamo does not allow empty binary values, so we use a placeholder
// for empty values
if (value.length() <= 0) {
return new AttributeValue().withS(Constants.EMPTY_BUFFER_PLACEHOLDER);
}
return new AttributeValue().withB(value.asByteBuffer());
}
protected StaticBuffer decodeValue(AttributeValue val) {
if (null == val) {
return null;
}
// Dynamo does not allow empty binary values, so we use a placeholder
// for empty values
if (Constants.EMPTY_BUFFER_PLACEHOLDER.equals(val.getS())) {
return BufferUtil.emptyBuffer();
}
return StaticArrayBuffer.of(val.getB());
}
protected StaticBuffer decodeKey(Map key, String name) {
if (null == key || !key.containsKey(name)) {
return null;
}
AttributeValue attributeValue = key.get(name);
String value = attributeValue.getS();
return decodeKey(value);
}
public static StaticBuffer decodeKey(String name) {
try {
return new StaticArrayBuffer(Hex.decodeHex(name.toCharArray()));
} catch (DecoderException e) {
throw new RuntimeException(e);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy