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.
 
 
 
 
 

60 lines
2.4 KiB

# -*- coding: utf-8 -*-
################################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2025-TODAY Cybrosys Technologies(<https://www.cybrosys.com>).
# Author: Unnimaya C O (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 mysql.connector
from odoo import fields, models
from odoo.exceptions import ValidationError
class MysqlCredential(models.Model):
"""Model holding Mysql credentials"""
_name = 'mysql.credential'
_description = 'Mysql Credential'
name = fields.Char(string='Database', help='Name of the database',
required=True)
user = fields.Char(string='Username', help='Username of connection',
required=True)
host = fields.Char(string='Host', help='Host name of MySQL connection',
required=True)
password = fields.Char(string='Password',
help='Password of My SQL connection', required=True)
state = fields.Selection([('draft', 'Draft'),
('connect', 'Connected')],
string='State', help='State of the record',
readonly=True, default='draft')
def action_connect(self):
"""Method for connecting with Mysql"""
try:
connection = mysql.connector.connect(
host=self.host,
user=self.user,
password=self.password,
database=self.name
)
if connection.is_connected():
self.sudo().write({
'state': 'connect'
})
except mysql.connector.Error as e:
# Handle any connection errors
raise ValidationError(f"Error connecting to MySQL: {e}")