[FIX] account: incorrect usage of browse_record in fix for accounting reports merged...
[odoo/odoo.git] / addons / auth_signup / res_config.py
1 # -*- coding: utf-8 -*-
2 ##############################################################################
3 #
4 #    OpenERP, Open Source Management Solution
5 #    Copyright (C) 2012-today OpenERP SA (<http://www.openerp.com>)
6 #
7 #    This program is free software: you can redistribute it and/or modify
8 #    it under the terms of the GNU Affero General Public License as
9 #    published by the Free Software Foundation, either version 3 of the
10 #    License, or (at your option) any later version
11 #
12 #    This program is distributed in the hope that it will be useful,
13 #    but WITHOUT ANY WARRANTY; without even the implied warranty of
14 #    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 #    GNU Affero General Public License for more details
16 #
17 #    You should have received a copy of the GNU Affero General Public License
18 #    along with this program.  If not, see <http://www.gnu.org/licenses/>
19 #
20 ##############################################################################
21
22 from openerp.osv import osv, fields
23 from openerp.tools.safe_eval import safe_eval
24
25 class base_config_settings(osv.TransientModel):
26     _inherit = 'base.config.settings'
27
28     _columns = {
29         'auth_signup_uninvited': fields.boolean('Allow external users to sign up', help="If unchecked, only invited users may sign up"),
30         'auth_signup_template_user_id': fields.many2one('res.users', 'Template user for new users created through signup'),
31     }
32
33     def get_default_auth_signup_template_user_id(self, cr, uid, fields, context=None):
34         icp = self.pool.get('ir.config_parameter')
35         # we use safe_eval on the result, since the value of the parameter is a nonempty string
36         return {
37             'auth_signup_uninvited': safe_eval(icp.get_param(cr, uid, 'auth_signup.allow_uninvited', 'False')),
38             'auth_signup_template_user_id': safe_eval(icp.get_param(cr, uid, 'auth_signup.template_user_id', 'False')),
39         }
40
41     def set_auth_signup_template_user_id(self, cr, uid, ids, context=None):
42         config = self.browse(cr, uid, ids[0], context=context)
43         icp = self.pool.get('ir.config_parameter')
44         # we store the repr of the values, since the value of the parameter is a required string
45         icp.set_param(cr, uid, 'auth_signup.allow_uninvited', repr(config.auth_signup_uninvited))
46         icp.set_param(cr, uid, 'auth_signup.template_user_id', repr(config.auth_signup_template_user_id.id))