Package org.apache.cassandra.config

Source Code of org.apache.cassandra.config.UTMetaData

/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements.  See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership.  The ASF licenses this file
* to you 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 org.apache.cassandra.config;

import java.nio.ByteBuffer;
import java.util.*;

import org.apache.cassandra.db.*;
import org.apache.cassandra.db.composites.Composite;
import org.apache.cassandra.db.marshal.*;
import org.apache.cassandra.exceptions.RequestValidationException;
import org.apache.cassandra.cql3.*;
import org.apache.cassandra.utils.ByteBufferUtil;

/**
* Defined (and loaded) user types.
*
* In practice, because user types are global, we have only one instance of
* this class that retrieve through the Schema class.
*/
public final class UTMetaData
{
    private final Map<ByteBuffer, UserType> userTypes;

    public UTMetaData()
    {
        this(new HashMap<ByteBuffer, UserType>());
    }

    UTMetaData(Map<ByteBuffer, UserType> types)
    {
        this.userTypes = types;
    }

    private static UserType fromSchema(UntypedResultSet.Row row)
    {
        try
        {
            String keyspace = row.getString("keyspace_name");
            ByteBuffer name = ByteBufferUtil.bytes(row.getString("type_name"));
            List<String> rawColumns = row.getList("column_names", UTF8Type.instance);
            List<String> rawTypes = row.getList("column_types", UTF8Type.instance);

            List<ByteBuffer> columns = new ArrayList<>(rawColumns.size());
            for (String rawColumn : rawColumns)
                columns.add(ByteBufferUtil.bytes(rawColumn));

            List<AbstractType<?>> types = new ArrayList<>(rawTypes.size());
            for (String rawType : rawTypes)
                types.add(TypeParser.parse(rawType));

            return new UserType(keyspace, name, columns, types);
        }
        catch (RequestValidationException e)
        {
            // If it has been written in the schema, it should be valid
            throw new AssertionError();
        }
    }

    public static Map<ByteBuffer, UserType> fromSchema(Row row)
    {
        UntypedResultSet results = QueryProcessor.resultify("SELECT * FROM system." + SystemKeyspace.SCHEMA_USER_TYPES_CF, row);
        Map<ByteBuffer, UserType> types = new HashMap<>(results.size());
        for (UntypedResultSet.Row result : results)
        {
            UserType type = fromSchema(result);
            types.put(type.name, type);
        }
        return types;
    }

    public static Mutation toSchema(UserType newType, long timestamp)
    {
        return toSchema(new Mutation(Keyspace.SYSTEM_KS, SystemKeyspace.getSchemaKSKey(newType.keyspace)), newType, timestamp);
    }

    public static Mutation toSchema(Mutation mutation, UserType newType, long timestamp)
    {
        ColumnFamily cf = mutation.addOrGet(SystemKeyspace.SCHEMA_USER_TYPES_CF);

        Composite prefix = CFMetaData.SchemaUserTypesCf.comparator.make(newType.name);
        CFRowAdder adder = new CFRowAdder(cf, prefix, timestamp);

        adder.resetCollection("column_names");
        adder.resetCollection("column_types");

        for (ByteBuffer name : newType.columnNames)
            adder.addListEntry("column_names", name);
        for (AbstractType<?> type : newType.types)
            adder.addListEntry("column_types", type.toString());

        return mutation;
    }

    public Mutation toSchema(Mutation mutation, long timestamp)
    {
        for (UserType ut : userTypes.values())
            toSchema(mutation, ut, timestamp);
        return mutation;
    }

    public static Mutation dropFromSchema(UserType droppedType, long timestamp)
    {
        Mutation mutation = new Mutation(Keyspace.SYSTEM_KS, SystemKeyspace.getSchemaKSKey(droppedType.keyspace));
        ColumnFamily cf = mutation.addOrGet(SystemKeyspace.SCHEMA_USER_TYPES_CF);
        int ldt = (int) (System.currentTimeMillis() / 1000);

        Composite prefix = CFMetaData.SchemaUserTypesCf.comparator.make(droppedType.name);
        cf.addAtom(new RangeTombstone(prefix, prefix.end(), timestamp, ldt));

        return mutation;
    }

    public UserType getType(ByteBuffer typeName)
    {
        return userTypes.get(typeName);
    }

    public Map<ByteBuffer, UserType> getAllTypes()
    {
        // Copy to avoid concurrent modification while iterating. Not intended to be called on a criticial path anyway
        return new HashMap<>(userTypes);
    }

    // This is *not* thread safe but is only called in DefsTables that is synchronized.
    public void addType(UserType type)
    {
        UserType old = userTypes.get(type.name);
        assert old == null || type.isCompatibleWith(old);
        userTypes.put(type.name, type);
    }

    // Same remarks than for addType
    public void removeType(UserType type)
    {
        userTypes.remove(type.name);
    }

    public boolean equals(Object that)
    {
        if (!(that instanceof UTMetaData))
            return false;
        return userTypes.equals(((UTMetaData) that).userTypes);
    }
}
TOP

Related Classes of org.apache.cassandra.config.UTMetaData

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.