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

com.alogic.timer.core.LinkedScriptDoer Maven / Gradle / Ivy

There is a newer version: 1.6.17
Show newest version
package com.alogic.timer.core;

import java.util.HashMap;
import java.util.Map;

import org.apache.commons.lang3.StringUtils;
import org.w3c.dom.Element;

import com.alogic.xscript.Logiclet;
import com.alogic.xscript.LogicletContext;
import com.alogic.xscript.Script;
import com.anysoft.util.Properties;
import com.anysoft.util.PropertiesConstants;
import com.anysoft.util.XmlElementProperties;
import com.alogic.xscript.doc.XsObject;
import com.alogic.xscript.doc.json.JsonObject;

/**
 * 外部脚本处理者
 * 
 * @author duanyy
 *
 * @since 1.6.4.34
 * @version 1.6.8.14 [20170509 duanyy] 
* - 增加xscript的中间文档模型,以便支持多种报文协议
* * @version 1.6.9.2 [20170601 duanyy]
* - 改造TaskCenter模型,以便提供分布式任务处理支持;
*/ public class LinkedScriptDoer extends Doer.Abstract{ protected Logiclet stmt = null; @Override public void execute(Task task) { if (stmt == null){ LOG.error("The script is null"); return ; } try { // 向队列报告任务已经开始 onStart(task.id(),Task.State.Running, 0,""); Map root = new HashMap(); XsObject doc = new JsonObject("root",root); LogicletContext ctx = new LogicletContext(task.getParameters()); ctx.SetValue("$task", task.id()); ctx.SetValue("$event", task.getEventId()); // 执行任务 stmt.execute(doc,doc,ctx, null); // 任务完成 onFinish(task.id(),Task.State.Done, 10000,""); } catch (Exception t) { LOG.error("Failed to execute script", t); // 任务失败 onFinish(task.id(),Task.State.Failed, 10000,"Failed to execute script:" + t.getMessage()); } } @Override public void configure(Element _e, Properties _properties){ Properties p = new XmlElementProperties(_e,_properties); String src = PropertiesConstants.getString(p, "src",""); if (StringUtils.isNotEmpty(src)) { stmt = Script.create(src, p); }else{ LOG.error("Can not find script src"); } configure(p); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy