/
exec.go
102 lines (94 loc) · 2.68 KB
/
exec.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
package ddl
import (
"context"
"fmt"
"github.com/pkg/errors"
"github.com/sirupsen/logrus"
"github.com/unionj-cloud/go-doudou/toolkit/caller"
"os"
"path/filepath"
"strings"
"time"
// here must import mysql
_ "github.com/go-sql-driver/mysql"
"github.com/iancoleman/strcase"
"github.com/jmoiron/sqlx"
"github.com/unionj-cloud/go-doudou/cmd/internal/ddl/codegen"
"github.com/unionj-cloud/go-doudou/cmd/internal/ddl/config"
"github.com/unionj-cloud/go-doudou/cmd/internal/ddl/table"
)
// Ddl is for ddl command
type Ddl struct {
Dir string
Reverse bool
Dao bool
Pre string
Df string
Conf config.DbConfig
}
// Exec executes the logic for ddl command
// if Reverse is true, it will generate code from database tables,
// otherwise it will update database tables from structs defined in domain pkg
func (d Ddl) Exec() {
var db *sqlx.DB
var err error
conf := d.Conf
conn := fmt.Sprintf("%s:%s@tcp(%s:%s)/%s?charset=%s",
conf.User,
conf.Passwd,
conf.Host,
conf.Port,
conf.Schema,
conf.Charset)
conn += `&loc=Asia%2FShanghai&parseTime=True`
db, err = sqlx.Connect("mysql", conn)
if err != nil {
panic(errors.Wrap(err, caller.NewCaller().String()))
}
defer db.Close()
db.MapperFunc(strcase.ToSnake)
db = db.Unsafe()
var existTables []string
if err = db.Select(&existTables, "show tables"); err != nil {
panic(errors.Wrap(err, caller.NewCaller().String()))
}
var tables []table.Table
timeoutCtx, cancel := context.WithTimeout(context.Background(), 30*time.Second)
defer cancel()
_ = os.MkdirAll(d.Dir, os.ModePerm)
if !d.Reverse {
tables = table.Struct2Table(timeoutCtx, d.Dir, d.Pre, existTables, db, d.Conf.Schema)
} else {
tables = table.Table2struct(timeoutCtx, d.Pre, d.Conf.Schema, existTables, db)
for _, item := range tables {
dfile := filepath.Join(d.Dir, strings.ToLower(item.Meta.Name)+".go")
if _, err = os.Stat(dfile); os.IsNotExist(err) {
if err = codegen.GenDomainGo(d.Dir, item.Meta); err != nil {
panic(errors.Wrap(err, caller.NewCaller().String()))
}
} else {
logrus.Warnf("file %s already exists", dfile)
}
}
}
if d.Dao {
genDao(d, tables)
}
}
func genDao(d Ddl, tables []table.Table) {
var err error
if err = codegen.GenBaseGo(d.Dir, d.Df); err != nil {
panic(errors.Wrap(err, caller.NewCaller().String()))
}
for _, t := range tables {
if err = codegen.GenDaoGo(d.Dir, t, d.Df); err != nil {
panic(errors.Wrap(err, caller.NewCaller().String()))
}
if err = codegen.GenDaoImplGo(d.Dir, t, d.Df); err != nil {
panic(errors.Wrap(err, caller.NewCaller().String()))
}
if err = codegen.GenDaoSQL(d.Dir, t, d.Df); err != nil {
panic(errors.Wrap(err, caller.NewCaller().String()))
}
}
}