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

com.datastax.driver.core.schemabuilder.KeyspaceOptions Maven / Gradle / Ivy

There is a newer version: 3.6.0-1
Show newest version
/*
 *      Copyright (C) 2012-2015 DataStax 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.datastax.driver.core.schemabuilder;

import com.datastax.driver.$internal.com.google.common.base.Optional;

import java.util.Map;

/**
 * The keyspace options used in CREATE KEYSPACE or ALTER KEYSPACE statements.
 */
public class KeyspaceOptions extends SchemaStatement {

    private Optional> replication = Optional.absent();
    private Optional durableWrites = Optional.absent();

    private final String command;
    private final String keyspaceName;

    public KeyspaceOptions(String command, String keyspaceName) {
        validateNotEmpty(keyspaceName, "Keyspace name");
        validateNotKeyWord(keyspaceName,
                String.format("The keyspace name '%s' is not allowed because it is a reserved keyword", keyspaceName));

        this.command = command;
        this.keyspaceName = keyspaceName;
    }

    /**
     * Define the replication options for the statement.
     *
     * @param replication replication properties map
     * @return this {@code KeyspaceOptions} object
     */
    public KeyspaceOptions replication(Map replication) {
        validateReplicationOptions(replication);
        this.replication = Optional.fromNullable(replication);
        return this;
    }

    /**
     * Define the durable writes option for the statement. If set to false,
     * data written to the keyspace will bypass the commit log.
     *
     * @param durableWrites durable write option
     * @return this {@code KeyspaceOptions} object
     */
    public KeyspaceOptions durableWrites(Boolean durableWrites) {
        this.durableWrites = Optional.fromNullable(durableWrites);
        return this;
    }

    @Override
    String buildInternal() {
        StringBuilder builtStatement = new StringBuilder(STATEMENT_START);
        builtStatement.append(command);
        builtStatement.append(" ");
        builtStatement.append(keyspaceName);
        builtStatement.append("\n\tWITH\n\t\t");

        boolean putSeparator = false;
        if (replication.isPresent()) {

            builtStatement.append("REPLICATION = {");

            int l = replication.get().entrySet().size();
            for (Map.Entry e : replication.get().entrySet()) {
                builtStatement.append("'")
                        .append(e.getKey())
                        .append("'")
                        .append(": ");

                if (e.getValue() instanceof String) {
                    builtStatement.append("'")
                            .append(e.getValue())
                            .append("'");
                } else {
                    builtStatement.append(e.getValue());
                }

                if (--l > 0) {
                    builtStatement.append(", ");
                }
            }

            builtStatement.append('}');
            builtStatement.append("\n\t\t");
            putSeparator = true;
        }


        if (durableWrites.isPresent()) {
            if (putSeparator) {
                builtStatement.append("AND ");
            }

            builtStatement.append("DURABLE_WRITES = " + durableWrites.get().toString());
        }


        return builtStatement.toString();
    }

    static void validateReplicationOptions(Map replicationOptions) {
        if (replicationOptions != null && !replicationOptions.containsKey("class")) {
            throw new IllegalArgumentException("Replication Strategy 'class' should be provided");
        }

        if (replicationOptions != null && !(replicationOptions.get("class") instanceof String)) {
            throw new IllegalArgumentException("Replication Strategy should be of type String");
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy