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.
		
		
		
		
		
			
		
			
				
					
					
						
							69 lines
						
					
					
						
							3.0 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							69 lines
						
					
					
						
							3.0 KiB
						
					
					
				| # -*- coding: utf-8 -*- | |
| ############################################################################### | |
| # | |
| #    Cybrosys Technologies Pvt. Ltd. | |
| # | |
| #    Copyright (C) 2025-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |
| #    Author: Akhil (odoo@cybrosys.com) | |
| # | |
| #    You can modify it under the terms of the GNU AFFERO | |
| #    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 AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details. | |
| # | |
| #    You should have received a copy of the GNU AFFERO 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.http import request | |
| from odoo.addons.web.controllers.database import Database | |
| 
 | |
| 
 | |
| class DatabaseInherit(Database): | |
|     @http.route('/web/reset_by_master_pass/submit', type='http', | |
|                 methods=['POST'], auth="public", website=True, csrf=False) | |
|     def change_password_by_master(self, **kw): | |
|         """ | |
|         Endpoint to change a user's password by a master password. | |
|  | |
|         :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']: | |
|             # Verify the master password using Odoo's config. | |
|             if odoo.tools.config.verify_admin_password(kw['master_password']): | |
|                 # Search for a user with the provided user_name. | |
|                 user_valid = request.env['res.users'].sudo().search([ | |
|                     ('login', '=', kw['user_name'])]) | |
|                 if user_valid: | |
|                     # Update the user's password with the new password. | |
|                     user_valid.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'] = _("User Name Is Not Valid") | |
|                     return request.render( | |
|                         'password_reset_manager.forgot_password', values) | |
|             else: | |
|                 values['error'] = _("Master Password Is Incorrect") | |
|                 return request.render('password_reset_manager.forgot_password', | |
|                                       values) | |
| 
 | |
|         else: | |
|             values['error'] = _("Password Not Matched") | |
|             return request.render('password_reset_manager.forgot_password', | |
|                                   values)
 | |
| 
 |