2020-11-16 23:30:47 +08:00
|
|
|
|
package main
|
|
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
|
"encoding/json"
|
2020-11-16 23:33:46 +08:00
|
|
|
|
"fmt"
|
2020-11-16 23:30:47 +08:00
|
|
|
|
"github.com/TeaOSLab/EdgeAPI/internal/setup"
|
|
|
|
|
|
_ "github.com/iwind/TeaGo/bootstrap"
|
|
|
|
|
|
"github.com/iwind/TeaGo/dbs"
|
|
|
|
|
|
"go/format"
|
|
|
|
|
|
"os"
|
|
|
|
|
|
"path/filepath"
|
|
|
|
|
|
"strconv"
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
|
|
db, err := dbs.Default()
|
|
|
|
|
|
if err != nil {
|
2020-11-16 23:33:46 +08:00
|
|
|
|
fmt.Println("[ERROR]" + err.Error())
|
2020-11-16 23:30:47 +08:00
|
|
|
|
return
|
|
|
|
|
|
}
|
|
|
|
|
|
results, err := setup.NewSQLDump().Dump(db)
|
|
|
|
|
|
if err != nil {
|
2020-11-16 23:33:46 +08:00
|
|
|
|
fmt.Println("[ERROR]" + err.Error())
|
2020-11-16 23:30:47 +08:00
|
|
|
|
return
|
|
|
|
|
|
}
|
|
|
|
|
|
resultsJSON, err := json.Marshal(results)
|
|
|
|
|
|
if err != nil {
|
2020-11-16 23:33:46 +08:00
|
|
|
|
fmt.Println("[ERROR]" + err.Error())
|
2020-11-16 23:30:47 +08:00
|
|
|
|
return
|
|
|
|
|
|
}
|
|
|
|
|
|
dir, _ := os.Getwd()
|
|
|
|
|
|
var sqlFile string
|
|
|
|
|
|
for i := 0; i < 5; i++ {
|
|
|
|
|
|
lookupFile := dir + "/internal/setup/sql.go"
|
|
|
|
|
|
_, err = os.Stat(lookupFile)
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
dir = filepath.Dir(dir)
|
|
|
|
|
|
continue
|
|
|
|
|
|
}
|
|
|
|
|
|
sqlFile = lookupFile
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if len(sqlFile) == 0 {
|
2020-11-16 23:33:46 +08:00
|
|
|
|
fmt.Println("[ERROR]can not find sql.go")
|
2020-11-16 23:30:47 +08:00
|
|
|
|
return
|
|
|
|
|
|
}
|
|
|
|
|
|
content := []byte(`package setup
|
|
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
|
"encoding/json"
|
|
|
|
|
|
"github.com/iwind/TeaGo/logs"
|
|
|
|
|
|
)
|
|
|
|
|
|
|
2021-04-18 16:32:08 +08:00
|
|
|
|
// 最新版本的数据库SQL语句,用来对比并升级已有的数据库
|
|
|
|
|
|
// 由 sql-dump/main.go 自动生成
|
2020-11-16 23:30:47 +08:00
|
|
|
|
func init() {
|
|
|
|
|
|
err := json.Unmarshal([]byte(` + strconv.Quote(string(resultsJSON)) + `), LatestSQLResult)
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
logs.Println("[ERROR]load sql failed: " + err.Error())
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
`)
|
|
|
|
|
|
dst, err := format.Source(content)
|
|
|
|
|
|
if err != nil {
|
2020-11-16 23:33:46 +08:00
|
|
|
|
fmt.Println("[ERROR]format code failed: " + err.Error())
|
2020-11-16 23:30:47 +08:00
|
|
|
|
return
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-09-03 22:03:22 +08:00
|
|
|
|
err = os.WriteFile(sqlFile, dst, 0666)
|
2020-11-16 23:30:47 +08:00
|
|
|
|
if err != nil {
|
2020-11-16 23:33:46 +08:00
|
|
|
|
fmt.Println("[ERROR]write file failed: " + err.Error())
|
2020-11-16 23:30:47 +08:00
|
|
|
|
return
|
|
|
|
|
|
}
|
2020-11-16 23:33:46 +08:00
|
|
|
|
fmt.Println("ok")
|
2020-11-16 23:30:47 +08:00
|
|
|
|
}
|