使用OpenERP自定义模块开发的时候,你会发现,有一个uid(当前登录用户id)特别好用,不管是在xml的domain

条件表达式中,还是在类中,都能很方便的使用uid.有一段时间就一直在琢磨,这个uid 是什么时候赋值的。感觉是在

session中,一直没有找到。后来需要获取当前登录人的部门id,把department_id做成类似uid这么的变量,就爽了,就

太方便了。

注:Search 资料显示     ['&',('department', '=', user.context_department_id.id),('state', '=', 'pr_draft')]

提示context_department_id不存在,其实这是OE7.0之前的用法,6.0中有类似的方法定义:

  1. def get_users_department(self, val):
  2. dep = val.get('department')
  3. fields = ['name']
  4. data = [dep]
  5. if not dep:
  6. return False
  7. return self.import_object(fields, data, 'hr.department', 'hr_department_user', dep)
  8. def get_user_mapping(self):
  9. return {
  10. 'model' : 'res.users',
  11. 'hook' : self.import_user,
  12. 'map' : {
  13. 'name': concat('first_name', 'last_name'),
  14. 'login': value('user_name', fallback='last_name'),
  15. 'context_lang' : 'context_lang',
  16. 'password' : 'password',
  17. '.id' : '.id',
  18. 'context_department_id/id': self.get_users_department,
  19. 'user_email' : 'email1',
  20. }
  21. }

其实也不是那么神秘,当你实现了下面的步骤:

1)  在context中写入自己的东西(测试)

1.1) 定义一个扩展类,是函数字段

  1. class extend_user(osv.osv):
  2. _name = "res.users"
  3. _inherit = ['res.users']
  4. # 返回我的id
  5. def _write_mine_id(self, cr, uid, ids, name, args, context=None):
  6. result =  dict.fromkeys(ids, 1024)
  7. return result
  8. _columns = {
  9. 'context_mine_id': fields.function( _write_mine_id,type="integer"),
  10. }
  11. extend_user()

1.2)  在Firefox的Debug下,看请求,奇迹发生了

说明:  不是当时的截图,应该是{"mine_id:": 1024}

1.3)  原理剖析

抽时间在做梳理了

2)  在context中写入当前登录人department_id

2.1)  修改上面的类文

  1. class extend_user(osv.osv):
  2. _name = "res.users"
  3. _inherit = ['res.users']
  4. # 获取用户关联的部门
  5. def _get_self_department_ids(self, cr, uid, ids, name, args, context=None):
  6. result = dict.fromkeys(ids, False)
  7. emp = self.pool.get('hr.employee')
  8. for id in ids:
  9. emp_ids = emp.search(cr, uid, [('user_id', '=', id)], context=context)
  10. emp = emp.browse(cr, uid, emp_ids[0], context=context)
  11. result[id] = emp.department_id
  12. return result
  13. _columns = {
  14. 'context_department_id': fields.function(_get_self_department_ids,type="hr.department"),
  15. }
  16. extend_user()

2.2)  结果看上面的截图,出来了

2.3)  注意函数字段的类型是  type="hr.department",你没看错就是这个

2.4) 获取部门id另一种方法,职员同名存在问题

  1. def get_current_user_department_id(self, cr, uid, ids, context=None):
  2. list_resource_id = self.pool.get('resource.resource').search(cr, uid, [('user_id','=',uid)], context=context)
  3. username = self.pool.get('resource.resource').browse(cr, uid, list_resource_id[0], context=context).name
  4. list_emp_id = self.pool.get('hr.employee').search(cr, uid, [('name_related','=',username)], context=context)
  5. depart_id = self.pool.get('hr.employee').browse(cr, uid, list_emp_id[0], context=context).department_id
  6. return depart_id

注意:这个return 的depart_id 可不是integer类型,raise Exception(type(depart_id))  :

Exception: <class 'openerp.osv.orm.browse_record'>

raise osv.except_osv(_("test"), _(depart_id))

