-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathmain.go
More file actions
70 lines (57 loc) · 1.59 KB
/
main.go
File metadata and controls
70 lines (57 loc) · 1.59 KB
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
package main
import (
"context"
"flag"
"fmt"
"strings"
"github.com/actiontech/sqle/sqle/driver"
adaptor "github.com/actiontech/sqle/sqle/pkg/driver"
"github.com/actiontech/sqle/sqle/pkg/params"
_ "github.com/ibmdb/go_ibm_db"
)
var database_name string
type DB2Dialector struct{}
func (d *DB2Dialector) Dialect(dsn *driver.DSN) (string, string) {
p := dsn.AdditionalParams
database_name = p.GetParam("database_name").String()
con := fmt.Sprintf("HOSTNAME=%v;DATABASE=%v;PORT=%v;UID=%v;PWD=%v", dsn.Host, database_name, dsn.Port, dsn.User, dsn.Password)
return "go_ibm_db", con
}
func (d *DB2Dialector) String() string {
return "DB2"
}
func (d *DB2Dialector) ShowDatabaseSQL() string {
return fmt.Sprintf("select '%v' as name from SYSIBM.SYSDUMMY1", database_name)
}
var version string
var printVersion = flag.Bool("version", false, "Print version & exit")
func main() {
flag.Parse()
if *printVersion {
fmt.Println(version)
return
}
plugin := adaptor.NewAdaptor(&DB2Dialector{})
ruleDQL1 := &driver.Rule{
Name: "db2_dql_1",
Desc: "禁止不带where条件的查询",
Category: "SQL规范",
Level: driver.RuleLevelError,
}
ruleDQL1Handler := func(ctx context.Context, rule *driver.Rule, sql string) (string, error) {
lowerSql := strings.ToLower(sql)
if strings.Contains(lowerSql, "select") &&
!strings.Contains(lowerSql, "where") {
return rule.Desc, nil
}
return "", nil
}
plugin.AddRule(ruleDQL1, ruleDQL1Handler)
plugin.AddAdditionalParams(¶ms.Param{
Key: "database_name",
Value: "",
Desc: "数据库名",
Type: "string",
})
plugin.Serve()
}