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.
		
		
		
		
		
			
		
			
				
					
					
						
							151 lines
						
					
					
						
							6.7 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							151 lines
						
					
					
						
							6.7 KiB
						
					
					
				| # -*- coding: utf-8 -*- | |
| ############################################################################## | |
| # | |
| #    Cybrosys Technologies Pvt. Ltd. | |
| # | |
| #    Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |
| #    Author: Dhanya Babu (odoo@cybrosys.com) | |
| # | |
| #    You can modify it under the terms of the GNU LESSER | |
| #    GENERAL PUBLIC LICENSE (LGPL 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 (LGPL v3) for more details. | |
| # | |
| #    You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE | |
| #    (LGPL v3) along with this program. | |
| #    If not, see <http://www.gnu.org/licenses/>. | |
| # | |
| ############################################################################## | |
| import base64 | |
| import json | |
| from psycopg2 import IntegrityError | |
| from odoo import http, _ | |
| from odoo.http import request | |
| from odoo.exceptions import ValidationError | |
| from odoo.addons.website.controllers.form import WebsiteForm | |
| 
 | |
| 
 | |
| class HelpdeskProduct(http.Controller): | |
|     """    Controller for handling helpdesk products. | |
|     """ | |
| 
 | |
|     @http.route('/product', auth='public', type='json') | |
|     def product(self): | |
|         prols = [] | |
|         acc = request.env['product.template'].sudo().search([]) | |
|         for i in acc: | |
|             dic = {'name': i['name'], | |
|                    'id': i['id']} | |
|             prols.append(dic) | |
|         return prols | |
| 
 | |
| 
 | |
| class WebsiteFormInherit(WebsiteForm): | |
| 
 | |
|     def _handle_website_form(self, model_name, **kwargs): | |
|         """ | |
|         Handle the submission of website forms. | |
|         :param model_name: The name of the model associated with the form. | |
|         :type model_name: str | |
|         :param kwargs: Keyword arguments containing form data. | |
|         :type kwargs: dict | |
|         :return: JSON response indicating the success or failure of form submission. | |
|         :rtype: str | |
|         """ | |
|         customer = request.env.user.partner_id | |
|         lowest_stage_id = None | |
|         if model_name == 'ticket.helpdesk': | |
|             tickets = request.env['ticket.stage'].sudo().search([]) | |
|             if tickets: | |
|                 sequence = tickets.mapped('sequence') | |
|                 lowest_sequence = tickets.filtered( | |
|                     lambda x: x.sequence == min(sequence)) | |
|                 if lowest_sequence: | |
|                     lowest_stage_id = lowest_sequence[0] | |
|             if lowest_stage_id is None: | |
|                 return json.dumps( | |
|                     {'error': "No stage found with the lowest sequence."}) | |
|             products = kwargs.get('product') | |
|             if products: | |
|                 split_product = products.split(',') | |
|                 product_list = [int(i) for i in split_product] | |
|                 rec_val = { | |
|                     'customer_name': kwargs.get('customer_name'), | |
|                     'subject': kwargs.get('subject'), | |
|                     'description': kwargs.get('description'), | |
|                     'email': kwargs.get('email_from'), | |
|                     'phone': kwargs.get('phone'), | |
|                     'priority': kwargs.get('priority'), | |
|                     'product_ids': product_list, | |
|                     'stage_id': lowest_stage_id.id, | |
|                     'customer_id': customer.id, | |
|                     'ticket_type_id': kwargs.get('ticket_type_id'), | |
|                     'category_id': kwargs.get('category'), | |
|                 } | |
|             else: | |
|                 rec_val = { | |
|                     'customer_name': kwargs.get('customer_name'), | |
|                     'subject': kwargs.get('subject'), | |
|                     'description': kwargs.get('description'), | |
|                     'email': kwargs.get('email_from'), | |
|                     'phone': kwargs.get('phone'), | |
|                     'priority': kwargs.get('priority'), | |
|                     'stage_id': lowest_stage_id.id, | |
|                     'customer_id': customer.id, | |
|                     'ticket_type_id': kwargs.get('ticket_type_id'), | |
|                     'category_id': kwargs.get('category'), | |
|                 } | |
|             ticket_id = request.env['ticket.helpdesk'].sudo().create(rec_val) | |
|             request.session['ticket_number'] = ticket_id.name | |
|             request.session['ticket_id'] = ticket_id.id | |
|             model_record = request.env['ir.model'].sudo().search( | |
|                 [('model', '=', model_name)]) | |
|             attachments = [] | |
|             attachment_index = 0 | |
|             while f"ticket_attachment[0][{attachment_index}]" in kwargs: | |
|                 attachment_key = f"ticket_attachment[0][{attachment_index}]" | |
|                 if attachment_key in kwargs: | |
|                     attachment = kwargs[attachment_key] | |
|                     attachments.append(attachment) | |
|                 attachment_index += 1 | |
|             for attachment in attachments: | |
|                 attached_file = attachment.read() | |
|                 request.env['ir.attachment'].sudo().create({ | |
|                     'name': attachment.filename, | |
|                     'res_model': 'ticket.helpdesk', | |
|                     'res_id': ticket_id.id, | |
|                     'type': 'binary', | |
|                     'datas': base64.encodebytes(attached_file), | |
|                 }) | |
|             request.session['form_builder_model_model'] = model_record.model | |
|             request.session['form_builder_model'] = model_record.name | |
|             request.session['form_builder_id'] = ticket_id.id | |
|             return json.dumps({'id': ticket_id.id}) | |
|         else: | |
|             model_record = request.env['ir.model'].sudo().search( | |
|                 [('model', '=', model_name)]) | |
|             if not model_record: | |
|                 return json.dumps( | |
|                     {'error': _("The form's specified model does not exist")}) | |
|             try: | |
|                 data = self.extract_data(model_record, request.params) | |
|             except ValidationError as e: | |
|                 return json.dumps({'error_fields': e.args[0]}) | |
|             try: | |
|                 id_record = self.insert_record(request, model_record, | |
|                                                data['record'], data['custom'], | |
|                                                data.get('meta')) | |
|                 if id_record: | |
|                     self.insert_attachment(model_record, id_record, | |
|                                            data['attachments']) | |
|                     if model_name == 'mail.mail': | |
|                         request.env[model_name].sudo().browse(id_record).send() | |
|             except IntegrityError: | |
|                 return json.dumps(False) | |
|             request.session['form_builder_model_model'] = model_record.model | |
|             request.session['form_builder_model'] = model_record.name | |
|             request.session['form_builder_id'] = id_record | |
|             return json.dumps({'id': id_record})
 | |
| 
 |