OpenERP 在context中写自己的部门ID的更多相关文章

  1. 关于如何在其他包中写controller和简单介绍@SpringBootApplication

    本文参考博客:https://blog.csdn.net/u013473691/article/details/52353923 关于@Configuration和@Bean参考博客:https:// ...

  2. 在mybatis中写sql语句的一些体会

    本文会使用一个案例,就mybatis的一些基础语法进行讲解.案例中使用到的数据库表和对象如下: article表:这个表存放的是文章的基础信息 -- ------------------------- ...

  3. 一种获取context中keys和values的高效方法 | golang

    我们知道,在 golang 中的 context 是一个非常重要的包,保存了代码活动的上下文.我们经常使用 WithValue() 这个方法,来往 context 中 传递一些 key value 数 ...

  4. x01.os.12: 在 windows 中写 OS

    在 windows 中写操作系统,需要一系列的辅助工具.在此,要感谢川谷秀实!所有工具,都在 z_tools 文件夹中.有了大师的帮助,不妨也来尝试在 windows 中写一把 OS. 源代码及工具可 ...

  5. oracle调用java方法的例子(下面所有代码都是在sql/plus中写)

    在Oracle中调用Java程序,注意:java方法必须是static类型的,如果想在JAVA中使用system.out/err输出log. 需要在oracle 中执行"call dbms_ ...

  6. 【Filter 不登陆无法访问】web项目中写一个过滤器实现用户不登陆,直接给链接,无法进入页面的功能

    在web项目中写一个过滤器实现用户不登陆,直接给链接,无法进入页面,而重定向到登陆界面的功能. 项目是用springMVC+spring+hibernate实现 (和这个没有多大关系) 第一步: 首先 ...

  7. python中写shell(转)

    python中写shell,亲测可用,转自stackoverflow To run a bash script, copy from stackoverflow def run_script(scri ...

  8. css笔记——关于css中写上charset “utf-8”

    当css文件中写上 charset "utf-8" 时需要将body和html的样式分开写 例如: html,body{margin:0;padding:0;font-family ...

  9. 用RelativeLayout布局可以在imageview中写上文字

    <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android=&quo ...

随机推荐

  1. WordPress Permissions Update Error [RESOLVED]

    Recently I ran into an issue where an installation of WordPress that had never had any issues updati ...

  2. Lingoes 一款功能强大、简明易用的多语言词典和文本翻译软件

    Lingoes 软件自述 Lingoes 是一款功能强大.简明易用的多语言词典和文本翻译软件,支持多达80种语言互查互译,这些语言包括 英.法.德.意.俄.中.日.韩.西.葡.阿拉伯语 及更多... ...

  3. USB Mass Storage Class – Bulk Only Transport - Error Handling

    6.4 Device Error Handling The device may not be able to fully satisfy the host's request. At the poi ...

  4. [Asp.net MVC]HandleErrorAttribute异常过滤器

    摘要 在asp.net mvc中除了使用try...catch/finally来处理异常外,它提供了一种通过在Controller或者Action上添加特性的方式来处理异常. HandleErrorA ...

  5. [转载] MATLAB快捷键

    原文地址,点此查看 一.常用对象操作 除了一般windows窗口的常用功能键外. 1.!dir 可以查看当前工作目录的文件. !dir& 可以在dos状态下查看. 2.who   可以查看当前 ...

  6. pytest文档25-conftest.py作用范围

    前言 一个测试工程下是可以有多个conftest.py的文件,一般在工程根目录放一个conftest.py起到全局作用. 在不同的测试子目录也可以放conftest.py,作用范围只在该层级以及以下目 ...

  7. 用JavaScript,获取Table中指定的行、列

    前言: 先要谢谢George Wing的慷慨赠书<悟透JavaScript>,让我更加感受到了技术交流的重要性,呵呵~ 进入正题,面试题中有一题:如何通过JavaScript获取Table ...

  8. 一款DIY移动电源的性能

    文波很大 就这款产品,质量非常一般后面拿品胜的做个对比

  9. NFV/SDN驱动OSS转型

  10. [Android Pro] activity-alias的使用

    activity-alias是android里为了重复使用Activity而设计的. 当在Activity的onCreate()方法里,执行getIntent().getComponent().get ...