001    /**
002     * Copyright (c) 2000-present Liferay, Inc. All rights reserved.
003     *
004     * This library is free software; you can redistribute it and/or modify it under
005     * the terms of the GNU Lesser General Public License as published by the Free
006     * Software Foundation; either version 2.1 of the License, or (at your option)
007     * any later version.
008     *
009     * This library is distributed in the hope that it will be useful, but WITHOUT
010     * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
011     * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
012     * details.
013     */
014    
015    package com.liferay.portal.kernel.scripting;
016    
017    import java.io.File;
018    
019    import java.util.Map;
020    import java.util.Set;
021    
022    /**
023     * @author Alberto Montero
024     * @author Brian Wing Shun Chan
025     */
026    public interface ScriptingExecutor {
027    
028            public void clearCache();
029    
030            public Map<String, Object> eval(
031                            Set<String> allowedClasses, Map<String, Object> inputObjects,
032                            Set<String> outputNames, File scriptFile)
033                    throws ScriptingException;
034    
035            /**
036             * @deprecated As of 7.0.0, replaced by {@link #eval(Set, Map, Set, File)}
037             */
038            @Deprecated
039            public Map<String, Object> eval(
040                            Set<String> allowedClasses, Map<String, Object> inputObjects,
041                            Set<String> outputNames, File scriptFile,
042                            ClassLoader... classloaders)
043                    throws ScriptingException;
044    
045            public Map<String, Object> eval(
046                            Set<String> allowedClasses, Map<String, Object> inputObjects,
047                            Set<String> outputNames, String script)
048                    throws ScriptingException;
049    
050            /**
051             * @deprecated As of 7.0.0, replaced by {@link #eval(Set, Map, Set, String)}
052             */
053            @Deprecated
054            public Map<String, Object> eval(
055                            Set<String> allowedClasses, Map<String, Object> inputObjects,
056                            Set<String> outputNames, String script, ClassLoader... classloaders)
057                    throws ScriptingException;
058    
059            public String getLanguage();
060    
061            public ScriptingContainer<?> getScriptingContainer();
062    
063            public ScriptingExecutor newInstance(boolean executeInSeparateThread);
064    
065    }