apoc.trigger.TriggerInfo Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of apoc-core Show documentation
Show all versions of apoc-core Show documentation
Core package for Neo4j Procedures
/*
* Copyright (c) "Neo4j"
* Neo4j Sweden AB [http://neo4j.com]
*
* This file is part of Neo4j.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package apoc.trigger;
import apoc.SystemPropertyKeys;
import apoc.util.Util;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.neo4j.graphdb.Node;
import org.neo4j.procedure.Description;
public class TriggerInfo {
@Description("The name of the trigger.")
public String name;
@Description("The query belonging to the trigger.")
public String query;
@Description("{ phase = \"before\" :: [\"before\", \"rollback\", \"after\", \"afterAsync\"] }")
public Map selector;
@Description("The parameters for the given Cypher statement.")
public Map params;
@Description("Whether or not the trigger was installed.")
public boolean installed = false;
@Description("Whether or not the trigger was paused.")
public boolean paused = false;
public TriggerInfo(String name) {
this.name = name;
}
public TriggerInfo(String name, String query) {
this(name);
this.query = query;
}
public TriggerInfo(String name, String query, Map selector, boolean installed, boolean paused) {
this(name, query);
this.selector = selector;
this.installed = installed;
this.paused = paused;
}
public TriggerInfo(
String name,
String query,
Map selector,
Map params,
boolean installed,
boolean paused) {
this(name, query, selector, installed, paused);
this.params = params;
}
public static TriggerInfo from(Map mapInfo, boolean installed, String name) {
return new TriggerInfo(
name,
(String) mapInfo.get(SystemPropertyKeys.statement.name()),
(Map) mapInfo.get(SystemPropertyKeys.selector.name()),
(Map) mapInfo.get(SystemPropertyKeys.params.name()),
installed,
(boolean) mapInfo.getOrDefault(SystemPropertyKeys.paused.name(), true));
}
public static TriggerInfo from(Map mapInfo, boolean installed) {
return from(mapInfo, installed, (String) mapInfo.get(SystemPropertyKeys.name.name()));
}
public static TriggerInfo fromNode(Node node, boolean installed) {
// filter and transform node props to map
final Map triggerMap = toTriggerMap(node);
// transform map to TriggerInfo
return from(triggerMap, installed);
}
private static Map toTriggerMap(Node node) {
return node.getAllProperties().entrySet().stream()
.filter(e -> !SystemPropertyKeys.database.name().equals(e.getKey()))
.collect(
HashMap::new, // workaround for https://bugs.openjdk.java.net/browse/JDK-8148463
(mapAccumulator, e) -> {
Object value = List.of(SystemPropertyKeys.selector.name(), SystemPropertyKeys.params.name())
.contains(e.getKey())
? Util.fromJson((String) e.getValue(), Map.class)
: e.getValue();
mapAccumulator.put(e.getKey(), value);
},
HashMap::putAll);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy