Rails 中的扩展

最近公司一个项目,需要将新网站接入美国总部的 ERP 系统,同时对流程做一部分的扩展。在这之中碰到的最大的问题,就是没有旧系统的设计并不符合 ERP 的需求,而因为要保证整个过程的无缝链接以及敏感数据的安全,对于数据库的改动限制非常大。

同事 Daniel 负责这次的更新,我们对这个问题也讨论过好多次,在 Rails 如何实现这样的功能呢。最后选出了一种不破坏旧系统的结构,也不需要数据导入的方式。只在需要进行 ERP 扩展的对象上增加相应的字段,然后使用 Order 对象的子类 ERPOrder 进行封装,将这个类传递到 ERP 系统代替原来的 order 对象。这样下来,几乎整个 ERP 的交互过程不需要做太大的改动,流程控制也变得简单且清晰,状态判断以及异常处理也变得非常合理,代码精简不少。

对 ERPOrder 类的编码中,深刻体会到 Ruby 语言的动态性带来的便利。为了避免这次的情况,能为以后更新版本的系统提供兼容,我们将很多业务逻辑抽取出来,作为 module mix in 到 erp 对象中。以后即使系统再次升级,也不用担心是否会影响到 order 对象本身的业务逻辑以及数据验证。

不过对于 Ruby 中的  module,mixin,include 机制还不是了解得很透彻,以后要多学习了。

Comments

comments powered by Disqus