workflow中的‘非典型’自动触发器trigger_model

原文:http://cn.openerp.cn/workflow%E4%B8%AD%E7%9A%84%E9%9D%9E%E5%85%B8%E5%9E%8B%E8%87%AA%E5%8A%A8%E8%A7%A6%E5%8F%91%E5%99%A8trigger_model/

Openerp中workflow的设计机制

工作流程系统在OpenERP里是非常有用的机制,可以用于即时描述单据(模型)状态的演进过程。工作流实现了状态流转的可配置,通过迁移的condition代替python代码中的判断语句,通过迁移的signal增加审批按钮,增加了系统的灵活性。工作流程是完全可以定制的,这些流程可以调整适用于几乎所有公司的作业流程和交易逻辑。 这个工作流程系统使OpenERP非常有弹性, 而且可以不用编程增加新功能,就可以支持不断变化的需要。对于单据的审批,以及对应的的动作,都可以在OE的工作流中定义解决,而不需要全在对象上进行编码。即工作流实现了流程处理与对象的业务逻辑的代码相分离,降低了不同处理代码的耦合性,增加了系统功能的柔软性。

如上所说工作流定义了对某一类型的对象,为model的处理流程,每当系统新产生一个model的实例(resource)时候,则对应产生一个工作流实例(workinstance)。如:创建sale.order实例时系统自动启动一个对应的工作流实例 。

简而言之就是工作流定义流程,工作流实例记录对象在流程的哪个阶段,如SO中,SO1在draft状态,SO2已经审批通过。

上面一方的大论过后,下面我们来揭开trigger_model的神秘面纱

工作流就像是隐藏在对象幕后的一个灵敏而又聪明的监视器,闻风而动,它并不会傻傻的每时每刻去检查这些条件,只有当对象发生了变化,这个监视器才会敏锐的捕获信息,随后去检查条件是否满足,可否迁移,当然,仅有这聪明和敏锐是难成大事的,所谓大师就是看到别人看不到的东西,下面我们看看:
当你创建了一张Sale Order,你想当它发货确认以后,就让Sale order的状态为Done,你确认Sale order的时候,它乖乖的会检查一次,当前处在未发货状态,condition为False,状态不能变,但是过几天我们发货了,这时你发现这工作流装死,它不给你的Sale Order状态改为 Done,你怒了,把这小子狠批一顿,工作流委屈的说,那是别人家的事(外部的对象)你得让他和我打个招呼…,于是你想想也有道理,于是你跑去别人家也装了监视器(子工作流),那边有变化就发个信号过来
这个监视器是这样设计的(子工作流):当Activity为subflow的类型时,进入该状态节点(activity)触发“subflow_id”中指定的工作流。在sale模块的workflow “wkf_sale”中, 需要开发票时候,它触发流程account模块中的工作流“account.invioce.basic” (field name=”subflow_id” ref=”account.wkf”)。 account.wkf处理完成后,发出信号subflow.paid 通知wkf_sale流程(field name=”signal_send”>subflow.paid<)。 销售订单的工作流中从invioce子工作流节点到invioce_end节点的transition条件中定义了信号subflow.paid=True,当条件满足时就实现状态跳转,用于父子流程通信的工作流signal必须是形如subflow.*

可是过几天麻烦来了,有人家不让你装这个监视器(有些对象没有定义工作流如stock.move),这可咋办,你为难了,这时候trigger_model闪亮登场

<field name="trigger_model">stock.move</field>
<field name="trigger_expr_id">[move_id.id]</field>

trigger_model:触发你去检查迁移条件的外部对象类型
trigger_expr_id:trigger_model类型的对象ids,可以是一段Python代码,也可以定义一个方法,返回ids

大喜之余,立马动手

<record id="ship_to_ongoing" model="workflow.transition">
   <field name="act_from" ref="state_ship" />
   <field name="act_to" ref="state_ongoing" />
   <field name="trigger_model">stock.picking</field>
   <field name="trigger_expr_id">[out_picking_id.id]</field>
   <field name="condition">test_out_shipping_done()</field>
</record>

沾沾自喜,再一次再一次被耍了,我改变picking对象状态的时候,它没有在去检查condition

What Amazing Happens! 低头grep…,目标出现。。。

./procurement/procurement_workflow.xml:171:            <field name="trigger_model">stock.move</field>
./procurement/procurement.py:431:            wf_service.trg_trigger(uid, 'procurement.order', id, cr)

映衬标题,‘非典型’触发器trigger_model,它并不是那么自动,你得在定义的模块中手动调用wf_service.trg_trigger方法,第一次触发的时候它在数据库中写入wkf_trigger:
1 model = trigger_model

2 res_ids = trigger_expr_id定义的ids

3 workitem_id = workitem id of act_from activity

4 inst_id = instance id of the wrk_flw (参见addons/base/ir/workflow/work.py 下的wkf_triggers)

wkf_trigger就像是一个过滤器,只有哪些对象的特定记录改变了,才会让这工作流去check

trigger_model这个神奇的利器在OpenERP 7.0却仅有中account.move.line, procurement.order 和 stock.move中 用到了

越厉害的东西越危险,高内聚低耦合的设计理念,openerp玩转自如,面纱已落地….

openerp 经典收藏 workflow中的‘非典型’自动触发器trigger_model(转载)的更多相关文章

  1. workflow中的‘非典型’自动触发器trigger_model

    Openerp中workflow的设计机制 工作流程系统在OpenERP里是非常有用的机制,可以用于即时描述单据(模型)状态的演进过程.工作流实现了状态流转的可配置,通过迁移的 condition代替 ...

  2. openerp经典收藏 深入理解对象(转载)

    深入理解对象(转载) 原文地址:http://shine-it.net/index.php/topic,2159.0.htmlhttp://blog.sina.com.cn/s/blog_57ded9 ...

  3. openerp经典收藏 深入理解工作流(Workflow)(转载)

    深入理解工作流(Workflow) 原文:http://shine-it.net/index.php/topic,2494.0.html 一.工作流定义:<?xml version=" ...

  4. openerp 经典收藏 Openerp开发进销存系统完毕总结(转载)

    原文地址:http://blog.csdn.net/heartrude/article/details/9142463 Openerp开发进销存系统完毕总结 分类: 代码历程 OpenERP 工程思想 ...

  5. openerp 经典收藏 记录规则 – 销售只能看到自己的客户,经理可以看到全部(转载)

    记录规则 – 销售只能看到自己的客户,经理可以看到全部 原文地址:http://cn.openerp.cn/record_rule/ OpenERP中的权限管理有四个层次: 菜单级别: 即,不属于指定 ...

  6. openerp经典收藏 OpenERP库存管理的若干概念讲解(新增库存价值)(转载)

    OpenERP库存管理的若干概念讲解(新增库存价值) 原文:http://shine-it.net/index.php/topic,2425.0/topicseen.html 一.复式库存(Doubl ...

  7. openerp经典收藏 对象定义详解(转载)

    对象定义详解 原文地址:http://shine-it.net/index.php/topic,2159.0.htmlhttp://blog.sina.com.cn/s/blog_57ded94e01 ...

  8. openerp经典收藏 深入理解报表运行机制(转载)

    深入理解报表运行机制 原文:http://blog.sina.com.cn/s/blog_57ded94e01014ppd.html 1) OpenERP报表的基本运行机制    OpenERP报表的 ...

  9. openerp经典收藏 对象的预定义方法(转载)

    对象的预定义方法 原文:http://shine-it.net/index.php/topic,2159.15.html 每个OpenERP的对象都有一些预定义方法,这些方法定义在基类osv.osv中 ...

随机推荐

  1. CSDN中根据文章自动生成文章目录

    概述 CSDN中有根据文件内容中H标签在文章中自动生成文章目录,看起来比较专业,就想把它搬到自己的博客园中.类似下图 提取JS脚本 通过浏览器开发者工具(IE/Chrome)找到产生文章目录javas ...

  2. MySQL关于InnoDB的几个错误

    阿里云服务器上装有MySQL 5.6,这几天MySQL服务经常死掉,启动MySQL服务(service mysql start),却报如下错误 Starting MySQL.. ERROR! The ...

  3. 获取数组排序后的index算法实现

    需求: 一个数组var arr = [4,7,2,9],排序后的新数组var newArr = [2,4,7,9]或者[9,7,4,2] 我们要得到的是排序后元数组的每一项在新数组中的位置所构成的数组 ...

  4. 转:从三层架构到MVC-MVP

    当然这种架构模式本身的一些问题也会在接下来的内容就加以介绍,另外就是如果大家有什么不同观点的话,欢迎拍砖(只要不打脸就行,呵呵). 一. MVC是谁提出的 模型-视图-控制器(MVC)是Xerox P ...

  5. HttpServletResponse接口

    public interface HttpServletResponse extends ServletResponse 描述一个返回到客户端的HTTP回应.这个接口允许Servlet程序员利用HTT ...

  6. 查询score中选学多门课程的同学中分数为非最高分成绩的记录。

    20.查询score中选学多门课程的同学中分数为非最高分成绩的记录. select * from score a where sno in ( select sno from score group ...

  7. linux和Windows下文本格式转换

    1.安装转换工具:sudo apt-get install tofrodos 2.开始转换:fromdos grade.sh

  8. 使用Boost asio实现异步的TCP/IP通信

    可以先了解一下Boost asio基本概念,以下是Boost asio实现的异步TCP/IP通信: 服务器: #include "stdafx.h" #include <io ...

  9. ORA-01502错误成因和解决方法

    这个错误是由于索引失效造成的,重建索引后,问题就解决了. 我们看到,当使用类似 alter table xxxxxx move tablespace xxxxxxx 命令后,索引就会失效. 当然,作为 ...

  10. Javascript计算中英文混输字符串长度V2

    同上篇, client端也需要同样规则验证 compact_strlen: function(str) { var strlen = 0; for(var i =0; i<str.length; ...