| /* |
| * 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.ignite.internal.catalog.descriptors; |
| |
| import static org.apache.ignite.internal.catalog.CatalogManagerImpl.INITIAL_CAUSALITY_TOKEN; |
| |
| import java.util.Objects; |
| import org.apache.ignite.internal.catalog.storage.UpdateEntry; |
| import org.apache.ignite.internal.tostring.S; |
| |
| /** |
| * Base class for catalog objects. |
| */ |
| public abstract class CatalogObjectDescriptor { |
| private final int id; |
| private final String name; |
| private final Type type; |
| private long updateToken; |
| |
| CatalogObjectDescriptor(int id, Type type, String name, long causalityToken) { |
| this.id = id; |
| this.type = Objects.requireNonNull(type, "type"); |
| this.name = Objects.requireNonNull(name, "name"); |
| this.updateToken = causalityToken; |
| } |
| |
| /** Returns id of the described object. */ |
| public int id() { |
| return id; |
| } |
| |
| /** Returns name of the described object. */ |
| public String name() { |
| return name; |
| } |
| |
| /** Return schema-object type. */ |
| public Type type() { |
| return type; |
| } |
| |
| /** |
| * Token of the update of the descriptor. |
| * Updated when {@link UpdateEntry#applyUpdate(org.apache.ignite.internal.catalog.Catalog, long)} is called for the |
| * corresponding catalog descriptor. This token is the token that is associated with the corresponding update being applied to |
| * the Catalog. Any new catalog descriptor associated with an {@link UpdateEntry}, meaning that this token is set only once. |
| * |
| * @return Token of the update of the descriptor. |
| */ |
| public long updateToken() { |
| return updateToken; |
| } |
| |
| /** |
| * Set token of the update of the descriptor. Must be called only once when |
| * {@link UpdateEntry#applyUpdate(org.apache.ignite.internal.catalog.Catalog, long)} is called for the corresponding catalog descriptor. |
| * This token is the token that is associated with the corresponding update being applied to |
| * the Catalog. Any new catalog descriptor associated with an {@link UpdateEntry}, meaning that this token is set only once. |
| * |
| * @param updateToken Update token of the descriptor. |
| */ |
| public void updateToken(long updateToken) { |
| assert this.updateToken == INITIAL_CAUSALITY_TOKEN : "Update token for the descriptor must be updated only once"; |
| |
| this.updateToken = updateToken; |
| } |
| |
| @Override |
| public String toString() { |
| return S.toString(CatalogObjectDescriptor.class, this); |
| } |
| |
| /** Catalog object type. */ |
| public enum Type { |
| SCHEMA, |
| TABLE, |
| INDEX, |
| ZONE, |
| SYSTEM_VIEW |
| } |
| } |