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

org.neo4j.kernel.impl.api.index.IndexProxy Maven / Gradle / Ivy

Go to download

Neo4j kernel is a lightweight, embedded Java database designed to store data structured as graphs rather than tables. For more information, see http://neo4j.org.

There is a newer version: 5.26.0
Show newest version
/*
 * Copyright (c) "Neo4j"
 * Neo4j Sweden AB [http://neo4j.com]
 *
 * This file is part of Neo4j.
 *
 * Neo4j is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see .
 */
package org.neo4j.kernel.impl.api.index;

import java.io.IOException;
import java.nio.file.Path;
import java.util.concurrent.TimeUnit;

import org.neo4j.graphdb.ResourceIterator;
import org.neo4j.internal.kernel.api.InternalIndexState;
import org.neo4j.internal.kernel.api.PopulationProgress;
import org.neo4j.internal.kernel.api.exceptions.schema.IndexNotFoundKernelException;
import org.neo4j.internal.schema.IndexDescriptor;
import org.neo4j.io.pagecache.context.CursorContext;
import org.neo4j.kernel.api.exceptions.index.IndexActivationFailedKernelException;
import org.neo4j.kernel.api.exceptions.index.IndexEntryConflictException;
import org.neo4j.kernel.api.exceptions.index.IndexPopulationFailedKernelException;
import org.neo4j.kernel.api.exceptions.schema.UniquePropertyValueValidationException;
import org.neo4j.kernel.api.index.IndexAccessor;
import org.neo4j.kernel.api.index.IndexPopulator;
import org.neo4j.kernel.api.index.IndexUpdater;
import org.neo4j.kernel.api.index.MinimalIndexAccessor;
import org.neo4j.kernel.api.index.TokenIndexReader;
import org.neo4j.kernel.api.index.ValueIndexReader;
import org.neo4j.storageengine.api.NodePropertyAccessor;
import org.neo4j.values.storable.Value;

/**
 * Controls access to {@link IndexPopulator}, {@link IndexAccessor} during different stages
 * of the lifecycle of an index. It's designed to be decorated with multiple stacked instances.
 *
 * The contract of {@link IndexProxy} is
 *
 * 
    *
  • The index may not be created twice
  • *
  • The context may not be closed twice
  • *
  • Close or drop both close the context
  • *
  • The index may not be dropped before it has been created
  • *
  • newUpdater and force may only be called after the index has been created and before it is closed
  • *
  • It is an error to not close an updater before doing any other call on an index
  • *
  • It is an error to close or drop the index while there are still ongoing calls to update and force
  • *
* * @see ContractCheckingIndexProxy */ public interface IndexProxy extends MinimalIndexAccessor { void start(); IndexUpdater newUpdater( IndexUpdateMode mode, CursorContext cursorContext ); /** * Close this index context. */ void close( CursorContext cursorContext ) throws IOException; IndexDescriptor getDescriptor(); /** * Change the index descriptor connected to this proxy. * This should only be done if the index descriptors describe the same physical index. */ default void changeIdentity( IndexDescriptor descriptor ) { throw new UnsupportedOperationException( "Identity of this proxy is immutable" ); } InternalIndexState getState(); /** * @return failure message. Expect a call to it if {@link #getState()} returns {@link InternalIndexState#FAILED}. */ IndexPopulationFailure getPopulationFailure() throws IllegalStateException; PopulationProgress getIndexPopulationProgress(); void force( CursorContext cursorContext ) throws IOException; void refresh() throws IOException; /** * @throws IndexNotFoundKernelException if the index isn't online yet. * @throws UnsupportedOperationException if underlying index is not Value Index */ ValueIndexReader newValueReader() throws IndexNotFoundKernelException; /** * @throws IndexNotFoundKernelException if the index isn't online yet. * @throws UnsupportedOperationException if underlying index is not Token Index */ TokenIndexReader newTokenReader() throws IndexNotFoundKernelException; /** * @param time time to wait maximum. A value of 0 means indefinite wait. * @param unit unit of time to wait. * @return {@code true} if the call waited, {@code false} if the condition was already reached. */ boolean awaitStoreScanCompleted( long time, TimeUnit unit ) throws IndexPopulationFailedKernelException, InterruptedException; void activate() throws IndexActivationFailedKernelException; void validate() throws IndexPopulationFailedKernelException, UniquePropertyValueValidationException; /** * Validates a {@link Value} so that it's OK to later apply to the index. This method is designed to be * called before committing a transaction as to prevent exception during applying that transaction. * * @param tuple {@link Value value tuple} to validate. * @param entityId id of the entity being validated */ void validateBeforeCommit( Value[] tuple, long entityId ); ResourceIterator snapshotFiles() throws IOException; default void verifyDeferredConstraints( NodePropertyAccessor accessor ) throws IndexEntryConflictException, IOException { throw new IllegalStateException( this.toString() ); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy