org.neo4j.consistency.checking.AbstractStoreProcessor Maven / Gradle / Ivy
/*
* Copyright (c) 2002-2018 "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.consistency.checking;
import org.neo4j.consistency.RecordType;
import org.neo4j.consistency.report.ConsistencyReport;
import org.neo4j.consistency.report.ConsistencyReport.LabelTokenConsistencyReport;
import org.neo4j.consistency.report.ConsistencyReport.NodeConsistencyReport;
import org.neo4j.consistency.report.ConsistencyReport.PropertyConsistencyReport;
import org.neo4j.consistency.report.ConsistencyReport.PropertyKeyTokenConsistencyReport;
import org.neo4j.consistency.report.ConsistencyReport.RelationshipConsistencyReport;
import org.neo4j.consistency.report.ConsistencyReport.RelationshipGroupConsistencyReport;
import org.neo4j.consistency.report.ConsistencyReport.RelationshipTypeConsistencyReport;
import org.neo4j.kernel.impl.store.RecordStore;
import org.neo4j.kernel.impl.store.id.IdType;
import org.neo4j.kernel.impl.store.record.DynamicRecord;
import org.neo4j.kernel.impl.store.record.LabelTokenRecord;
import org.neo4j.kernel.impl.store.record.NodeRecord;
import org.neo4j.kernel.impl.store.record.PropertyKeyTokenRecord;
import org.neo4j.kernel.impl.store.record.PropertyRecord;
import org.neo4j.kernel.impl.store.record.RelationshipGroupRecord;
import org.neo4j.kernel.impl.store.record.RelationshipRecord;
import org.neo4j.kernel.impl.store.record.RelationshipTypeTokenRecord;
import static java.lang.String.format;
import static org.neo4j.consistency.checking.DynamicStore.ARRAY;
import static org.neo4j.consistency.checking.DynamicStore.NODE_LABEL;
import static org.neo4j.consistency.checking.DynamicStore.SCHEMA;
public abstract class AbstractStoreProcessor extends RecordStore.Processor
{
private RecordCheck sparseNodeChecker;
private RecordCheck denseNodeChecker;
private RecordCheck relationshipChecker;
private final RecordCheck propertyChecker;
private final RecordCheck propertyKeyTokenChecker;
private final RecordCheck relationshipTypeTokenChecker;
private final RecordCheck labelTokenChecker;
private final RecordCheck relationshipGroupChecker;
public AbstractStoreProcessor()
{
this( CheckDecorator.NONE );
}
public AbstractStoreProcessor( CheckDecorator decorator )
{
this.sparseNodeChecker = decorator.decorateNodeChecker( NodeRecordCheck.forSparseNodes() );
this.denseNodeChecker = decorator.decorateNodeChecker( NodeRecordCheck.forDenseNodes() );
this.relationshipChecker = decorator.decorateRelationshipChecker( new RelationshipRecordCheck() );
this.propertyChecker = decorator.decoratePropertyChecker( new PropertyRecordCheck() );
this.propertyKeyTokenChecker = decorator.decoratePropertyKeyTokenChecker( new PropertyKeyTokenRecordCheck() );
this.relationshipTypeTokenChecker =
decorator.decorateRelationshipTypeTokenChecker( new RelationshipTypeTokenRecordCheck() );
this.labelTokenChecker = decorator.decorateLabelTokenChecker( new LabelTokenRecordCheck() );
this.relationshipGroupChecker = decorator.decorateRelationshipGroupChecker( new RelationshipGroupRecordCheck() );
}
public void reDecorateRelationship( CheckDecorator decorator, RelationshipRecordCheck newChecker )
{
this.relationshipChecker = decorator.decorateRelationshipChecker( newChecker );
}
public void reDecorateNode( CheckDecorator decorator, NodeRecordCheck newChecker, boolean sparseNode )
{
if ( sparseNode )
{
this.sparseNodeChecker = decorator.decorateNodeChecker( newChecker );
}
else
{
this.denseNodeChecker = decorator.decorateNodeChecker( newChecker );
}
}
protected abstract void checkNode(
RecordStore store, NodeRecord node,
RecordCheck checker );
protected abstract void checkRelationship(
RecordStore store, RelationshipRecord rel,
RecordCheck checker );
protected abstract void checkProperty(
RecordStore store, PropertyRecord property,
RecordCheck checker );
protected abstract void checkRelationshipTypeToken(
RecordStore store,
RelationshipTypeTokenRecord record,
RecordCheck checker );
protected abstract void checkLabelToken(
RecordStore store,
LabelTokenRecord record,
RecordCheck checker );
protected abstract void checkPropertyKeyToken(
RecordStore store, PropertyKeyTokenRecord record,
RecordCheck checker );
protected abstract void checkDynamic(
RecordType type, RecordStore store, DynamicRecord string,
RecordCheck checker );
protected abstract void checkDynamicLabel(
RecordType type, RecordStore store, DynamicRecord string,
RecordCheck checker );
protected abstract void checkRelationshipGroup(
RecordStore store, RelationshipGroupRecord record,
RecordCheck checker );
@Override
public void processSchema( RecordStore store, DynamicRecord schema )
{
// cf. StoreProcessor
checkDynamic( RecordType.SCHEMA, store, schema, new DynamicRecordCheck( store, SCHEMA ) );
}
@Override
public void processNode( RecordStore store, NodeRecord node )
{
if ( node.isDense() )
{
checkNode( store, node, denseNodeChecker );
}
else
{
checkNode( store, node, sparseNodeChecker );
}
}
@Override
public final void processRelationship( RecordStore store, RelationshipRecord rel )
{
checkRelationship( store, rel, relationshipChecker );
}
@Override
public final void processProperty( RecordStore store, PropertyRecord property )
{
checkProperty( store, property, propertyChecker );
}
@Override
public final void processString( RecordStore store, DynamicRecord string, IdType idType )
{
RecordType type;
DynamicStore dereference;
switch ( idType )
{
case STRING_BLOCK:
type = RecordType.STRING_PROPERTY;
dereference = DynamicStore.STRING;
break;
case RELATIONSHIP_TYPE_TOKEN_NAME:
type = RecordType.RELATIONSHIP_TYPE_NAME;
dereference = DynamicStore.RELATIONSHIP_TYPE;
break;
case PROPERTY_KEY_TOKEN_NAME:
type = RecordType.PROPERTY_KEY_NAME;
dereference = DynamicStore.PROPERTY_KEY;
break;
case LABEL_TOKEN_NAME:
type = RecordType.LABEL_NAME;
dereference = DynamicStore.LABEL;
break;
default:
throw new IllegalArgumentException( format( "The id type [%s] is not valid for String records.", idType ) );
}
checkDynamic( type, store, string, new DynamicRecordCheck( store, dereference ) );
}
@Override
public final void processArray( RecordStore store, DynamicRecord array )
{
checkDynamic( RecordType.ARRAY_PROPERTY, store, array, new DynamicRecordCheck( store, ARRAY ) );
}
@Override
public final void processLabelArrayWithOwner( RecordStore store, DynamicRecord array )
{
checkDynamic( RecordType.NODE_DYNAMIC_LABEL, store, array, new DynamicRecordCheck( store, NODE_LABEL ) );
checkDynamicLabel( RecordType.NODE_DYNAMIC_LABEL, store, array, new NodeDynamicLabelOrphanChainStartCheck() );
}
@Override
public final void processRelationshipTypeToken( RecordStore store,
RelationshipTypeTokenRecord record )
{
checkRelationshipTypeToken( store, record, relationshipTypeTokenChecker );
}
@Override
public final void processPropertyKeyToken( RecordStore store,
PropertyKeyTokenRecord record )
{
checkPropertyKeyToken( store, record, propertyKeyTokenChecker );
}
@Override
public void processLabelToken( RecordStore store, LabelTokenRecord record )
{
checkLabelToken( store, record, labelTokenChecker );
}
@Override
public void processRelationshipGroup( RecordStore store, RelationshipGroupRecord record )
throws RuntimeException
{
checkRelationshipGroup( store, record, relationshipGroupChecker );
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy