[FIX] lp 703649
[odoo/odoo.git] / bin / addons / base / res / res_company.py
index 33d39a6..ba4c0fa 100644 (file)
@@ -1,6 +1,6 @@
 # -*- coding: utf-8 -*-
 ##############################################################################
-#    
+#
 #    OpenERP, Open Source Management Solution
 #    Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
 #
@@ -15,7 +15,7 @@
 #    GNU Affero General Public License for more details.
 #
 #    You should have received a copy of the GNU Affero General Public License
-#    along with this program.  If not, see <http://www.gnu.org/licenses/>.     
+#    along with this program.  If not, see <http://www.gnu.org/licenses/>.
 #
 ##############################################################################
 
@@ -24,7 +24,7 @@ from osv import fields
 import os
 import tools
 from tools.translate import _
-
+from tools.safe_eval import safe_eval as eval
 
 class multi_company_default(osv.osv):
     """
@@ -42,7 +42,7 @@ class multi_company_default(osv.osv):
         'company_dest_id': fields.many2one('res.company', 'Default Company', required=True,
             help='Company to store the current record'),
         'object_id': fields.many2one('ir.model', 'Object', required=True,
-            help='Object affect by this rules'),
+            help='Object affected by this rule'),
         'expression': fields.char('Expression', size=256, required=True,
             help='Expression, must be True to match\nuse context.get or user (browse)'),
         'field_id': fields.many2one('ir.model.fields', 'Field', help='Select field property'),
@@ -72,6 +72,7 @@ multi_company_default()
 class res_company(osv.osv):
     _name = "res.company"
     _description = 'Companies'
+    _order = 'name'
     _columns = {
         'name': fields.char('Company Name', size=64, required=True),
         'parent_id': fields.many2one('res.company', 'Parent Company', select=True),
@@ -80,14 +81,28 @@ class res_company(osv.osv):
         'rml_header1': fields.char('Report Header', size=200),
         'rml_footer1': fields.char('Report Footer 1', size=200),
         'rml_footer2': fields.char('Report Footer 2', size=200),
-        'rml_header' : fields.text('RML Header'),
-        'rml_header2' : fields.text('RML Internal Header'),
+        'rml_header' : fields.text('RML Header', required=True),
+        'rml_header2' : fields.text('RML Internal Header', required=True),
+        'rml_header3' : fields.text('RML Internal Header', required=True),
         'logo' : fields.binary('Logo'),
         'currency_id': fields.many2one('res.currency', 'Currency', required=True),
         'currency_ids': fields.one2many('res.currency', 'company_id', 'Currency'),
-        'user_ids': fields.many2many('res.users', 'res_company_users_rel', 'cid', 'user_id', 'Accepted Users')
+        'user_ids': fields.many2many('res.users', 'res_company_users_rel', 'cid', 'user_id', 'Accepted Users'),
+        'account_no':fields.char('Account No.', size=64),
     }
 
+    def _search(self, cr, uid, args, offset=0, limit=None, order=None,
+            context=None, count=False, access_rights_uid=None):
+
+        if context is None:
+            context = {}
+        user_preference = context.get('user_preference', False)
+        if user_preference:
+            user = self.pool.get('res.users').browse(cr, uid, uid, context=context)
+            cmp_ids = list(set([user.company_id.id] + [cmp.id for cmp in user.company_ids]))
+            return cmp_ids
+        return super(res_company, self)._search(cr, uid, args, offset=offset, limit=limit, order=order,
+            context=context, count=count, access_rights_uid=access_rights_uid)
 
     def _company_default_get(self, cr, uid, object=False, field=False, context=None):
         """
@@ -98,33 +113,27 @@ class res_company(osv.osv):
         proxy = self.pool.get('multi_company.default')
         args = [
             ('object_id.model', '=', object),
+            ('field_id', '=', field),
         ]
-        if field:
-            args.append(('field_id.name','=',field))
-        else:
-            args.append(('field_id','=',False))
-        print args
+
         ids = proxy.search(cr, uid, args, context=context)
+        user = self.pool.get('res.users').browse(cr, uid, uid, context=context)
         for rule in proxy.browse(cr, uid, ids, context):
-            user = self.pool.get('res.users').browse(cr, uid, uid)
             if eval(rule.expression, {'context': context, 'user': user}):
-                print 'found', object
                 return rule.company_dest_id.id
-        user_company_id = self.pool.get('res.users').browse(cr, uid, uid).company_id.id
-        print 'not found', object
-        return user_company_id
+        return user.company_id.id
 
     def _get_child_ids(self, cr, uid, uid2, context={}):
         company = self.pool.get('res.users').company_get(cr, uid, uid2)
         ids = self._get_company_children(cr, uid, company)
         return ids
 
+    @tools.cache()
     def _get_company_children(self, cr, uid=None, company=None):
         if not company:
             return []
         ids =  self.search(cr, uid, [('parent_id','child_of',[company])])
         return ids
-    _get_company_children = tools.cache()(_get_company_children)
 
     def _get_partner_hierarchy(self, cr, uid, company_id, context={}):
         if company_id:
@@ -148,14 +157,20 @@ class res_company(osv.osv):
     def cache_restart(self, cr):
         self._get_company_children.clear_cache(cr.dbname)
 
-    def create(self, cr, *args, **argv):
+    def create(self, cr, uid, vals, context=None):
+        if not vals.get('name', False) or vals.get('partner_id', False):
+            self.cache_restart(cr)
+            return super(res_company, self).create(cr, uid, vals, context=context)
+        obj_partner = self.pool.get('res.partner')
+        partner_id = obj_partner.create(cr, uid, {'name': vals['name']}, context=context)
+        vals.update({'partner_id': partner_id})
         self.cache_restart(cr)
-        return super(res_company, self).create(cr, *args, **argv)
+        company_id = super(res_company, self).create(cr, uid, vals, context=context)
+        obj_partner.write(cr, uid, partner_id, {'company_id': company_id}, context=context)
+        return company_id
 
     def write(self, cr, *args, **argv):
         self.cache_restart(cr)
-        # Restart the cache on the company_get method
-        self.pool.get('ir.rule').domain_get.clear_cache(cr.dbname)
         return super(res_company, self).write(cr, *args, **argv)
 
     def _get_euro(self, cr, uid, context={}):
@@ -164,39 +179,52 @@ class res_company(osv.osv):
         except:
             return False
 
-    def _check_recursion(self, cr, uid, ids):
-        level = 100
-        while len(ids):
-            cr.execute('select distinct parent_id from res_company where id in ('+','.join(map(str, ids))+')')
-            ids = filter(None, map(lambda x:x[0], cr.fetchall()))
-            if not level:
-                return False
-            level -= 1
-        return True
+    def _get_logo(self, cr, uid, ids):
+        return open(os.path.join(
+            tools.config['root_path'], '..', 'pixmaps', 'openerp-header.png'),
+                    'rb') .read().encode('base64')
 
+    def _get_header3(self,cr,uid,ids):
+        return """
+<header>
+<pageTemplate>
+    <frame id="first" x1="28.0" y1="28.0" width="786" height="525"/>
+    <pageGraphics>
+        <fill color="black"/>
+        <stroke color="black"/>
+        <setFont name="DejaVu Sans" size="8"/>
+        <drawString x="25" y="555"> [[ formatLang(time.strftime("%Y-%m-%d"), date=True) ]]  [[ time.strftime("%H:%M") ]]</drawString>
+        <setFont name="DejaVu Sans Bold" size="10"/>
+        <drawString x="382" y="555">[[ company.partner_id.name ]]</drawString>
+        <stroke color="#000000"/>
+        <lines>25 550 818 550</lines>
+    </pageGraphics>
+    </pageTemplate>
+</header>"""
     def _get_header2(self,cr,uid,ids):
         return """
         <header>
         <pageTemplate>
-        <frame id="first" x1="1.3cm" y1="1.5cm" width="18.4cm" height="26.5cm"/>
+        <frame id="first" x1="28.0" y1="28.0" width="539" height="772"/>
         <pageGraphics>
         <fill color="black"/>
         <stroke color="black"/>
         <setFont name="DejaVu Sans" size="8"/>
-        <drawString x="1.3cm" y="28.3cm"> [[ formatLang(time.strftime("%Y-%m-%d"), date=True) ]]  [[ time.strftime("%H:%M") ]]</drawString>
+        <drawString x="1.0cm" y="28.3cm"> [[ formatLang(time.strftime("%Y-%m-%d"), date=True) ]]  [[ time.strftime("%H:%M") ]]</drawString>
         <setFont name="DejaVu Sans Bold" size="10"/>
-        <drawString x="9.8cm" y="28.3cm">[[ company.partner_id.name ]]</drawString>
-        <setFont name="DejaVu Sans" size="8"/>
-        <drawRightString x="19.7cm" y="28.3cm"><pageNumber/> /  </drawRightString>
-        <drawString x="19.8cm" y="28.3cm"><pageCount/></drawString>
+        <drawString x="9.3cm" y="28.3cm">[[ company.partner_id.name ]]</drawString>
         <stroke color="#000000"/>
-        <lines>1.3cm 28.1cm 20cm 28.1cm</lines>
+        <lines>1.0cm 28.1cm 20.1cm 28.1cm</lines>
         </pageGraphics>
         </pageTemplate>
 </header>"""
     def _get_header(self,cr,uid,ids):
         try :
-            return tools.file_open(os.path.join('base', 'report', 'corporate_rml_header.rml')).read()
+            header_file = tools.file_open(os.path.join('base', 'report', 'corporate_rml_header.rml'))
+            try:
+                return header_file.read()
+            finally:
+                header_file.close()
         except:
             return """
     <header>
@@ -204,7 +232,7 @@ class res_company(osv.osv):
         <frame id="first" x1="1.3cm" y1="2.5cm" height="23.0cm" width="19cm"/>
         <pageGraphics>
             <!-- You Logo - Change X,Y,Width and Height -->
-        <image x="1.3cm" y="27.6cm" height="40.0" >[[company.logo]]</image>
+            <image x="1.3cm" y="27.6cm" height="40.0" >[[ company.logo or removeParentNode('image') ]]</image>
             <setFont name="DejaVu Sans" size="8"/>
             <fill color="black"/>
             <stroke color="black"/>
@@ -235,11 +263,13 @@ class res_company(osv.osv):
     _defaults = {
         'currency_id': _get_euro,
         'rml_header':_get_header,
-        'rml_header2': _get_header2
+        'rml_header2': _get_header2,
+        'rml_header3': _get_header3,
+        #'logo':_get_logo
     }
 
     _constraints = [
-        (_check_recursion, 'Error! You can not create recursive companies.', ['parent_id'])
+        (osv.osv._check_recursion, 'Error! You can not create recursive companies.', ['parent_id'])
     ]
 
 res_company()