简化API节点的数据库配置(db.yaml)

This commit is contained in:
GoEdgeLab
2024-05-06 17:29:11 +08:00
parent d8e9268dab
commit a573eb5608
8 changed files with 223 additions and 91 deletions

View File

@@ -1,12 +1,14 @@
package database
import (
"github.com/TeaOSLab/EdgeAdmin/internal/configs"
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
"github.com/go-sql-driver/mysql"
"github.com/iwind/TeaGo/Tea"
"github.com/iwind/TeaGo/dbs"
"github.com/iwind/TeaGo/maps"
"gopkg.in/yaml.v3"
"net"
"os"
"strings"
)
@@ -22,7 +24,7 @@ func (this *IndexAction) Init() {
func (this *IndexAction) RunGet(params struct{}) {
this.Data["error"] = ""
configFile := Tea.ConfigFile("api_db.yaml")
var configFile = Tea.ConfigFile("api_db.yaml")
data, err := os.ReadFile(configFile)
if err != nil {
this.Data["error"] = "read config file failed: api_db.yaml: " + err.Error()
@@ -30,8 +32,33 @@ func (this *IndexAction) RunGet(params struct{}) {
return
}
config := &dbs.Config{}
// new config
var config = &configs.SimpleDBConfig{}
err = yaml.Unmarshal(data, config)
if err == nil && len(config.Host) > 0 {
host, port, splitErr := net.SplitHostPort(config.Host)
if splitErr != nil {
port = "3306"
}
this.Data["dbConfig"] = maps.Map{
"host": host,
"port": port,
"username": config.User,
"password": config.Password,
"database": config.Database,
}
this.Show()
return
}
this.parseOldConfig(data)
}
func (this *IndexAction) parseOldConfig(data []byte) {
var config = &dbs.Config{}
err := yaml.Unmarshal(data, config)
if err != nil {
this.Data["error"] = "parse config file failed: api_db.yaml: " + err.Error()
this.Show()
@@ -49,7 +76,12 @@ func (this *IndexAction) RunGet(params struct{}) {
dbConfig = db
break
}
dsn := dbConfig.Dsn
if dbConfig == nil {
this.Data["error"] = "no database configured in config file: api_db.yaml"
this.Show()
return
}
var dsn = dbConfig.Dsn
cfg, err := mysql.ParseDSN(dsn)
if err != nil {
this.Data["error"] = "parse dsn error: " + err.Error()
@@ -57,18 +89,19 @@ func (this *IndexAction) RunGet(params struct{}) {
return
}
host := cfg.Addr
port := "3306"
index := strings.LastIndex(host, ":")
var host = cfg.Addr
var port = "3306"
var index = strings.LastIndex(host, ":")
if index > 0 {
port = host[index+1:]
host = host[:index]
}
password := cfg.Passwd
var password = cfg.Passwd
if len(password) > 0 {
password = strings.Repeat("*", len(password))
}
this.Data["dbConfig"] = maps.Map{
"host": host,
"port": port,

View File

@@ -2,6 +2,7 @@ package database
import (
"fmt"
"github.com/TeaOSLab/EdgeAdmin/internal/configs"
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
"github.com/TeaOSLab/EdgeCommon/pkg/configutils"
"github.com/TeaOSLab/EdgeCommon/pkg/langs/codes"
@@ -40,55 +41,28 @@ func (this *UpdateAction) RunGet(params struct{}) {
return
}
config := &dbs.Config{}
// new config
var config = &configs.SimpleDBConfig{}
err = yaml.Unmarshal(data, config)
if err != nil {
this.Show()
return
}
if config.DBs == nil {
this.Show()
return
}
var dbConfig *dbs.DBConfig
for _, db := range config.DBs {
dbConfig = db
break
}
dsn := dbConfig.Dsn
cfg, err := mysql.ParseDSN(dsn)
if err != nil {
this.Data["dbConfig"] = maps.Map{
"host": "",
"port": "",
"username": "",
"password": "",
"database": "",
if err == nil && len(config.Host) > 0 {
host, port, splitErr := net.SplitHostPort(config.Host)
if splitErr != nil {
port = "3306"
}
this.Data["dbConfig"] = maps.Map{
"host": host,
"port": port,
"username": config.User,
"password": config.Password,
"database": config.Database,
}
this.Show()
return
}
host := cfg.Addr
port := "3306"
index := strings.LastIndex(cfg.Addr, ":")
if index > 0 {
host = cfg.Addr[:index]
port = cfg.Addr[index+1:]
}
this.Data["dbConfig"] = maps.Map{
"host": host,
"port": port,
"username": cfg.User,
"password": cfg.Passwd,
"database": cfg.DBName,
}
this.Show()
this.parseOldConfig(data)
}
func (this *UpdateAction) RunPost(params struct {
@@ -129,28 +103,91 @@ func (this *UpdateAction) RunPost(params struct {
Require("请输入连接数据库的用户名").
Match(`^[\w\.-]+$`, "用户名中不能包含特殊字符")
// 保存
dsn := params.Username + ":" + params.Password + "@tcp(" + configutils.QuoteIP(params.Host) + ":" + fmt.Sprintf("%d", params.Port) + ")/" + params.Database
configFile := Tea.ConfigFile("api_db.yaml")
template := `default:
db: "prod"
prefix: ""
dbs:
prod:
driver: "mysql"
dsn: "` + dsn + `?charset=utf8mb4&timeout=30s"
prefix: "edge"
models:
package: internal/web/models
`
err := os.WriteFile(configFile, []byte(template), 0666)
var config = &configs.SimpleDBConfig{
User: params.Username,
Password: params.Password,
Database: params.Database,
Host: configutils.QuoteIP(params.Host) + ":" + fmt.Sprintf("%d", params.Port),
}
configYAML, err := yaml.Marshal(config)
if err != nil {
this.Fail("保存配置失败:" + err.Error())
this.ErrorPage(err)
return
}
// TODO 让本地的节点生效
// 保存
var configFile = Tea.ConfigFile("api_db.yaml")
err = os.WriteFile(configFile, configYAML, 0666)
if err != nil {
this.Fail("保存配置失败:" + err.Error())
return
}
// TODO 思考是否让本地的API节点生效
this.Success()
}
func (this *UpdateAction) parseOldConfig(data []byte) {
var config = &dbs.Config{}
err := yaml.Unmarshal(data, config)
if err != nil {
this.Show()
return
}
if config.DBs == nil {
this.Show()
return
}
var dbConfig *dbs.DBConfig
for _, db := range config.DBs {
dbConfig = db
break
}
if dbConfig == nil {
this.Data["dbConfig"] = maps.Map{
"host": "",
"port": "",
"username": "",
"password": "",
"database": "",
}
this.Show()
return
}
var dsn = dbConfig.Dsn
cfg, err := mysql.ParseDSN(dsn)
if err != nil {
this.Data["dbConfig"] = maps.Map{
"host": "",
"port": "",
"username": "",
"password": "",
"database": "",
}
this.Show()
return
}
var host = cfg.Addr
var port = "3306"
var index = strings.LastIndex(cfg.Addr, ":")
if index > 0 {
host = cfg.Addr[:index]
port = cfg.Addr[index+1:]
}
this.Data["dbConfig"] = maps.Map{
"host": host,
"port": port,
"username": cfg.User,
"password": cfg.Passwd,
"database": cfg.DBName,
}
this.Show()
}