1 # -*- coding: utf-8 -*-
2 ##############################################################################
4 # OpenERP, Open Source Management Solution
5 # Copyright (C) 2012-today OpenERP SA (<http://www.openerp.com>)
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
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
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/>
20 ##############################################################################
27 from openerp.modules.registry import RegistryManager
28 from ..res_users import SignupError
30 _logger = logging.getLogger(__name__)
32 class Controller(openerp.addons.web.http.Controller):
33 _cp_path = '/auth_signup'
35 @openerp.addons.web.http.jsonrequest
36 def get_config(self, req, dbname):
37 """ retrieve the module config (which features are enabled) for the login page """
38 registry = RegistryManager.get(dbname)
39 with registry.cursor() as cr:
40 icp = registry.get('ir.config_parameter')
42 'signup': icp.get_param(cr, openerp.SUPERUSER_ID, 'auth_signup.allow_uninvited') == 'True',
43 'reset_password': icp.get_param(cr, openerp.SUPERUSER_ID, 'auth_signup.reset_password') == 'True',
47 @openerp.addons.web.http.jsonrequest
48 def retrieve(self, req, dbname, token):
49 """ retrieve the user info (name, login or email) corresponding to a signup token """
50 registry = RegistryManager.get(dbname)
51 with registry.cursor() as cr:
52 res_partner = registry.get('res.partner')
53 user_info = res_partner.signup_retrieve_info(cr, openerp.SUPERUSER_ID, token)
56 @openerp.addons.web.http.jsonrequest
57 def signup(self, req, dbname, token, name, login, password):
58 """ sign up a user (new or existing)"""
59 values = {'name': name, 'login': login, 'password': password}
61 self._signup_with_values(req, dbname, token, values)
62 except SignupError, e:
63 return {'error': openerp.tools.exception_to_unicode(e)}
66 def _signup_with_values(self, req, dbname, token, values):
67 registry = RegistryManager.get(dbname)
68 with registry.cursor() as cr:
69 res_users = registry.get('res.users')
70 res_users.signup(cr, openerp.SUPERUSER_ID, values, token)
72 @openerp.addons.web.http.httprequest
73 def reset_password(self, req, dbname, login):
74 """ retrieve user, and perform reset password """
75 registry = RegistryManager.get(dbname)
76 with registry.cursor() as cr:
78 res_users = registry.get('res.users')
79 res_users.reset_password(cr, openerp.SUPERUSER_ID, login)
81 message = 'An email has been sent with credentials to reset your password'
82 except Exception as e:
84 _logger.exception('error when resetting password')
86 params = [('action', 'login'), ('error_message', message)]
87 return werkzeug.utils.redirect("/#" + urllib.urlencode(params))
89 # vim:expandtab:tabstop=4:softtabstop=4:shiftwidth=4: