2008-07-23 15:01:27 +00:00
# -*- encoding: utf-8 -*-
2006-12-07 13:41:40 +00:00
##############################################################################
2009-10-14 12:32:15 +00:00
#
# OpenERP, Open Source Management Solution
# Copyright (C) 2004-2009 Tiny SPRL (<http://tiny.be>).
2008-06-16 11:00:21 +00:00
#
2008-11-03 18:27:16 +00:00
# This program is free software: you can redistribute it and/or modify
2009-10-14 12:32:15 +00:00
# it under the terms of the GNU Affero General Public License as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
2006-12-07 13:41:40 +00:00
#
2008-11-03 18:27:16 +00:00
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
2009-10-14 12:32:15 +00:00
# GNU Affero General Public License for more details.
2006-12-07 13:41:40 +00:00
#
2009-10-14 12:32:15 +00:00
# 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/>.
2006-12-07 13:41:40 +00:00
#
##############################################################################
from osv import osv , fields
# -------------------------------------------------------------------------
# Properties
# -------------------------------------------------------------------------
def _models_get2 ( self , cr , uid , context = { } ) :
2008-07-22 14:24:36 +00:00
obj = self . pool . get ( ' ir.model.fields ' )
ids = obj . search ( cr , uid , [ ( ' view_load ' , ' = ' , 1 ) ] )
res = [ ]
done = { }
for o in obj . browse ( cr , uid , ids , context = context ) :
if o . relation not in done :
res . append ( [ o . relation , o . relation ] )
done [ o . relation ] = True
return res
2006-12-07 13:41:40 +00:00
def _models_get ( self , cr , uid , context = { } ) :
2008-07-22 14:24:36 +00:00
obj = self . pool . get ( ' ir.model.fields ' )
ids = obj . search ( cr , uid , [ ( ' view_load ' , ' = ' , 1 ) ] )
res = [ ]
done = { }
for o in obj . browse ( cr , uid , ids , context = context ) :
if o . model_id . id not in done :
res . append ( [ o . model_id . model , o . model_id . name ] )
done [ o . model_id . id ] = True
return res
2006-12-07 13:41:40 +00:00
class ir_property ( osv . osv ) :
2008-07-22 14:24:36 +00:00
_name = ' ir.property '
_columns = {
' name ' : fields . char ( ' Name ' , size = 128 ) ,
' value ' : fields . reference ( ' Value ' , selection = _models_get2 , size = 128 ) ,
' res_id ' : fields . reference ( ' Resource ' , selection = _models_get , size = 128 ) ,
' company_id ' : fields . many2one ( ' res.company ' , ' Company ' ) ,
' fields_id ' : fields . many2one ( ' ir.model.fields ' , ' Fields ' , ondelete = ' cascade ' , required = True )
}
def unlink ( self , cr , uid , ids , context = { } ) :
if ids :
cr . execute ( ' delete from ir_model_fields where id in (select fields_id from ir_property where (fields_id is not null) and (id in ( ' + ' , ' . join ( map ( str , ids ) ) + ' ))) ' )
res = super ( ir_property , self ) . unlink ( cr , uid , ids , context )
return res
2006-12-28 14:41:28 +00:00
2008-07-22 14:24:36 +00:00
def get ( self , cr , uid , name , model , res_id = False , context = { } ) :
cr . execute ( ' select id from ir_model_fields where name= %s and model= %s ' , ( name , model ) )
res = cr . fetchone ( )
if res :
ucid = self . pool . get ( ' res.users ' ) . browse ( cr , uid , uid ) . company_id . id
nid = self . search ( cr , uid , [ ( ' fields_id ' , ' = ' , res [ 0 ] ) , ( ' res_id ' , ' = ' , res_id ) , ( ' company_id ' , ' = ' , ucid ) ] )
if nid :
d = self . browse ( cr , uid , nid [ 0 ] , context ) . value
return ( d and int ( d . split ( ' , ' ) [ 1 ] ) ) or False
return False
2006-12-07 13:41:40 +00:00
ir_property ( )
2008-07-23 15:01:27 +00:00
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4: