org.neo4j.dbms.systemgraph.CommunityTopologyGraphDbmsModel Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of neo4j-kernel Show documentation
Show all versions of neo4j-kernel Show documentation
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.
The newest version!
/*
* Copyright (c) "Neo4j"
* Neo4j Sweden AB [https://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.dbms.systemgraph;
import java.util.Map;
import java.util.Optional;
import java.util.Set;
import java.util.UUID;
import java.util.stream.Collectors;
import java.util.stream.Stream;
import java.util.stream.StreamSupport;
import org.neo4j.graphdb.Direction;
import org.neo4j.graphdb.Label;
import org.neo4j.graphdb.Node;
import org.neo4j.graphdb.ResourceIterator;
import org.neo4j.graphdb.Transaction;
import org.neo4j.internal.helpers.collection.Pair;
import org.neo4j.kernel.database.DatabaseReference;
import org.neo4j.kernel.database.DatabaseReferenceImpl;
import org.neo4j.kernel.database.NamedDatabaseId;
import org.neo4j.kernel.database.NormalizedCatalogEntry;
import org.neo4j.kernel.database.NormalizedDatabaseName;
public class CommunityTopologyGraphDbmsModel implements TopologyGraphDbmsModel {
protected final Transaction tx;
public CommunityTopologyGraphDbmsModel(Transaction tx) {
this.tx = tx;
}
public Map getAllDatabaseAccess() {
try (ResourceIterator nodes = tx.findNodes(DATABASE_LABEL)) {
return nodes.stream()
.collect(Collectors.toMap(
CommunityTopologyGraphDbmsModelUtil::getDatabaseId,
CommunityTopologyGraphDbmsModelUtil::getDatabaseAccess));
}
}
@Override
public Optional getDatabaseIdByAlias(String databaseName) {
return CommunityTopologyGraphDbmsModelUtil.getDatabaseIdByAlias(tx, databaseName)
.or(() ->
CommunityTopologyGraphDbmsModelUtil.getDatabaseIdBy(tx, DATABASE_NAME_PROPERTY, databaseName));
}
@Override
public Optional getDatabaseIdByUUID(UUID uuid) {
return CommunityTopologyGraphDbmsModelUtil.getDatabaseIdBy(tx, DATABASE_UUID_PROPERTY, uuid.toString());
}
@Override
public Set getAllDatabaseReferences() {
var primaryRefs = CommunityTopologyGraphDbmsModelUtil.getAllPrimaryStandardDatabaseReferencesInRoot(tx);
var internalAliasRefs = getAllInternalDatabaseReferencesInRoot();
var externalRefs = getAllExternalDatabaseReferencesInRoot();
var compositeRefs = getAllCompositeDatabaseReferencesInRoot();
var spdEntityShardRefs = getAllSPDEntityShardReferencesInRoot();
var spdPropertyShardRefs = getAllSPDPropertyShardReferencesInRoot();
return Stream.of(
primaryRefs,
internalAliasRefs,
externalRefs,
compositeRefs,
spdEntityShardRefs,
spdPropertyShardRefs)
.flatMap(s -> s)
.collect(Collectors.toUnmodifiableSet());
}
@Override
public Set getAllInternalDatabaseReferences() {
var primaryRefs = CommunityTopologyGraphDbmsModelUtil.getAllPrimaryStandardDatabaseReferencesInRoot(tx);
var internalAliasRefs = getAllInternalDatabaseReferencesInRoot();
var spdEntityShardRefs = getAllSPDEntityShardReferencesInRoot();
var spdPropertyShardRefs = getAllSPDPropertyShardReferencesInRoot();
return Stream.of(primaryRefs, internalAliasRefs, spdEntityShardRefs, spdPropertyShardRefs)
.flatMap(s -> s)
.collect(Collectors.toUnmodifiableSet());
}
@Override
public Set getAllExternalDatabaseReferences() {
return getAllExternalDatabaseReferencesInRoot().collect(Collectors.toUnmodifiableSet());
}
@Override
public Set getAllCompositeDatabaseReferences() {
return getAllCompositeDatabaseReferencesInRoot().collect(Collectors.toUnmodifiableSet());
}
@Override
public Optional getDatabaseRefByAlias(String databaseName) {
var normalizedDatabaseName = new NormalizedDatabaseName(databaseName).name();
// A uniqueness constraint at the Cypher level should prevent two references from ever having the same name, but
// in case they do, we simply prefer the internal reference.
return Optional.empty()
.or(() -> getCompositeDatabaseReferenceInRoot(normalizedDatabaseName))
.or(() -> getSPDEntityShardReferenceInRoot(normalizedDatabaseName))
.or(() -> getSPDPropertyShardReferenceInRoot(normalizedDatabaseName))
.or(() -> CommunityTopologyGraphDbmsModelUtil.getInternalDatabaseReference(tx, normalizedDatabaseName))
.or(() -> CommunityTopologyGraphDbmsModelUtil.getExternalDatabaseReference(tx, normalizedDatabaseName));
}
@Override
public Optional getDatabaseRefByAlias(NormalizedCatalogEntry catalogEntry) {
if (catalogEntry.compositeDb().isPresent()) {
return resolveConstituent(catalogEntry.compositeDb().get(), catalogEntry.databaseAlias());
} else {
return resolveRootReference(catalogEntry.databaseAlias());
}
}
private Optional resolveConstituent(String composite, String constituent) {
return Optional.empty()
.or(() -> CommunityTopologyGraphDbmsModelUtil.getInternalDatabaseReference(tx, composite, constituent))
.or(() -> CommunityTopologyGraphDbmsModelUtil.getExternalDatabaseReference(tx, composite, constituent));
}
private Optional resolveRootReference(String normalizedDatabaseAlias) {
return Optional.empty()
.or(() -> getCompositeDatabaseReferenceInRoot(normalizedDatabaseAlias))
.or(() -> getSPDEntityShardReferenceInRoot(normalizedDatabaseAlias))
.or(() -> getSPDPropertyShardReferenceInRoot(normalizedDatabaseAlias))
.or(() -> CommunityTopologyGraphDbmsModelUtil.getInternalDatabaseReference(tx, normalizedDatabaseAlias))
.or(() ->
CommunityTopologyGraphDbmsModelUtil.getExternalDatabaseReference(tx, normalizedDatabaseAlias));
}
@Override
public Optional getDriverSettings(String databaseName, String namespace) {
databaseName = new NormalizedDatabaseName(databaseName).name();
namespace = new NormalizedDatabaseName(namespace).name();
return tx.findNodes(REMOTE_DATABASE_LABEL, NAME_PROPERTY, databaseName, NAMESPACE_PROPERTY, namespace).stream()
.findFirst()
.flatMap(CommunityTopologyGraphDbmsModelUtil::getDriverSettings);
}
@Override
public Optional
© 2015 - 2025 Weber Informatics LLC | Privacy Policy