All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.zodiac.script.engine.ognl.OgnlEngine Maven / Gradle / Ivy

There is a newer version: 1.6.8
Show newest version
package org.zodiac.script.engine.ognl;

import ognl.Ognl;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.zodiac.commons.crypto.Md5;
import org.zodiac.commons.util.Colls;
import org.zodiac.script.engine.ExecuteResult;
import org.zodiac.script.engine.ListenerSupportEngine;
import org.zodiac.script.engine.ScriptContext;

import java.util.Map;

public class OgnlEngine extends ListenerSupportEngine {

    protected final Logger logger = LoggerFactory.getLogger(this.getClass());

    protected final Map cache = Colls.concurrentMap();

    @Override
    public boolean compiled(String id) {
        return cache.containsKey(id);
    }

    @Override
    public ScriptContext getContext(String id) {
        return cache.get(id);
    }

    @Override
    public boolean remove(String id) {
        return cache.remove(id) != null;
    }

    @Override
    public void init(String... contents) throws Exception {}

    @Override
    public ExecuteResult execute(String id) {
        return execute(id, Colls.map());
    }

    @Override
    public boolean compile(String id, String code) throws Exception {
        if (logger.isDebugEnabled()) {
            logger.debug("compile Ognl {} : {}", id, code);
        }
        cache.put(id, new OgnlScriptContext(id, Md5.md5Hex(code), Ognl.parseExpression(code)));
        return false;
    }

    @Override
    public ExecuteResult execute(String id, Map param) {
        if (logger.isDebugEnabled()) {
            logger.debug("execute Ognl {} : {}", id, param);
        }
        ExecuteResult result = new ExecuteResult();
        long start = System.currentTimeMillis();
        OgnlScriptContext scriptContext = cache.get(id);
        try {
            if (scriptContext != null) {
                doListenerBefore(scriptContext);
                scriptContext = cache.get(id);
                param = Colls.map(param);
                param.putAll(getGlobalVariable());
                Object obj = Ognl.getValue(scriptContext.getScript(), param, param);
                result.setSuccess(true);
                result.setResult(obj);
            } else {
                result.setSuccess(false);
                result.setResult(null);
                result.setMessage(String.format("Ognl: %s not found!", id));
            }
            long end = System.currentTimeMillis();
            result.setUseTime(end - start);
        } catch (Exception e) {
            logger.error("execute SpEL error", e);
            result.setException(e);
        }
        doListenerAfter(scriptContext, result);
        return result;
    }

    class OgnlScriptContext extends ScriptContext {
        private Object script;

        public OgnlScriptContext(String id, String md5, Object script) {
            super(id, md5);
            this.script = script;
        }

        public Object getScript() {
            return script;
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy