O2OA提供的服务管理中心可以让用户使用Javascript语言自由编写脚本的处理逻辑来实现与第三方的数据交互,数据同步以及系统内的数据处理等工作,也可以编写系统内的定时任务脚本。本文主要介绍O2OA系统定时代理和接口的脚本编写。
O2OA中复杂的应用通常需要通过Javascript来实现。根据运行环境的差异,分为前后端脚本。
前端脚本是运行在浏览器上的,本系统的前端脚本基于mootools来构建,遵循ECMAScript 5.1规范。
后端脚本运行在服务器上,基于JDK8标准的Nashorn,遵循ECMAScript 5.1规范。
前端脚本在本系统的WebAPI中有详细介绍,这里不再过多介绍。
后端脚本在视图列脚本、流程事件、接口和代理中都有使用,并且这些地方的上下文都有不同。
前端脚本 | 视图列 | 流程事件 | 接口和代理 | |
运行环境 | 浏览器 | 服务器端 | 服务器端 | 服务器端 |
访问DOM对象 | 允许 | 不允许 | 不允许 | 不允许 |
使用JAVA | 不允许 | 不允许 | 允许 | 允许 |
总结上表,我们在代理和接口的代码中可以使用的规则:
1、使用JavaScript语法来编写定时代理和接口的代码。
2、对o2oa的功能,可以调用后端api来进行调用。
3、另外,还可以调用Java类处理一些功能。
我们通过下面的例子,可以看出这是典型的ECMAScript 5写法。
var appId = "6e075ac7-3eb3-436f-8ba1-e98f9b64349e"; //流程应用id var process = "4cca966f-3682-45c8-bddc-f2980654dc5e"; //流程id var data = JSON.parse(this.requestText); //通过api this.requestText获取外部传入的初始数据 data.application = appId; data.process = process; //通过api this.Actions加载流程服务根 var action = this.Actions.load("x_processplatform_service_processing"); action.WorkAction.assignCreate(//发起流程 data,//body请求参数 function (json) { //服务调用成功的回调函数, json为服务传回的数据 print("流程启动返回的数据为="+JSON.stringify(json); //在服务器控制台输出 this.response.setBody("success!"); //通过api this.response来响应请求 }.bind(this), function (json) { //服务调用失败的回调函数, json为服务传回的数据 console.error("流程启动失败"); //在服务器控制台输出错误 this.response.setBody(json); }.bind(this) );
在6.3及以后版本,o2oa提供了后台API来编写脚本和代理。
打开地址:http://{hostname}/api,如:https://www.o2oa.net/api
我们在API中提供的功能如下:
//classString 为类名字符串,比如 "java.util.Calendar" var Class = Java.type( classString ); var object = new Class(); //object.method() 或者 var object = new Class(); //比如 var simpleDateFormat = new java.text.SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); 样例: 获取当前日期后的第5天 function setDate(){ var Date = java.util.Date(); var Calendar = Java.type("java.util.Calendar"); var GregorianCalendar = Java.type("java.util.GregorianCalendar"); var now = new Date(); var calendar = new GregorianCalendar(); calendar.setTime(now); calendar.set(Calendar.DATE, calendar.get(Calendar.DATE) - Config.waitDay); return calendar.getTime(); }
在6.3版本之前的版本,我们还未提供后台api,可以通过以下方式进行脚本编写。
var text = "在服务器控制台输出的消息" print( text );
服务查看和调试需要打开 http://centerserver/x_program_center/jest/list.html
请注意,V7.2之前端口为20030:
http://centerserver:20030/x_program_center/jest/list.html
本小节中的“服务根(serviceRoot)”如下:
x_processplatform_assemble_surface | 流程平台相关服务 |
x_portal_assemble_surface | 门户平台相关服务 |
x_cms_assemble_control | 内容管理平台相关服务 |
x_query_assemble_surface | 数据平台相关服务 |
x_organization_assemble_express | 组织架构相关服务 |
x_file_assemble_control | 云文件相关服务 |
x_meeting_assemble_control | 会议管理相关服务 |
x_bbs_assemble_control | 论坛相关服务 |
x_calendar_assemble_control | 日程管理相关服务 |
x_hotpic_assemble_control | 热点信息相关服务 |
x_mind_assemble_control | 脑图模块相关服务 |
x_organization_assemble_personal | 个人设置相关服务 |
x_attendance_assemble_control | 考勤模块相关服务 |
查找method,后台服务有GETPOSTPUTDELET几种方法,可以在服务详情中找到,如下图:
本小节中的“路径(path)”,可以在服务详情中找到,如下图:
以上图的服务为例,最后拼接成下列两种路径均可使用
/jaxrs/work/workorworkcompleted/dcd8e168-2da0-4496-83ee-137dc976c7f6
或
work/workorworkcompleted/dcd8e168-2da0-4496-83ee-137dc976c7f6
var applications = resources.getContext().applications(); //serviceRoot 服务根 //path 路径 applications.getQuery( serviceRoot, path ); //样例: //已知work id为dcd8e168-2da0-4496-83ee-137dc976c7f6,获取work内容,并解析成JSON。 var applications = resources.getContext().applications(); var serviceRoot = "x_processplatform_assemble_surface"; var path = "work/workorworkcompleted/dcd8e168-2da0-4496-83ee-137dc976c7f6" var resp = applications.getQuery( serviceRoot, path ); var json = JSON.parse( resp.toString() );
var applications = resources.getContext().applications(); //serviceRoot 服务根 //path 路径 //string 数据字符串,json转字符串可以用 JSON.stringify( json ) applications.postQuery( serviceRoot, path, string );
样例:
已知发文流程的ID为“0b7c5c43-caa8-4789-a263-308508d44016”,发起人的dn是“张三@zhangsan@I”。需要发起一个流程。
查到发起流程的路径是“jaxrs/work/process/{processFlag}”。
var applications = resources.getContext().applications(); var serviceRoot = "x_processplatform_assemble_surface"; var path = "work/process/0b7c5c43-caa8-4789-a263-308508d44016"; var string = JSON.stringify({ "latest" : false, "title" : "测试发文流程", "identity" : "张三@zhangsan@I", "data" : { //业务数据 "fileNoPrefix" : "xxx" //文号冠字 } }); var resp = applications.postQuery( serviceRoot, path, string ); var json = JSON.parse( resp.toString() );
var applications = resources.getContext().applications(); //serviceRoot 服务根 //path 路径 //string 数据字符串,json转字符串可以用 JSON.stringify( json ) applications.putQuery( serviceRoot, path, string );
样例:
已知发文流程实例的work id为“0b7c5c43-caa8-4789-a263-308508d44016”,需要更新数据。
查到修改流程数据的路径是“jaxrs/data/work/{id}”。
var applications = resources.getContext().applications(); var serviceRoot = "x_processplatform_assemble_surface"; var path = "data/work/0b7c5c43-caa8-4789-a263-308508d44016"; var string = JSON.stringify({ "subject" : "测试流程11", "fileNoPrefix" : "xxx1" }); var resp = applications.putQuery( serviceRoot, path, string ); var json = JSON.parse( resp.toString() );
var applications = resources.getContext().applications(); //serviceRoot 服务根 //path 路径 applications.deleteQuery( serviceRoot, path );
样例:
已知发文流程实例的work id为“0b7c5c43-caa8-4789-a263-308508d44016”,需要删除改流程实例。
查到删除流程实例的路径是“jaxrs/work/{id}”。
var applications = resources.getContext().applications(); var serviceRoot = "x_processplatform_assemble_surface"; var path = "work/0b7c5c43-caa8-4789-a263-308508d44016"; var resp = applications.deleteQuery( serviceRoot, path ); var json = JSON.parse( resp.toString() );
样例:现有一个名称为“sendSMS”的接口,接收的requestText为 "{ mobile : mobile, content : content }"
var CipherConnectionAction = Java.type('com.x.base.core.project.connection.CipherConnectionAction'); var Config = Java.type('com.x.base.core.project.config.Config'); var path = "invoke/sendSMS/execute"; var dataString = JSON.stringify({ "mobile" : "13500000000", "content" : "测试短信内容" }); var resp = CipherConnectionAction.post(false, Config.url_x_program_center_jaxrs() + path, dataString ); //var resp = CipherConnectionAction.post(false, Config.x_program_centerUrlRoot() + path, dataString ); var json = JSON.parse( resp.toString() );
样例:现有一个外系统的服务,url为 'http://hostname/UnifiedWorkbench/ProcessTaskService',接收的Content-type 为 'text/xml; charset=utf-8'
function sendRequest( xml ){ try{ print("发起请求:"+xml); var url = 'http://hostname/UnifiedWorkbench/ProcessTaskService' var ArrayList = Java.type('java.util.ArrayList'); var heads = new ArrayList(); var NameValuePair = Java.type('com.x.base.core.project.bean.NameValuePair'); var p1 = new NameValuePair('Content-Type', 'text/xml; charset=utf-8'); heads.add(p1); var HttpConnectionClass = Java.type('com.x.base.core.project.connection.HttpConnection'); var resp = HttpConnectionClass.postAsString(url, heads, xml); print( "统一待办返回:"+ resp.toString()); }catch(e){ print("发送请求出错:"); print( e.printStackTrace() ); } }
组织管理中包括人员、人员属性、组织、组织属性、身份、群组和角色。有两种方法可以进行组织管理的操作:
1、通过调用后台组织查询服务“x_organization_assemble_express”进行组织管理的操作。具体服务请查看
http://{applicationServer}/x_organization_assemble_express/jest/index.html
其中:{applicationServer}为部署的服务器IP地址或者域名。
请注意,V7.2之前端口为20020:
http://{applicationServer}:20020/x_organization_assemble_express/jest/index.html
2、你可以通过 this.org 获取组织中的人员、人员属性、组织、组织属性、身份、群组和角色。
具体请查看API的org章节
以上是对定时代理和接口脚本编写的描述,希望对您有帮助。如果您想进一步了解服务和接口,可以查看以下文章:
《服务管理-定时代理开发》
《服务管理-接口服务开发》
《后端脚本api》
上一篇:服务管理-简介
下一篇:没有了!