/* * 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. */ package org.apache.tinkerpop.gremlin.groovy.jsr223; import org.apache.tinkerpop.gremlin.groovy.plugin.GremlinPlugin; import org.apache.tinkerpop.gremlin.groovy.plugin.PluginAcceptor; import javax.script.ScriptContext; import javax.script.ScriptEngine; import javax.script.ScriptException; import javax.script.SimpleBindings; import java.util.HashMap; import java.util.Map; import java.util.Set; /** * A {@link PluginAcceptor} implementation for bare {@code ScriptEngine} implementations allowing plugins to * interact with them on initialization. * * @author Stephen Mallette (http://stephen.genoprime.com) * @deprecated As of release 3.2.4, not replaced. */ @Deprecated public class ScriptEnginePluginAcceptor implements PluginAcceptor { private final ScriptEngine scriptEngine; public ScriptEnginePluginAcceptor(final ScriptEngine scriptEngine) { this.scriptEngine = scriptEngine; } /** * Adds global bindings to the {@code ScriptEngine} that will be applied to every evaluated script. */ @Override public void addBinding(final String key, final Object val) { // The binding was originally added to the engine scope but that proved to be "bad" as it mixed with other // bindings in that space. if (null == scriptEngine.getContext().getBindings(ScriptContext.GLOBAL_SCOPE)) scriptEngine.getContext().setBindings(new SimpleBindings(), ScriptContext.GLOBAL_SCOPE); scriptEngine.getContext().setAttribute(key, val, ScriptContext.GLOBAL_SCOPE); } /** * Gets the global bindings that will be applied to every evaluated script. */ @Override public Map<String, Object> getBindings() { // as these "global" bindings were added to engine scope they should be pulled from the same place return scriptEngine.getBindings(ScriptContext.GLOBAL_SCOPE); } /** * If the {@code ScriptEngine} implements the {@link DependencyManager} interface it will try to import the * specified import statements. */ @Override public void addImports(final Set<String> importStatements) { if (this.scriptEngine instanceof DependencyManager) ((DependencyManager) this.scriptEngine).addImports(importStatements); } /** * Evaluate a script in the {@code ScriptEngine}. Typically {@code eval()} should be called after imports as * {@code ScriptEngine} resets may occur during import. */ @Override public Object eval(final String script) throws ScriptException { return this.scriptEngine.eval(script); } /** * Defines the environment settings for the {@link GremlinPlugin}. */ @Override public Map<String, Object> environment() { final Map<String, Object> env = new HashMap<>(); env.put(GremlinPlugin.ENVIRONMENT, "scriptEngine"); return env; } }