2023-10-27 17:41:45 +08:00
|
|
|
|
package entity
|
|
|
|
|
|
|
|
|
|
|
|
import (
|
2024-01-05 08:55:34 +08:00
|
|
|
|
"errors"
|
2023-10-27 17:41:45 +08:00
|
|
|
|
"fmt"
|
|
|
|
|
|
"mayfly-go/internal/common/utils"
|
|
|
|
|
|
"mayfly-go/pkg/model"
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
type DbInstance struct {
|
|
|
|
|
|
model.Model
|
|
|
|
|
|
|
2024-02-29 22:12:50 +08:00
|
|
|
|
Name string `json:"name"`
|
|
|
|
|
|
Type string `json:"type"` // 类型,mysql oracle等
|
|
|
|
|
|
Host string `json:"host"`
|
|
|
|
|
|
Port int `json:"port"`
|
|
|
|
|
|
Network string `json:"network"`
|
2024-03-07 17:26:11 +08:00
|
|
|
|
Extra *string `json:"extra"` // 连接需要的其他额外参数(json格式), 如oracle需要sid等
|
2024-02-29 22:12:50 +08:00
|
|
|
|
Username string `json:"username"`
|
|
|
|
|
|
Password string `json:"-"`
|
|
|
|
|
|
Params *string `json:"params"`
|
|
|
|
|
|
Remark string `json:"remark"`
|
|
|
|
|
|
SshTunnelMachineId int `json:"sshTunnelMachineId"` // ssh隧道机器id
|
2023-10-27 17:41:45 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func (d *DbInstance) TableName() string {
|
|
|
|
|
|
return "t_db_instance"
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 获取数据库连接网络, 若没有使用ssh隧道,则直接返回。否则返回拼接的网络需要注册至指定dial
|
|
|
|
|
|
func (d *DbInstance) GetNetwork() string {
|
|
|
|
|
|
network := d.Network
|
|
|
|
|
|
if d.SshTunnelMachineId <= 0 {
|
|
|
|
|
|
if network == "" {
|
|
|
|
|
|
return "tcp"
|
|
|
|
|
|
} else {
|
|
|
|
|
|
return network
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
return fmt.Sprintf("%s+ssh:%d", d.Type, d.SshTunnelMachineId)
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2024-01-05 08:55:34 +08:00
|
|
|
|
func (d *DbInstance) PwdEncrypt() error {
|
2023-10-27 17:41:45 +08:00
|
|
|
|
// 密码替换为加密后的密码
|
2024-01-05 08:55:34 +08:00
|
|
|
|
password, err := utils.PwdAesEncrypt(d.Password)
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
return errors.New("加密数据库密码失败")
|
|
|
|
|
|
}
|
|
|
|
|
|
d.Password = password
|
|
|
|
|
|
return nil
|
2023-10-27 17:41:45 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2024-01-05 08:55:34 +08:00
|
|
|
|
func (d *DbInstance) PwdDecrypt() error {
|
2023-10-27 17:41:45 +08:00
|
|
|
|
// 密码替换为解密后的密码
|
2024-01-05 08:55:34 +08:00
|
|
|
|
password, err := utils.PwdAesDecrypt(d.Password)
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
return errors.New("解密数据库密码失败")
|
|
|
|
|
|
}
|
|
|
|
|
|
d.Password = password
|
|
|
|
|
|
return nil
|
2023-10-27 17:41:45 +08:00
|
|
|
|
}
|