mirror of
https://github.com/TeaOSLab/EdgeAPI.git
synced 2025-11-02 22:10:26 +08:00
修改SQL对比算法
This commit is contained in:
77
cmd/sql-dump/main.go
Normal file
77
cmd/sql-dump/main.go
Normal file
@@ -0,0 +1,77 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"github.com/TeaOSLab/EdgeAPI/internal/setup"
|
||||
_ "github.com/iwind/TeaGo/bootstrap"
|
||||
"github.com/iwind/TeaGo/dbs"
|
||||
"github.com/iwind/TeaGo/logs"
|
||||
"go/format"
|
||||
"io/ioutil"
|
||||
"os"
|
||||
"path/filepath"
|
||||
"strconv"
|
||||
)
|
||||
|
||||
func main() {
|
||||
db, err := dbs.Default()
|
||||
if err != nil {
|
||||
logs.Println("[ERROR]" + err.Error())
|
||||
return
|
||||
}
|
||||
results, err := setup.NewSQLDump().Dump(db)
|
||||
if err != nil {
|
||||
logs.Println("[ERROR]" + err.Error())
|
||||
return
|
||||
}
|
||||
resultsJSON, err := json.Marshal(results)
|
||||
if err != nil {
|
||||
logs.Println("[ERROR]" + err.Error())
|
||||
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 {
|
||||
logs.Println("[ERROR]can not find sql.go")
|
||||
return
|
||||
}
|
||||
content := []byte(`package setup
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"github.com/iwind/TeaGo/logs"
|
||||
)
|
||||
|
||||
// 最新的SQL语句
|
||||
// 由sql-dump/main.go自动生成
|
||||
|
||||
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 {
|
||||
logs.Println("[ERROR]format code failed: " + err.Error())
|
||||
return
|
||||
}
|
||||
|
||||
err = ioutil.WriteFile(sqlFile, dst, 0666)
|
||||
if err != nil {
|
||||
logs.Println("[ERROR]write file failed: " + err.Error())
|
||||
return
|
||||
}
|
||||
logs.Println("ok")
|
||||
}
|
||||
@@ -1,103 +0,0 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"flag"
|
||||
"fmt"
|
||||
"github.com/iwind/TeaGo/Tea"
|
||||
_ "github.com/iwind/TeaGo/bootstrap"
|
||||
"github.com/iwind/TeaGo/logs"
|
||||
"go/format"
|
||||
"io/ioutil"
|
||||
"os"
|
||||
"path/filepath"
|
||||
"strings"
|
||||
)
|
||||
|
||||
func main() {
|
||||
var dir string
|
||||
flag.StringVar(&dir, "dir", "", "SQL dir")
|
||||
flag.Parse()
|
||||
|
||||
if len(dir) == 0 {
|
||||
fmt.Println("[ERROR]'dir' should not be empty")
|
||||
return
|
||||
}
|
||||
|
||||
sourceDir := filepath.Dir(Tea.Root)
|
||||
|
||||
// full
|
||||
fullSQLFile := dir + "/full.sql"
|
||||
_, err := os.Stat(fullSQLFile)
|
||||
if err != nil {
|
||||
if os.IsNotExist(err) {
|
||||
fmt.Println("[ERROR]'full.sql' not found")
|
||||
return
|
||||
}
|
||||
fmt.Println("[ERROR]checking 'full.sql' failed: " + err.Error())
|
||||
return
|
||||
}
|
||||
|
||||
matches, err := filepath.Glob(dir + "/*.sql")
|
||||
if err != nil {
|
||||
fmt.Println("[ERROR]" + err.Error())
|
||||
return
|
||||
}
|
||||
|
||||
versionsCode := "// generated\npackage sqls\n\nvar SQLVersions = []map[string]string{"
|
||||
|
||||
for _, match := range matches {
|
||||
baseName := filepath.Base(match)
|
||||
logs.Println("reading " + baseName + " ...")
|
||||
|
||||
data, err := ioutil.ReadFile(match)
|
||||
if err != nil {
|
||||
fmt.Println("[ERROR]" + err.Error())
|
||||
return
|
||||
}
|
||||
|
||||
version := baseName[:strings.LastIndex(baseName, ".")]
|
||||
versionsCode += "\n" + `{ "version": "` + version + `", "sql": SQL_` + version + ` },`
|
||||
|
||||
code := "// generated\npackage sqls \n\n"
|
||||
lines := bytes.Split(data, []byte{'\n'})
|
||||
for index, line := range lines {
|
||||
if index == 0 {
|
||||
code += "var SQL_" + version + " = "
|
||||
}
|
||||
code += `"` + string(line) + `\n"`
|
||||
if index != len(lines)-1 {
|
||||
code += "+"
|
||||
}
|
||||
code += "\n"
|
||||
}
|
||||
code += "\n"
|
||||
|
||||
codeBytes, err := format.Source([]byte(code))
|
||||
if err != nil {
|
||||
fmt.Println("[ERROR]" + err.Error())
|
||||
return
|
||||
}
|
||||
fmt.Println("writing sql_" + version + ".go ...")
|
||||
err = ioutil.WriteFile(sourceDir+"/internal/setup/sqls/sql_"+version+".go", codeBytes, 0666)
|
||||
if err != nil {
|
||||
fmt.Println("[ERROR]" + err.Error())
|
||||
return
|
||||
}
|
||||
fmt.Println("ok")
|
||||
}
|
||||
|
||||
versionsCode += "\n}"
|
||||
versionsCodeBytes, err := format.Source([]byte(versionsCode))
|
||||
if err != nil {
|
||||
fmt.Println("[ERROR]" + err.Error())
|
||||
return
|
||||
}
|
||||
fmt.Println("writing sqls.go ...")
|
||||
err = ioutil.WriteFile(sourceDir+"/internal/setup/sqls/sqls.go", versionsCodeBytes, 0666)
|
||||
if err != nil {
|
||||
fmt.Println("[ERROR]" + err.Error())
|
||||
return
|
||||
}
|
||||
fmt.Println("ok")
|
||||
}
|
||||
Reference in New Issue
Block a user