org.neo4j.coreedge.core.state.machines.token.ReplicatedTokenHolder Maven / Gradle / Ivy
/*
* Copyright (c) 2002-2016 "Neo Technology,"
* Network Engine for Objects in Lund AB [http://neotechnology.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 Affero 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 Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see .
*/
package org.neo4j.coreedge.core.state.machines.token;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Future;
import org.neo4j.coreedge.core.replication.Replicator;
import org.neo4j.kernel.api.exceptions.TransactionFailureException;
import org.neo4j.kernel.api.exceptions.schema.ConstraintValidationKernelException;
import org.neo4j.kernel.api.exceptions.schema.CreateConstraintFailureException;
import org.neo4j.kernel.api.txstate.TransactionState;
import org.neo4j.kernel.impl.api.state.TxState;
import org.neo4j.kernel.impl.core.NonUniqueTokenException;
import org.neo4j.kernel.impl.core.TokenHolder;
import org.neo4j.kernel.impl.core.TokenNotFoundException;
import org.neo4j.kernel.impl.store.id.IdGeneratorFactory;
import org.neo4j.kernel.impl.store.id.IdType;
import org.neo4j.kernel.impl.util.Dependencies;
import org.neo4j.storageengine.api.StorageCommand;
import org.neo4j.storageengine.api.StorageEngine;
import org.neo4j.storageengine.api.StorageStatement;
import org.neo4j.storageengine.api.Token;
import org.neo4j.storageengine.api.lock.ResourceLocker;
abstract class ReplicatedTokenHolder implements TokenHolder
{
protected final Dependencies dependencies;
private final Replicator replicator;
private final TokenRegistry tokenRegistry;
private final IdGeneratorFactory idGeneratorFactory;
private final IdType tokenIdType;
private final TokenType type;
// TODO: Clean up all the resolving, which now happens every time with special selection strategies.
ReplicatedTokenHolder( TokenRegistry tokenRegistry, Replicator replicator,
IdGeneratorFactory idGeneratorFactory, IdType tokenIdType,
Dependencies dependencies, TokenType type )
{
this.replicator = replicator;
this.tokenRegistry = tokenRegistry;
this.idGeneratorFactory = idGeneratorFactory;
this.tokenIdType = tokenIdType;
this.type = type;
this.dependencies = dependencies;
}
@Override
public void setInitialTokens( List tokens ) throws NonUniqueTokenException
{
tokenRegistry.setInitialTokens( tokens );
}
@Override
public void addToken( TOKEN token ) throws NonUniqueTokenException
{
tokenRegistry.addToken( token );
}
@Override
public int getOrCreateId( String tokenName )
{
Integer tokenId = tokenRegistry.getId( tokenName );
if ( tokenId != null )
{
return tokenId;
}
return requestToken( tokenName );
}
private int requestToken( String tokenName )
{
ReplicatedTokenRequest tokenRequest = new ReplicatedTokenRequest( type, tokenName, createCommands( tokenName ) );
try
{
Future