| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you 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. |
| */ |
| |
| // An example of an initialization script that can be configured to run in Gremlin Server. |
| // Functions defined here will go into global cache and will not be removed from there |
| // unless there is a reset of the ScriptEngine. |
| def addItUp(x, y) { x + y } |
| |
| // an init script that returns a Map allows explicit setting of global bindings. |
| def globals = [:] |
| |
| // defines a sample LifeCycleHook that prints some output to the Gremlin Server console. |
| // note that the name of the key in the "global" map is unimportant. |
| globals << [hook : [ |
| onStartUp: { ctx -> |
| ctx.logger.info("Executed once at startup of Gremlin Server.") |
| }, |
| onShutDown: { ctx -> |
| ctx.logger.info("Executed once at shutdown of Gremlin Server.") |
| } |
| ] as LifeCycleHook] |
| |
| // Define the default TraversalSource to bind queries to - this one will be named "g" and use |
| // SparkGraphComputer. Note that for this script to work, tinkerpop.spark needs to be listed |
| // as a plugin in the Gremlin Server yaml config file and the plugin must be installed with: |
| // |
| // bin/gremlin-server.sh -i org.apache.tinkerpop spark-gremlin x.y.z |
| // |
| // Please see conf/gremlin-server-spark.yaml for a working example of a config file that will |
| // work with this init script. |
| // |
| // ReferenceElementStrategy converts all graph elements (vertices/edges/vertex properties) |
| // to "references" (i.e. just id and label without properties). this strategy was added |
| // in 3.4.0 to make all Gremlin Server results consistent across all protocols and |
| // serialization formats aligning it with TinkerPop recommended practices for writing |
| // Gremlin. |
| globals << [g : traversal().withEmbedded(graph).withComputer(SparkGraphComputer).withStrategies(ReferenceElementStrategy)] |