org.neo4j.fabric.transaction.FabricProcedures Maven / Gradle / Ivy
/*
* 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.fabric.transaction;
import java.time.Clock;
import java.util.Set;
import java.util.stream.Stream;
import org.neo4j.collection.RawIterator;
import org.neo4j.common.DependencyResolver;
import org.neo4j.graphdb.Transaction;
import org.neo4j.graphdb.security.URLAccessChecker;
import org.neo4j.internal.kernel.api.Procedures;
import org.neo4j.internal.kernel.api.exceptions.ProcedureException;
import org.neo4j.internal.kernel.api.procs.ProcedureCallContext;
import org.neo4j.internal.kernel.api.procs.ProcedureHandle;
import org.neo4j.internal.kernel.api.procs.ProcedureSignature;
import org.neo4j.internal.kernel.api.procs.QualifiedName;
import org.neo4j.internal.kernel.api.procs.UserAggregationReducer;
import org.neo4j.internal.kernel.api.procs.UserFunctionHandle;
import org.neo4j.internal.kernel.api.procs.UserFunctionSignature;
import org.neo4j.internal.kernel.api.security.SecurityContext;
import org.neo4j.kernel.api.KernelTransaction;
import org.neo4j.kernel.api.procedure.Context;
import org.neo4j.kernel.api.procedure.ProcedureView;
import org.neo4j.kernel.impl.coreapi.InternalTransaction;
import org.neo4j.kernel.internal.GraphDatabaseAPI;
import org.neo4j.values.AnyValue;
import org.neo4j.values.ValueMapper;
/**
* Fabric needs to evaluate functions and evaluate procedure names, without being having access to a {@link Context}.
*
* This class provides a wrapper around {@link ProcedureView} that satisfies these requirements.
*/
public class FabricProcedures implements Procedures {
private final ProcedureView view;
private final Context EMPTY_CONTEXT = new EmptyProcedureContext();
public FabricProcedures(ProcedureView view) {
this.view = view;
}
private static T notAvailable() {
throw new RuntimeException("Operation not available in static context.");
}
@Override
public UserFunctionHandle functionGet(QualifiedName name) {
return view.function(name);
}
@Override
public Stream functionGetAll() {
return notAvailable();
}
@Override
public UserFunctionHandle aggregationFunctionGet(QualifiedName name) {
return notAvailable();
}
@Override
public Stream aggregationFunctionGetAll() {
return notAvailable();
}
@Override
public ProcedureHandle procedureGet(QualifiedName name) throws ProcedureException {
// Note: Bolt checks connections by invoking `dbms.routing.getRoutingTable`.
// This means that we have to be able to resolve this symbol in the planning step.
return view.procedure(name);
}
@Override
public Set proceduresGetAll() throws ProcedureException {
return notAvailable();
}
@Override
public RawIterator procedureCallRead(
int id, AnyValue[] arguments, ProcedureCallContext context) throws ProcedureException {
return notAvailable();
}
@Override
public RawIterator procedureCallWrite(
int id, AnyValue[] arguments, ProcedureCallContext context) throws ProcedureException {
return notAvailable();
}
@Override
public RawIterator procedureCallSchema(
int id, AnyValue[] arguments, ProcedureCallContext context) throws ProcedureException {
return notAvailable();
}
@Override
public RawIterator procedureCallDbms(
int id, AnyValue[] arguments, ProcedureCallContext context) throws ProcedureException {
return notAvailable();
}
@Override
public AnyValue functionCall(int id, AnyValue[] arguments, ProcedureCallContext context) throws ProcedureException {
return view.callFunction(EMPTY_CONTEXT, id, arguments);
}
@Override
public AnyValue builtInFunctionCall(int id, AnyValue[] arguments, ProcedureCallContext context)
throws ProcedureException {
return view.callFunction(EMPTY_CONTEXT, id, arguments);
}
@Override
public UserAggregationReducer aggregationFunction(int id, ProcedureCallContext context) throws ProcedureException {
return notAvailable();
}
@Override
public UserAggregationReducer builtInAggregationFunction(int id, ProcedureCallContext context)
throws ProcedureException {
return notAvailable();
}
@Override
public long signatureVersion() {
return view.signatureVersion();
}
private static class EmptyProcedureContext implements Context {
private EmptyProcedureContext() {
/* We indent to restrict the usage to FabricProcedures only */
}
@Override
public ValueMapper