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

com.amazon.titan.diskstorage.dynamodb.builder.ConditionExpressionBuilder 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.util.HashMap;
import java.util.Map;

import com.amazon.titan.diskstorage.dynamodb.Constants;
import com.amazon.titan.diskstorage.dynamodb.Expression;
import com.amazonaws.services.dynamodbv2.model.AttributeValue;
import com.thinkaurelius.titan.diskstorage.StaticBuffer;

/**
 * ConditionExpressionBuilder is responsible for generating a KeyConditionExpressions used in the
 * DynamoDB scan and range queries.
 *
 * @author Alexander Patrikalakis
 * @author Matthew Sowders
 *
 */
public class ConditionExpressionBuilder extends AbstractBuilder {
    public static final String K = ":k";
    public static final String HASH_KEY_EQUALS = String.format("%s = %s", Constants.TITAN_HASH_KEY, K);
    private final Map conditionExpressions = new HashMap<>();
    private final Map expressionAttributeValues = new HashMap<>();

    public ConditionExpressionBuilder hashKey(StaticBuffer key) {
        // build up condition expression
        conditionExpressions.put(Constants.TITAN_HASH_KEY, HASH_KEY_EQUALS);

        // add the constants
        final AttributeValue av = new AttributeValue().withS(encodeKeyBuffer(key));
        if(!expressionAttributeValues.containsKey(K)) {
            expressionAttributeValues.put(K, av);
        } else {
            if(!expressionAttributeValues.get(K).equals(av)) {
                throw new IllegalArgumentException("inconsistent hash keys provided.");
            }
        }

        return this;
    }

    public ConditionExpressionBuilder hashKey(StaticBuffer start, StaticBuffer end) {
        return between(Constants.TITAN_HASH_KEY, start, end);
    }

    public ConditionExpressionBuilder rangeKey(StaticBuffer start, StaticBuffer end) {
        return between(Constants.TITAN_RANGE_KEY, start, end);
    }

    public Expression build() {
        if(conditionExpressions.isEmpty()) {
            throw new IllegalStateException("must have added at least one key condition to build");
        }
        if(!conditionExpressions.containsKey(Constants.TITAN_HASH_KEY)) {
            throw new IllegalStateException("must have hash key in keyconditions expression");
        }
        StringBuilder sb = new StringBuilder();
        sb.append(conditionExpressions.get(Constants.TITAN_HASH_KEY));
        if(conditionExpressions.containsKey(Constants.TITAN_RANGE_KEY)) {
            sb.append(" AND (").append(conditionExpressions.get(Constants.TITAN_RANGE_KEY)).append(")");
        }
        return new Expression(null /*updateExpression*/, sb.toString(),
            expressionAttributeValues, null /*expressionAttributeNames*/);
    }

    private ConditionExpressionBuilder between(String key, StaticBuffer start, StaticBuffer end) {
        final Expression filterExpression = new FilterExpressionBuilder().label(key)
                                                                         .range(start, end)
                                                                         .build();
        // build up condition expression
        conditionExpressions.put(key, filterExpression.getConditionExpression());

        // add the constants
        expressionAttributeValues.putAll(filterExpression.getAttributeValues());

        return this;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy