You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
104 lines
4.3 KiB
104 lines
4.3 KiB
# -*- coding: utf-8 -*-
|
|
#############################################################################
|
|
#
|
|
# Cybrosys Technologies Pvt. Ltd.
|
|
#
|
|
# Copyright (C) 2023-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
|
|
# Author: Cybrosys Techno Solutions (<https://www.cybrosys.com>)
|
|
#
|
|
# You can modify it under the terms of the GNU LESSER
|
|
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
|
|
#
|
|
# 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
|
|
# GNU LESSER GENERAL PUBLIC LICENSE (AGPL v3) for more details.
|
|
#
|
|
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
|
|
# (AGPL v3) along with this program
|
|
# If not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
#############################################################################
|
|
|
|
import odoo
|
|
from odoo import http, _
|
|
from odoo.exceptions import UserError
|
|
from odoo.http import request, dispatch_rpc
|
|
|
|
from odoo.addons.auth_signup.controllers.main import AuthSignupHome
|
|
|
|
|
|
class AuthSignupHomeInherit(AuthSignupHome):
|
|
@http.route('/web/forgot_password', type='http', auth='public',
|
|
website=True, sitemap=False, csrf=False)
|
|
def forgot_password(self):
|
|
"""
|
|
Handle the "Forgot Password" functionality.
|
|
|
|
:return: A response containing the "forgot_password" template with the
|
|
context data.
|
|
"""
|
|
qcontext = self.get_auth_signup_qcontext()
|
|
response = request.render('password_reset_manager.forgot_password',
|
|
qcontext)
|
|
return response
|
|
|
|
@http.route('/web/reset_password/direct', type='http', auth='public',
|
|
website=True, sitemap=False, csrf=False, )
|
|
def web_auth_reset_password_direct(self):
|
|
"""
|
|
Handle the direct reset password functionality for web authentication.
|
|
|
|
:return: A response containing the "reset_password_direct" template
|
|
with the context data.
|
|
"""
|
|
qcontext = self.get_auth_signup_qcontext()
|
|
response = request.render(
|
|
'password_reset_manager.reset_password_direct', qcontext)
|
|
return response
|
|
|
|
@http.route('/web/reset_password/submit', type='http',
|
|
methods=['POST'], auth="public", website=True, csrf=False)
|
|
def change_password(self, **kw):
|
|
"""
|
|
Handle the password change functionality for a user.
|
|
|
|
:param kw: Keyword arguments received from the request.
|
|
|
|
:return: A redirect to the login page with a success message or an
|
|
error message.
|
|
"""
|
|
values = {}
|
|
|
|
# Check if the new password and confirm new password match.
|
|
if kw['confirm_new_password'] == kw['new_password']:
|
|
try:
|
|
# Authenticate the user session with the provided old password
|
|
uid = request.session.authenticate(request.session.db,
|
|
kw['user_name'],
|
|
kw['old_password'])
|
|
user = request.env['res.users'].search([('id', '=', uid)])
|
|
is_user_public = request.env.user.has_group(
|
|
'base.group_public')
|
|
if not is_user_public:
|
|
# Update the user's password with the new password.
|
|
user.sudo().write({
|
|
'password': kw['confirm_new_password']
|
|
})
|
|
|
|
# Redirect to the login page with a success message.
|
|
return request.redirect('/web/login?message=%s'
|
|
% _('Password Changed'))
|
|
else:
|
|
values['error'] = _(
|
|
"Public users can't change their password")
|
|
return request.render(
|
|
'password_reset_manager.reset_password_direct', values)
|
|
except odoo.exceptions.AccessDenied as e:
|
|
values['error'] = _("Login or Password Is Incorrect")
|
|
return request.render(
|
|
'password_reset_manager.reset_password_direct', values)
|
|
else:
|
|
values['error'] = _("Password Not Match")
|
|
return request.render(
|
|
'password_reset_manager.reset_password_direct', values)
|
|
|