Compare commits
26 Commits
feature/ap
...
master
Author | SHA1 | Date | |
---|---|---|---|
94d3aec886 | |||
e37e4b3c6d | |||
428944cbe3 | |||
21b0a9e212 | |||
34701459c6 | |||
aca5c2e5b3 | |||
37406967b5 | |||
6a8592af37 | |||
0e48ae0041 | |||
69a4a3925e | |||
e7f4e3fca2 | |||
e2ac04a45d | |||
8c75d91915 | |||
7d3c63175d | |||
1b049b5bdc | |||
632c9ee5d1 | |||
a0dd3ed742 | |||
66bcb90ff9 | |||
e960797bb2 | |||
2f573767e1 | |||
2b23dd7714 | |||
0005d1e8f7 | |||
a4cbda626d | |||
27a522fbeb | |||
4e1b8ea8fb | |||
e0b984e2cf |
@ -26,6 +26,8 @@ type IDatabase interface {
|
|||||||
UpdateOne(dbInstance *gorm.DB, updateData any, optionFuncList ...define.SetOption) (int64, error)
|
UpdateOne(dbInstance *gorm.DB, updateData any, optionFuncList ...define.SetOption) (int64, error)
|
||||||
// List 查询数据列表
|
// List 查询数据列表
|
||||||
List(dbInstance *gorm.DB, result any, optionFuncList ...define.SetOption) error
|
List(dbInstance *gorm.DB, result any, optionFuncList ...define.SetOption) error
|
||||||
|
// ListAndTotal 查询列表并返回满足条件数据总数
|
||||||
|
ListAndTotal(dbInstance *gorm.DB, listRes any, totalRes *int64, disableTotal bool, optionFuncList ...define.SetOption) error
|
||||||
// Delete 删除数据
|
// Delete 删除数据
|
||||||
Delete(dbInstance *gorm.DB, dataModel any, optionFuncList ...define.SetOption) (int64, error)
|
Delete(dbInstance *gorm.DB, dataModel any, optionFuncList ...define.SetOption) (int64, error)
|
||||||
// Detail 数据详情
|
// Detail 数据详情
|
||||||
|
@ -1,345 +0,0 @@
|
|||||||
// Package api2sql ...
|
|
||||||
//
|
|
||||||
// Description : api2sql ...
|
|
||||||
//
|
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
|
||||||
//
|
|
||||||
// Date : 2024-08-21 20:45
|
|
||||||
package api2sql
|
|
||||||
|
|
||||||
import (
|
|
||||||
"context"
|
|
||||||
"errors"
|
|
||||||
"fmt"
|
|
||||||
"git.zhangdeman.cn/zhangdeman/consts"
|
|
||||||
"git.zhangdeman.cn/zhangdeman/database"
|
|
||||||
"git.zhangdeman.cn/zhangdeman/database/abstract"
|
|
||||||
"git.zhangdeman.cn/zhangdeman/database/define"
|
|
||||||
"git.zhangdeman.cn/zhangdeman/wrapper"
|
|
||||||
"gorm.io/gorm"
|
|
||||||
)
|
|
||||||
|
|
||||||
var (
|
|
||||||
Exec = &execute{}
|
|
||||||
)
|
|
||||||
|
|
||||||
type execute struct {
|
|
||||||
databaseClientManager abstract.IWrapperClient // 全部数据库管理的实例
|
|
||||||
baseDao database.BaseDao // 基础dao
|
|
||||||
}
|
|
||||||
|
|
||||||
// SetDatabaseClientManager 设置数据库连接管理实例
|
|
||||||
//
|
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
|
||||||
//
|
|
||||||
// Date : 21:06 2024/8/21
|
|
||||||
func (e *execute) SetDatabaseClientManager(databaseClientManager abstract.IWrapperClient) {
|
|
||||||
e.databaseClientManager = databaseClientManager
|
|
||||||
}
|
|
||||||
|
|
||||||
// Run 执行
|
|
||||||
//
|
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
|
||||||
//
|
|
||||||
// Date : 20:48 2024/8/21
|
|
||||||
func (e *execute) Run(ctx context.Context, inputParam *define.Api2SqlParam) (any, error) {
|
|
||||||
if err := e.formatAndValidateInputParam(inputParam); nil != err {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
if len(inputParam.InputSql) > 0 {
|
|
||||||
// 基于表达式执行
|
|
||||||
return e.Express(ctx, inputParam)
|
|
||||||
}
|
|
||||||
switch inputParam.SqlType {
|
|
||||||
case consts.SqlTypeCount:
|
|
||||||
return e.Count(ctx, inputParam)
|
|
||||||
case consts.SqlTypeDetail:
|
|
||||||
return e.Detail(ctx, inputParam)
|
|
||||||
case consts.SqlTypeList:
|
|
||||||
return e.List(ctx, inputParam)
|
|
||||||
case consts.SqlTypeInsert:
|
|
||||||
return e.Insert(ctx, inputParam)
|
|
||||||
case consts.SqlTypeUpdate:
|
|
||||||
return e.Update(ctx, inputParam)
|
|
||||||
case consts.SqlTypeDelete:
|
|
||||||
return e.Delete(ctx, inputParam)
|
|
||||||
default:
|
|
||||||
return nil, errors.New(inputParam.SqlType + " : sql type is not support")
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// List 方法用于从数据库中查询数据列表。
|
|
||||||
//
|
|
||||||
// 参数:
|
|
||||||
// - ctx: 上下文对象,用于传递请求的上下文信息。
|
|
||||||
// - inputParam: 查询参数,包含 SQL 语句、列列表等信息。
|
|
||||||
//
|
|
||||||
// 返回值:
|
|
||||||
// - any: 查询结果,返回一个结构体切片,其中包含查询到的数据。
|
|
||||||
// - error: 错误信息,如果查询过程中发生错误,将返回相应的错误对象。
|
|
||||||
//
|
|
||||||
// 使用示例:
|
|
||||||
// result, err := e.List(ctx, inputParam)
|
|
||||||
// if err!= nil {
|
|
||||||
// // 处理错误
|
|
||||||
// }
|
|
||||||
// // 处理查询结果
|
|
||||||
//
|
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
|
||||||
//
|
|
||||||
// Date : 20:52 2024/8/21
|
|
||||||
func (e *execute) List(ctx context.Context, inputParam *define.Api2SqlParam) ([]map[string]any, error) {
|
|
||||||
var (
|
|
||||||
err error
|
|
||||||
tx *gorm.DB
|
|
||||||
optionList []define.SetOption
|
|
||||||
val []map[string]any
|
|
||||||
)
|
|
||||||
if tx, err = e.getTx(ctx, inputParam); nil != err {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
if optionList, err = e.getOptionList(ctx, inputParam); nil != err {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
if err = e.baseDao.List(tx, &val, optionList...); nil != err {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return val, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Detail 方法用于获取单个数据的详细信息。
|
|
||||||
// 它接受一个上下文对象 ctx 和一个指向输入参数结构体 Api2SqlParam 的指针 inputParam。
|
|
||||||
// 首先,它会将 inputParam 的 Limit 属性设置为 1,以限制查询结果为一条记录。
|
|
||||||
// 然后,它会调用 e.List 方法来执行查询操作,并将结果存储在 res 变量中。
|
|
||||||
// 如果查询过程中发生错误,它会将错误返回。
|
|
||||||
// 如果查询成功但结果集为空,它会返回一个错误,表示未找到记录。
|
|
||||||
// 如果查询成功且结果集不为空,它会返回结果集中的第一条记录。
|
|
||||||
//
|
|
||||||
// 参数 :
|
|
||||||
// - ctx : 上下文对象,用于传递请求的上下文信息。
|
|
||||||
// - inputParam : 查询参数,包含了查询所需的条件和限制。
|
|
||||||
//
|
|
||||||
// 返回值 :
|
|
||||||
// - 返回查询到的单个数据的详细信息
|
|
||||||
// - 如果未找到数据则返回错误
|
|
||||||
//
|
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
|
||||||
//
|
|
||||||
// Date : 20:52 2024/8/21
|
|
||||||
func (e *execute) Detail(ctx context.Context, inputParam *define.Api2SqlParam) (any, error) {
|
|
||||||
inputParam.Limit = 1 // 限制查询一条
|
|
||||||
var (
|
|
||||||
list []map[string]any
|
|
||||||
err error
|
|
||||||
)
|
|
||||||
if list, err = e.List(ctx, inputParam); nil != err {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
if len(list) == 0 {
|
|
||||||
return nil, gorm.ErrRecordNotFound
|
|
||||||
}
|
|
||||||
return list[0], nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Insert 插入
|
|
||||||
//
|
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
|
||||||
//
|
|
||||||
// Date : 20:52 2024/8/21
|
|
||||||
func (e *execute) Insert(ctx context.Context, inputParam *define.Api2SqlParam) (any, error) {
|
|
||||||
var (
|
|
||||||
err error
|
|
||||||
tx *gorm.DB
|
|
||||||
)
|
|
||||||
|
|
||||||
if tx, err = e.getTx(ctx, inputParam); nil != err {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
// 动态生成结果解析结构体
|
|
||||||
insertVal := map[string]any{}
|
|
||||||
for _, itemColumn := range inputParam.ConditionList {
|
|
||||||
insertVal[itemColumn.Column] = itemColumn.Value
|
|
||||||
}
|
|
||||||
if err = e.baseDao.Create(tx, &insertVal, database.WithTable(inputParam.Table)); nil != err {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return insertVal, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Update 更新
|
|
||||||
//
|
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
|
||||||
//
|
|
||||||
// Date : 20:52 2024/8/21
|
|
||||||
func (e *execute) Update(ctx context.Context, inputParam *define.Api2SqlParam) (any, error) {
|
|
||||||
return nil, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Count 数量
|
|
||||||
//
|
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
|
||||||
//
|
|
||||||
// Date : 20:52 2024/8/21
|
|
||||||
func (e *execute) Count(ctx context.Context, inputParam *define.Api2SqlParam) (any, error) {
|
|
||||||
return nil, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Delete 删除
|
|
||||||
//
|
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
|
||||||
//
|
|
||||||
// Date : 20:51 2024/8/21
|
|
||||||
func (e *execute) Delete(ctx context.Context, inputParam *define.Api2SqlParam) (any, error) {
|
|
||||||
return nil, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Express 基于表达式执行
|
|
||||||
//
|
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
|
||||||
//
|
|
||||||
// Date : 20:51 2024/8/21
|
|
||||||
func (e *execute) Express(ctx context.Context, inputParam *define.Api2SqlParam) (any, error) {
|
|
||||||
if nil == e.databaseClientManager {
|
|
||||||
return nil, errors.New("database client is nil, please use `SetDatabaseClientManager` set instance")
|
|
||||||
}
|
|
||||||
// 格式化 inputParam
|
|
||||||
return nil, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// formatAndValidateInputParam 格式化并校验输入参数
|
|
||||||
//
|
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
|
||||||
//
|
|
||||||
// Date : 10:38 2024/8/22
|
|
||||||
func (e *execute) formatAndValidateInputParam(inputParam *define.Api2SqlParam) error {
|
|
||||||
if nil == inputParam {
|
|
||||||
return errors.New("inputParam is nil")
|
|
||||||
}
|
|
||||||
if len(inputParam.DatabaseFlag) == 0 {
|
|
||||||
return errors.New("databaseFlag is empty")
|
|
||||||
}
|
|
||||||
if len(inputParam.Table) == 0 {
|
|
||||||
return errors.New("table is empty")
|
|
||||||
}
|
|
||||||
if len(inputParam.SqlType) == 0 {
|
|
||||||
return errors.New("sqlType is empty")
|
|
||||||
}
|
|
||||||
databaseClient, err := e.databaseClientManager.GetDBClient(inputParam.DatabaseFlag)
|
|
||||||
if nil != err {
|
|
||||||
return errors.New(inputParam.DatabaseFlag + " : database client get fail -> " + err.Error())
|
|
||||||
}
|
|
||||||
// 尝试获取表结构, api 转 sql 要求必须开启表结构缓存, 否则无法确定相关数据如何解析
|
|
||||||
if inputParam.TableColumnConfig, err = databaseClient.GetTableFieldList(inputParam.Table); nil != err {
|
|
||||||
return errors.New(inputParam.DatabaseFlag + " : get table field list fail -> " + err.Error())
|
|
||||||
}
|
|
||||||
if len(inputParam.TableColumnConfig) == 0 {
|
|
||||||
return errors.New(inputParam.DatabaseFlag + " : table field list is empty, please enable `CacheDataTableStructureConfig` or `SetTableColumnConfig`")
|
|
||||||
}
|
|
||||||
// 操作字段列表为空
|
|
||||||
if err = e.validateColumn(inputParam); nil != err {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
// 验证 force no limit
|
|
||||||
if inputParam.ForceNoLimit {
|
|
||||||
inputParam.Limit = 0
|
|
||||||
inputParam.WithCount = false
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// validateColumn 验证表字段相关
|
|
||||||
//
|
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
|
||||||
//
|
|
||||||
// Date : 11:48 2024/8/22
|
|
||||||
func (e *execute) validateColumn(inputParam *define.Api2SqlParam) error {
|
|
||||||
if len(inputParam.ColumnList) == 0 && wrapper.ArrayType[string]([]string{
|
|
||||||
consts.SqlTypeList, consts.SqlTypeDetail,
|
|
||||||
}).Has(inputParam.SqlType) >= 0 {
|
|
||||||
return errors.New("column list is empty")
|
|
||||||
}
|
|
||||||
// 验证字段是否都正确
|
|
||||||
tableColumnTable := make(map[string]bool)
|
|
||||||
for _, itemColumn := range inputParam.TableColumnConfig {
|
|
||||||
tableColumnTable[itemColumn.Column] = true
|
|
||||||
}
|
|
||||||
for _, columnConfig := range inputParam.ColumnList {
|
|
||||||
if !tableColumnTable[columnConfig.Column] {
|
|
||||||
return errors.New(columnConfig.Column + " : input column not found in table column list")
|
|
||||||
}
|
|
||||||
if len(columnConfig.Alias) == 0 {
|
|
||||||
columnConfig.Alias = columnConfig.Column
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// getTx 获取数据库连接
|
|
||||||
//
|
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
|
||||||
//
|
|
||||||
// Date : 12:20 2024/8/23
|
|
||||||
func (e *execute) getTx(ctx context.Context, inputParam *define.Api2SqlParam) (*gorm.DB, error) {
|
|
||||||
if nil != inputParam.Tx {
|
|
||||||
return inputParam.Tx, nil
|
|
||||||
}
|
|
||||||
if inputParam.ForceMaster || // 强制操作主库
|
|
||||||
wrapper.ArrayType[string]([]string{consts.SqlTypeDelete, consts.SqlTypeInsert, consts.SqlTypeUpdate}).Has(inputParam.SqlType) >= 0 { // 写操作
|
|
||||||
return e.databaseClientManager.GetMasterClient(ctx, inputParam.DatabaseFlag)
|
|
||||||
}
|
|
||||||
return e.databaseClientManager.GetSlaveClient(ctx, inputParam.DatabaseFlag)
|
|
||||||
}
|
|
||||||
|
|
||||||
// getOptionList 设置where条件
|
|
||||||
//
|
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
|
||||||
//
|
|
||||||
// Date : 12:31 2024/8/23
|
|
||||||
func (e *execute) getOptionList(ctx context.Context, inputParam *define.Api2SqlParam) ([]define.SetOption, error) {
|
|
||||||
optionList := []define.SetOption{
|
|
||||||
database.WithTable(inputParam.Table),
|
|
||||||
}
|
|
||||||
// 设置 limit offset
|
|
||||||
if !inputParam.ForceNoLimit && inputParam.Limit > 0 {
|
|
||||||
optionList = append(optionList, database.WithLimit(inputParam.Limit, inputParam.Offset))
|
|
||||||
}
|
|
||||||
for _, item := range inputParam.ConditionList {
|
|
||||||
optionFunc, err := database.WithAnyCondition(item.Column, item.Operate, item.Value)
|
|
||||||
if nil != err {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
optionList = append(optionList, optionFunc)
|
|
||||||
}
|
|
||||||
return optionList, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// dynamicGenerateStruct 生成动态结构体
|
|
||||||
//
|
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
|
||||||
//
|
|
||||||
// Date : 14:19 2024/8/30
|
|
||||||
func (e *execute) dynamicGenerateStruct(columnList []*define.ColumnConfig) *wrapper.DynamicStruct {
|
|
||||||
st := wrapper.NewDynamic()
|
|
||||||
for _, columnConfig := range columnList {
|
|
||||||
tag := fmt.Sprintf(`%v`, columnConfig.Alias)
|
|
||||||
column := wrapper.String(columnConfig.Column).SnakeCaseToCamel()
|
|
||||||
switch columnConfig.Type {
|
|
||||||
case "int", "int8", "int16", "int32", "int64":
|
|
||||||
st.AddInt(column, tag, "")
|
|
||||||
case "uint", "uint8", "uint16", "uint32", "uint64":
|
|
||||||
st.AddUint(column, tag, "")
|
|
||||||
case "bool":
|
|
||||||
st.AddBool(column, tag, "")
|
|
||||||
case "float":
|
|
||||||
st.AddBool(column, tag, "")
|
|
||||||
case "string":
|
|
||||||
st.AddString(column, tag, "")
|
|
||||||
case "map":
|
|
||||||
st.AddMap(column, tag, "")
|
|
||||||
case "slice":
|
|
||||||
st.AddSlice(column, tag, "")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return st
|
|
||||||
}
|
|
@ -1,163 +0,0 @@
|
|||||||
// Package api2sql ...
|
|
||||||
//
|
|
||||||
// Description : api2sql ...
|
|
||||||
//
|
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
|
||||||
//
|
|
||||||
// Date : 2024-08-23 17:36
|
|
||||||
package api2sql
|
|
||||||
|
|
||||||
import (
|
|
||||||
"context"
|
|
||||||
"encoding/json"
|
|
||||||
"fmt"
|
|
||||||
"git.zhangdeman.cn/zhangdeman/consts"
|
|
||||||
"git.zhangdeman.cn/zhangdeman/database"
|
|
||||||
"git.zhangdeman.cn/zhangdeman/database/define"
|
|
||||||
"testing"
|
|
||||||
"time"
|
|
||||||
)
|
|
||||||
|
|
||||||
func startTest() {
|
|
||||||
clientManager := database.NewWrapperClient()
|
|
||||||
if err := clientManager.AddWithConfig("TEST_DATABASE", nil, &define.Database{
|
|
||||||
Master: &define.Driver{
|
|
||||||
DBType: "sqlite3",
|
|
||||||
Host: "/tmp/gateway.db",
|
|
||||||
},
|
|
||||||
Slave: &define.Driver{
|
|
||||||
DBType: "sqlite3",
|
|
||||||
Host: "/tmp/gateway.db",
|
|
||||||
},
|
|
||||||
}, []string{}); nil != err {
|
|
||||||
panic(err.Error())
|
|
||||||
}
|
|
||||||
dbClient, _ := clientManager.GetDBClient("TEST_DATABASE")
|
|
||||||
|
|
||||||
dbClient.SetTableStructure(map[string][]*define.ColumnConfig{
|
|
||||||
"project": []*define.ColumnConfig{
|
|
||||||
&define.ColumnConfig{
|
|
||||||
Column: "flag",
|
|
||||||
Alias: "project_flag",
|
|
||||||
Type: "string",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
})
|
|
||||||
Exec.SetDatabaseClientManager(clientManager)
|
|
||||||
}
|
|
||||||
|
|
||||||
func Test_execute_List(t *testing.T) {
|
|
||||||
startTest()
|
|
||||||
res, err := Exec.List(context.Background(), &define.Api2SqlParam{
|
|
||||||
DatabaseFlag: "TEST_DATABASE",
|
|
||||||
Table: "project",
|
|
||||||
ForceMaster: false,
|
|
||||||
InputSql: "",
|
|
||||||
TableSplitConfig: define.TableSplitConfig{},
|
|
||||||
SqlType: consts.SqlTypeList,
|
|
||||||
ColumnList: []*define.ColumnConfig{
|
|
||||||
&define.ColumnConfig{
|
|
||||||
Column: "flag",
|
|
||||||
Alias: "project_flag",
|
|
||||||
Type: "string",
|
|
||||||
},
|
|
||||||
&define.ColumnConfig{
|
|
||||||
Column: "connect_timeout",
|
|
||||||
Alias: "timeout",
|
|
||||||
Type: "string",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
Limit: 0,
|
|
||||||
Offset: 0,
|
|
||||||
ForceNoLimit: false,
|
|
||||||
OrderField: "id",
|
|
||||||
OrderRule: "desc",
|
|
||||||
WithCount: false,
|
|
||||||
ConditionList: nil,
|
|
||||||
TableColumnConfig: nil,
|
|
||||||
Tx: nil,
|
|
||||||
})
|
|
||||||
byteData, _ := json.Marshal(res)
|
|
||||||
fmt.Println(string(byteData), err)
|
|
||||||
}
|
|
||||||
|
|
||||||
func Test_execute_Detail(t *testing.T) {
|
|
||||||
startTest()
|
|
||||||
res, err := Exec.Detail(context.Background(), &define.Api2SqlParam{
|
|
||||||
DatabaseFlag: "TEST_DATABASE",
|
|
||||||
Table: "project",
|
|
||||||
ForceMaster: false,
|
|
||||||
InputSql: "",
|
|
||||||
TableSplitConfig: define.TableSplitConfig{},
|
|
||||||
SqlType: consts.SqlTypeList,
|
|
||||||
ColumnList: []*define.ColumnConfig{
|
|
||||||
&define.ColumnConfig{
|
|
||||||
Column: "flag",
|
|
||||||
Alias: "project_flag",
|
|
||||||
Type: "string",
|
|
||||||
},
|
|
||||||
&define.ColumnConfig{
|
|
||||||
Column: "description",
|
|
||||||
Alias: "desc",
|
|
||||||
Type: "string",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
Limit: 0,
|
|
||||||
Offset: 0,
|
|
||||||
ForceNoLimit: false,
|
|
||||||
OrderField: "id",
|
|
||||||
OrderRule: "desc",
|
|
||||||
WithCount: false,
|
|
||||||
ConditionList: nil,
|
|
||||||
TableColumnConfig: nil,
|
|
||||||
Tx: nil,
|
|
||||||
})
|
|
||||||
byteData, _ := json.Marshal(res)
|
|
||||||
fmt.Println(res, err, string(byteData))
|
|
||||||
}
|
|
||||||
|
|
||||||
func Test_execute_Insert(t *testing.T) {
|
|
||||||
startTest()
|
|
||||||
res, err := Exec.Insert(context.Background(), &define.Api2SqlParam{
|
|
||||||
DatabaseFlag: "TEST_DATABASE",
|
|
||||||
Table: "project",
|
|
||||||
ForceMaster: false,
|
|
||||||
InputSql: "",
|
|
||||||
TableSplitConfig: define.TableSplitConfig{},
|
|
||||||
SqlType: consts.SqlTypeList,
|
|
||||||
ColumnList: []*define.ColumnConfig{
|
|
||||||
&define.ColumnConfig{
|
|
||||||
Column: "flag",
|
|
||||||
Alias: "project_flag",
|
|
||||||
Type: "string",
|
|
||||||
},
|
|
||||||
&define.ColumnConfig{
|
|
||||||
Column: "description",
|
|
||||||
Alias: "desc",
|
|
||||||
Type: "string",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
Limit: 0,
|
|
||||||
Offset: 0,
|
|
||||||
ForceNoLimit: false,
|
|
||||||
OrderField: "id",
|
|
||||||
OrderRule: "desc",
|
|
||||||
WithCount: false,
|
|
||||||
ConditionList: []define.SqlCondition{
|
|
||||||
define.SqlCondition{
|
|
||||||
Column: "flag",
|
|
||||||
Operate: "",
|
|
||||||
Value: fmt.Sprintf("unit_test_flag_%v", time.Now().Unix()),
|
|
||||||
},
|
|
||||||
define.SqlCondition{
|
|
||||||
Column: "description",
|
|
||||||
Operate: "",
|
|
||||||
Value: "单元测试生成项目",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
TableColumnConfig: nil,
|
|
||||||
Tx: nil,
|
|
||||||
})
|
|
||||||
byteData, _ := json.Marshal(res)
|
|
||||||
fmt.Println(res, err, string(byteData))
|
|
||||||
}
|
|
60
base.go
60
base.go
@ -8,8 +8,8 @@ package database
|
|||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
"git.zhangdeman.cn/zhangdeman/database/define"
|
"git.zhangdeman.cn/zhangdeman/database/define"
|
||||||
|
|
||||||
"gorm.io/gorm"
|
"gorm.io/gorm"
|
||||||
|
"reflect"
|
||||||
)
|
)
|
||||||
|
|
||||||
// BaseDao 基础dao层
|
// BaseDao 基础dao层
|
||||||
@ -69,6 +69,40 @@ func (b *BaseDao) List(dbInstance *gorm.DB, result any, optionFuncList ...define
|
|||||||
return dbInstance.Find(result).Error
|
return dbInstance.Find(result).Error
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ListAndTotal 同时查询数据列表和数据总数
|
||||||
|
//
|
||||||
|
// Author : go_developer@163.com<白茶清欢>
|
||||||
|
//
|
||||||
|
// Date : 16:04 2025/2/26
|
||||||
|
func (b *BaseDao) ListAndTotal(dbInstance *gorm.DB, listRes any, totalRes *int64, disableTotal bool, optionFuncList ...define.SetOption) error {
|
||||||
|
var (
|
||||||
|
err error
|
||||||
|
)
|
||||||
|
if err = b.receiverTypeValid(listRes); nil != err {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if err = b.receiverTypeValid(totalRes); nil != err {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
dbInstance = b.setTxCondition(dbInstance, optionFuncList...)
|
||||||
|
if err = dbInstance.Find(listRes).Error; nil != err {
|
||||||
|
// 列表查询失败
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if disableTotal {
|
||||||
|
// 禁用查询总数
|
||||||
|
*totalRes = int64(reflect.ValueOf(listRes).Elem().Len())
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
optionFuncList = append(optionFuncList, WithClearLimit())
|
||||||
|
dbInstance = b.setTxCondition(dbInstance, optionFuncList...)
|
||||||
|
if err = dbInstance.Count(totalRes).Error; nil != err {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
// Delete 删除数据, 硬删除, 对应 delete语句
|
// Delete 删除数据, 硬删除, 对应 delete语句
|
||||||
//
|
//
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
// Author : go_developer@163.com<白茶清欢>
|
||||||
@ -120,6 +154,7 @@ func (b *BaseDao) IsNotFound(err error) bool {
|
|||||||
//
|
//
|
||||||
// Date : 8:25 下午 2021/8/8
|
// Date : 8:25 下午 2021/8/8
|
||||||
func (b *BaseDao) Count(dbInstance *gorm.DB, optionFuncList ...define.SetOption) (int64, error) {
|
func (b *BaseDao) Count(dbInstance *gorm.DB, optionFuncList ...define.SetOption) (int64, error) {
|
||||||
|
optionFuncList = append(optionFuncList, WithClearLimit())
|
||||||
dbInstance = b.setTxCondition(dbInstance, optionFuncList...)
|
dbInstance = b.setTxCondition(dbInstance, optionFuncList...)
|
||||||
var cnt int64
|
var cnt int64
|
||||||
return cnt, dbInstance.Count(&cnt).Error
|
return cnt, dbInstance.Count(&cnt).Error
|
||||||
@ -174,14 +209,18 @@ func (b *BaseDao) Rollback(db *gorm.DB) error {
|
|||||||
// Author : go_developer@163.com<白茶清欢>
|
// Author : go_developer@163.com<白茶清欢>
|
||||||
//
|
//
|
||||||
// Date : 17:38 2022/5/15
|
// Date : 17:38 2022/5/15
|
||||||
func (b *BaseDao) setTxCondition(tx *gorm.DB, optionFuncList ...define.SetOption) *gorm.DB {
|
func (b *BaseDao) setTxCondition(inputTx *gorm.DB, optionFuncList ...define.SetOption) *gorm.DB {
|
||||||
|
|
||||||
// 构建查询条件
|
// 构建查询条件
|
||||||
o := &define.Option{}
|
o := &define.Option{}
|
||||||
for _, fn := range optionFuncList {
|
for _, fn := range optionFuncList {
|
||||||
fn(o)
|
fn(o)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
tx := inputTx.Session(&gorm.Session{
|
||||||
|
NewDB: true,
|
||||||
|
Initialized: true,
|
||||||
|
})
|
||||||
|
|
||||||
// 指定查询的表
|
// 指定查询的表
|
||||||
if len(o.Table) > 0 {
|
if len(o.Table) > 0 {
|
||||||
tx = tx.Table(o.Table)
|
tx = tx.Table(o.Table)
|
||||||
@ -240,6 +279,10 @@ func (b *BaseDao) setTxCondition(tx *gorm.DB, optionFuncList ...define.SetOption
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if len(o.Where) > 0 {
|
||||||
|
tx = tx.Where(o.Where)
|
||||||
|
}
|
||||||
|
|
||||||
// between
|
// between
|
||||||
for field, betweenVal := range o.Between {
|
for field, betweenVal := range o.Between {
|
||||||
tx = tx.Where("`"+field+"` BETWEEN ? AND ?", betweenVal[0], betweenVal[1])
|
tx = tx.Where("`"+field+"` BETWEEN ? AND ?", betweenVal[0], betweenVal[1])
|
||||||
@ -250,8 +293,8 @@ func (b *BaseDao) setTxCondition(tx *gorm.DB, optionFuncList ...define.SetOption
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 排序
|
// 排序
|
||||||
for _, orderRule := range o.Order {
|
if len(o.Order) == 2 {
|
||||||
tx = tx.Order(orderRule)
|
tx = tx.Order(o.Order[0] + " " + o.Order[1])
|
||||||
}
|
}
|
||||||
|
|
||||||
// or 语句
|
// or 语句
|
||||||
@ -281,3 +324,10 @@ func (b *BaseDao) setTxCondition(tx *gorm.DB, optionFuncList ...define.SetOption
|
|||||||
}*/
|
}*/
|
||||||
return tx
|
return tx
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (b *BaseDao) receiverTypeValid(receiver any) error {
|
||||||
|
if receiver == nil || reflect.TypeOf(receiver).Kind() != reflect.Ptr {
|
||||||
|
return errors.New("receiver is nil or receiver is not a pointer")
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
@ -44,7 +44,6 @@ type Api2SqlParam struct {
|
|||||||
WithCount bool `json:"with_count"` // 是否返回数据总量, 仅 sqlType = list 生效
|
WithCount bool `json:"with_count"` // 是否返回数据总量, 仅 sqlType = list 生效
|
||||||
ConditionList []SqlCondition `json:"value_list"` // 字段列表
|
ConditionList []SqlCondition `json:"value_list"` // 字段列表
|
||||||
TableColumnConfig []*ColumnConfig `json:"table_column_config"` // 表字段配置
|
TableColumnConfig []*ColumnConfig `json:"table_column_config"` // 表字段配置
|
||||||
UpdateData map[string]any `json:"update_data"` // 要更新的数据, 仅对 update语句有效
|
|
||||||
Tx *gorm.DB `json:"-"` // 前后已有的数据库连接, 直接复用
|
Tx *gorm.DB `json:"-"` // 前后已有的数据库连接, 直接复用
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -7,6 +7,8 @@
|
|||||||
// Date : 2021-03-01 9:27 下午
|
// Date : 2021-03-01 9:27 下午
|
||||||
package define
|
package define
|
||||||
|
|
||||||
|
import "git.zhangdeman.cn/zhangdeman/consts"
|
||||||
|
|
||||||
// DBConfig 数据库连接的配置
|
// DBConfig 数据库连接的配置
|
||||||
//
|
//
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
// Author : go_developer@163.com<白茶清欢>
|
||||||
@ -28,10 +30,10 @@ type DBConfig struct {
|
|||||||
//
|
//
|
||||||
// Date : 14:47 2022/6/9
|
// Date : 14:47 2022/6/9
|
||||||
type CfgFile struct {
|
type CfgFile struct {
|
||||||
Flag string `json:"flag"` // 数据库标识
|
Flag string `json:"flag"` // 数据库标识
|
||||||
Path string `json:"path"` // 配置文件路径
|
Path string `json:"path"` // 配置文件路径
|
||||||
Type string `json:"type"` // 配置文件类型
|
Type consts.FileType `json:"type"` // 配置文件类型
|
||||||
Config *Database `json:"config"` // 解析之后的配置文件
|
Config *Database `json:"config"` // 解析之后的配置文件
|
||||||
}
|
}
|
||||||
|
|
||||||
// Database 数据库配置
|
// Database 数据库配置
|
||||||
@ -40,8 +42,8 @@ type CfgFile struct {
|
|||||||
//
|
//
|
||||||
// Date : 15:19 2022/6/9
|
// Date : 15:19 2022/6/9
|
||||||
type Database struct {
|
type Database struct {
|
||||||
Master *Driver `json:"master" yaml:"master"` // 主库配置
|
Master *Driver `json:"master" yaml:"master" toml:"master" ini:"master"` // 主库配置
|
||||||
Slave *Driver `json:"slave" yaml:"slave"` // 从库配置
|
Slave *Driver `json:"slave" yaml:"slave" toml:"slave" ini:"slave"` // 从库配置
|
||||||
}
|
}
|
||||||
|
|
||||||
// Driver ...
|
// Driver ...
|
||||||
@ -50,15 +52,15 @@ type Database struct {
|
|||||||
//
|
//
|
||||||
// Date : 18:44 2022/5/14
|
// Date : 18:44 2022/5/14
|
||||||
type Driver struct {
|
type Driver struct {
|
||||||
DBType string `json:"db_type" yaml:"db_type"` // 数据库驱动类型
|
DBType string `json:"db_type" yaml:"db_type" toml:"db_type" ini:"db_type"` // 数据库驱动类型
|
||||||
Host string `json:"host" yaml:"host"` // 数据库地址
|
Host string `json:"host" yaml:"host" toml:"host" ini:"host"` // 数据库地址
|
||||||
Port int `json:"port" yaml:"port"` // 数据库端口
|
Port int `json:"port" yaml:"port" toml:"port" ini:"port"` // 数据库端口
|
||||||
Username string `json:"username" yaml:"username"` // 用户名
|
Username string `json:"username" yaml:"username" toml:"username" ini:"username"` // 用户名
|
||||||
Password string `json:"password" yaml:"password"` // 密码
|
Password string `json:"password" yaml:"password" toml:"password" ini:"password"` // 密码
|
||||||
Database string `json:"database" yaml:"database"` // 数据库
|
Database string `json:"database" yaml:"database" toml:"database" ini:"database"` // 数据库
|
||||||
Charset string `json:"charset" yaml:"charset"` // 数据库编码
|
Charset string `json:"charset" yaml:"charset" toml:"charset" ini:"charset"` // 数据库编码
|
||||||
Connection *Connection `json:"connection" yaml:"connection"` // 连接配置
|
Connection *Connection `json:"connection" yaml:"connection" toml:"connection" ini:"connection"` // 连接配置
|
||||||
Timezone string `json:"timezone" yaml:"timezone"` // 时区
|
Timezone string `json:"timezone" yaml:"timezone" toml:"timezone" ini:"timezone"` // 时区
|
||||||
}
|
}
|
||||||
|
|
||||||
// Connection 连接数配置
|
// Connection 连接数配置
|
||||||
@ -67,8 +69,8 @@ type Driver struct {
|
|||||||
//
|
//
|
||||||
// Date : 15:18 2022/6/9
|
// Date : 15:18 2022/6/9
|
||||||
type Connection struct {
|
type Connection struct {
|
||||||
MaxOpen int `json:"max_open" yaml:"max_open"` // 最大打开连接数
|
MaxOpen int `json:"max_open" yaml:"max_open" toml:"max_open" ini:"max_open"` // 最大打开连接数
|
||||||
MaxIdle int `json:"max_idle" yaml:"max_idle"` // 最大的处理连接数
|
MaxIdle int `json:"max_idle" yaml:"max_idle" toml:"max_idle" ini:"max_idle"` // 最大的处理连接数
|
||||||
}
|
}
|
||||||
|
|
||||||
// DescTableItem 表结构的描述
|
// DescTableItem 表结构的描述
|
||||||
|
76
go.mod
76
go.mod
@ -1,77 +1,77 @@
|
|||||||
module git.zhangdeman.cn/zhangdeman/database
|
module git.zhangdeman.cn/zhangdeman/database
|
||||||
|
|
||||||
go 1.21.0
|
go 1.24.1
|
||||||
|
|
||||||
toolchain go1.23.0
|
toolchain go1.24.2
|
||||||
|
|
||||||
require (
|
require (
|
||||||
git.zhangdeman.cn/zhangdeman/consts v0.0.0-20240823041145-d4df71cf37e5
|
git.zhangdeman.cn/zhangdeman/consts v0.0.0-20250916024308-d378e6c57772
|
||||||
git.zhangdeman.cn/zhangdeman/logger v0.0.0-20240725055115-98eb52ae307a
|
git.zhangdeman.cn/zhangdeman/logger v0.0.0-20250817142254-a501f79e7894
|
||||||
git.zhangdeman.cn/zhangdeman/op_type v0.0.0-20240122104027-4928421213c0
|
git.zhangdeman.cn/zhangdeman/op_type v0.0.0-20240122104027-4928421213c0
|
||||||
git.zhangdeman.cn/zhangdeman/serialize v0.0.0-20240618035451-8d48a6bd39dd
|
git.zhangdeman.cn/zhangdeman/serialize v0.0.0-20250504055908-8d68e6106ea9
|
||||||
git.zhangdeman.cn/zhangdeman/wrapper v0.0.0-20240823103024-c38d16dc28d3
|
git.zhangdeman.cn/zhangdeman/wrapper v0.0.0-20250321102712-1cbfbe959740
|
||||||
github.com/pkg/errors v0.9.1
|
github.com/pkg/errors v0.9.1
|
||||||
github.com/xwb1989/sqlparser v0.0.0-20180606152119-120387863bf2
|
github.com/xwb1989/sqlparser v0.0.0-20180606152119-120387863bf2
|
||||||
go.uber.org/zap v1.27.0
|
go.uber.org/zap v1.27.0
|
||||||
gorm.io/driver/mysql v1.5.7
|
gorm.io/driver/mysql v1.6.0
|
||||||
gorm.io/driver/sqlite v1.5.6
|
gorm.io/driver/sqlite v1.6.0
|
||||||
gorm.io/gorm v1.25.11
|
gorm.io/gorm v1.31.0
|
||||||
)
|
)
|
||||||
|
|
||||||
require (
|
require (
|
||||||
filippo.io/edwards25519 v1.1.0 // indirect
|
filippo.io/edwards25519 v1.1.0 // indirect
|
||||||
git.zhangdeman.cn/zhangdeman/easylock v0.0.0-20230731062340-983985c12eda // indirect
|
git.zhangdeman.cn/zhangdeman/easylock v0.0.0-20230731062340-983985c12eda // indirect
|
||||||
git.zhangdeman.cn/zhangdeman/easymap v0.0.0-20240311030808-e2a2e6a3c211 // indirect
|
git.zhangdeman.cn/zhangdeman/easymap v0.0.0-20241101082529-28a6c68e38a4 // indirect
|
||||||
git.zhangdeman.cn/zhangdeman/gin v0.0.0-20240817122134-195e39123512 // indirect
|
git.zhangdeman.cn/zhangdeman/network v0.0.0-20250726060351-78810e906bfa // indirect
|
||||||
git.zhangdeman.cn/zhangdeman/network v0.0.0-20230925112156-f0eb86dd2442 // indirect
|
|
||||||
git.zhangdeman.cn/zhangdeman/util v0.0.0-20240618042405-6ee2c904644e // indirect
|
git.zhangdeman.cn/zhangdeman/util v0.0.0-20240618042405-6ee2c904644e // indirect
|
||||||
git.zhangdeman.cn/zhangdeman/websocket v0.0.0-20240723075210-85feada512b2 // indirect
|
git.zhangdeman.cn/zhangdeman/websocket v0.0.0-20241125101541-c5ea194c9c1e // indirect
|
||||||
github.com/BurntSushi/toml v1.4.0 // indirect
|
github.com/BurntSushi/toml v1.5.0 // indirect
|
||||||
github.com/axgle/mahonia v0.0.0-20180208002826-3358181d7394 // indirect
|
github.com/axgle/mahonia v0.0.0-20180208002826-3358181d7394 // indirect
|
||||||
github.com/bytedance/sonic v1.12.2 // indirect
|
github.com/bytedance/gopkg v0.1.3 // indirect
|
||||||
github.com/bytedance/sonic/loader v0.2.0 // indirect
|
github.com/bytedance/sonic v1.14.1 // indirect
|
||||||
github.com/cloudwego/base64x v0.1.4 // indirect
|
github.com/bytedance/sonic/loader v0.3.0 // indirect
|
||||||
github.com/cloudwego/iasm v0.2.0 // indirect
|
github.com/cloudwego/base64x v0.1.6 // indirect
|
||||||
github.com/dgrijalva/jwt-go/v4 v4.0.0-preview1 // indirect
|
github.com/dgrijalva/jwt-go/v4 v4.0.0-preview1 // indirect
|
||||||
github.com/gabriel-vasile/mimetype v1.4.5 // indirect
|
github.com/gabriel-vasile/mimetype v1.4.10 // indirect
|
||||||
github.com/gin-contrib/sse v0.1.0 // indirect
|
github.com/gin-contrib/sse v1.1.0 // indirect
|
||||||
github.com/gin-gonic/gin v1.10.0 // indirect
|
github.com/gin-gonic/gin v1.10.1 // indirect
|
||||||
github.com/go-ini/ini v1.67.0 // indirect
|
github.com/go-ini/ini v1.67.0 // indirect
|
||||||
github.com/go-playground/locales v0.14.1 // indirect
|
github.com/go-playground/locales v0.14.1 // indirect
|
||||||
github.com/go-playground/universal-translator v0.18.1 // indirect
|
github.com/go-playground/universal-translator v0.18.1 // indirect
|
||||||
github.com/go-playground/validator/v10 v10.22.0 // indirect
|
github.com/go-playground/validator/v10 v10.27.0 // indirect
|
||||||
github.com/go-sql-driver/mysql v1.8.1 // indirect
|
github.com/go-sql-driver/mysql v1.9.3 // indirect
|
||||||
github.com/goccy/go-json v0.10.3 // indirect
|
github.com/goccy/go-json v0.10.5 // indirect
|
||||||
github.com/gorilla/websocket v1.5.3 // indirect
|
github.com/gorilla/websocket v1.5.3 // indirect
|
||||||
github.com/jinzhu/inflection v1.0.0 // indirect
|
github.com/jinzhu/inflection v1.0.0 // indirect
|
||||||
github.com/jinzhu/now v1.1.5 // indirect
|
github.com/jinzhu/now v1.1.5 // indirect
|
||||||
github.com/json-iterator/go v1.1.12 // indirect
|
github.com/json-iterator/go v1.1.12 // indirect
|
||||||
github.com/klauspost/cpuid/v2 v2.2.8 // indirect
|
github.com/klauspost/cpuid/v2 v2.3.0 // indirect
|
||||||
github.com/leodido/go-urn v1.4.0 // indirect
|
github.com/leodido/go-urn v1.4.0 // indirect
|
||||||
github.com/lestrrat-go/file-rotatelogs v2.4.0+incompatible // indirect
|
github.com/lestrrat-go/file-rotatelogs v2.4.0+incompatible // indirect
|
||||||
github.com/lestrrat-go/strftime v1.1.0 // indirect
|
github.com/lestrrat-go/strftime v1.1.1 // indirect
|
||||||
github.com/mattn/go-isatty v0.0.20 // indirect
|
github.com/mattn/go-isatty v0.0.20 // indirect
|
||||||
github.com/mattn/go-sqlite3 v1.14.23 // indirect
|
github.com/mattn/go-sqlite3 v1.14.32 // indirect
|
||||||
github.com/mitchellh/go-homedir v1.1.0 // indirect
|
github.com/mitchellh/go-homedir v1.1.0 // indirect
|
||||||
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect
|
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect
|
||||||
github.com/modern-go/reflect2 v1.0.2 // indirect
|
github.com/modern-go/reflect2 v1.0.2 // indirect
|
||||||
github.com/mozillazg/go-pinyin v0.20.0 // indirect
|
github.com/mozillazg/go-pinyin v0.21.0 // indirect
|
||||||
github.com/mssola/user_agent v0.6.0 // indirect
|
github.com/mssola/user_agent v0.6.0 // indirect
|
||||||
github.com/pelletier/go-toml/v2 v2.2.3 // indirect
|
github.com/pelletier/go-toml/v2 v2.2.4 // indirect
|
||||||
|
github.com/sbabiv/xml2map v1.2.1 // indirect
|
||||||
github.com/spaolacci/murmur3 v1.1.0 // indirect
|
github.com/spaolacci/murmur3 v1.1.0 // indirect
|
||||||
github.com/tidwall/gjson v1.17.3 // indirect
|
github.com/tidwall/gjson v1.18.0 // indirect
|
||||||
github.com/tidwall/match v1.1.1 // indirect
|
github.com/tidwall/match v1.2.0 // indirect
|
||||||
github.com/tidwall/pretty v1.2.1 // indirect
|
github.com/tidwall/pretty v1.2.1 // indirect
|
||||||
github.com/twitchyliquid64/golang-asm v0.15.1 // indirect
|
github.com/twitchyliquid64/golang-asm v0.15.1 // indirect
|
||||||
github.com/ugorji/go/codec v1.2.12 // indirect
|
github.com/ugorji/go/codec v1.3.0 // indirect
|
||||||
go.uber.org/multierr v1.11.0 // indirect
|
go.uber.org/multierr v1.11.0 // indirect
|
||||||
golang.org/x/arch v0.10.0 // indirect
|
golang.org/x/arch v0.21.0 // indirect
|
||||||
golang.org/x/crypto v0.26.0 // indirect
|
golang.org/x/crypto v0.42.0 // indirect
|
||||||
golang.org/x/net v0.28.0 // indirect
|
golang.org/x/net v0.44.0 // indirect
|
||||||
golang.org/x/sys v0.25.0 // indirect
|
golang.org/x/sys v0.36.0 // indirect
|
||||||
golang.org/x/text v0.18.0 // indirect
|
golang.org/x/text v0.29.0 // indirect
|
||||||
golang.org/x/xerrors v0.0.0-20231012003039-104605ab7028 // indirect
|
golang.org/x/xerrors v0.0.0-20231012003039-104605ab7028 // indirect
|
||||||
google.golang.org/protobuf v1.34.2 // indirect
|
google.golang.org/protobuf v1.36.9 // indirect
|
||||||
gopkg.in/olahol/melody.v1 v1.0.0-20170518105555-d52139073376 // indirect
|
gopkg.in/olahol/melody.v1 v1.0.0-20170518105555-d52139073376 // indirect
|
||||||
gopkg.in/yaml.v3 v3.0.1 // indirect
|
gopkg.in/yaml.v3 v3.0.1 // indirect
|
||||||
)
|
)
|
||||||
|
178
go.sum
178
go.sum
@ -1,51 +1,48 @@
|
|||||||
filippo.io/edwards25519 v1.1.0 h1:FNf4tywRC1HmFuKW5xopWpigGjJKiJSV0Cqo0cJWDaA=
|
filippo.io/edwards25519 v1.1.0 h1:FNf4tywRC1HmFuKW5xopWpigGjJKiJSV0Cqo0cJWDaA=
|
||||||
filippo.io/edwards25519 v1.1.0/go.mod h1:BxyFTGdWcka3PhytdK4V28tE5sGfRvvvRV7EaN4VDT4=
|
filippo.io/edwards25519 v1.1.0/go.mod h1:BxyFTGdWcka3PhytdK4V28tE5sGfRvvvRV7EaN4VDT4=
|
||||||
git.zhangdeman.cn/zhangdeman/consts v0.0.0-20240823041145-d4df71cf37e5 h1:pmIHln0gWW+5xAB762h3WDsRkZuYLUDndvJDsGMKoOY=
|
git.zhangdeman.cn/zhangdeman/consts v0.0.0-20250916024308-d378e6c57772 h1:Yo1ur3LnDF5s7F7tpJsNrdUSF8LwYKnN9TdQU32F3eU=
|
||||||
git.zhangdeman.cn/zhangdeman/consts v0.0.0-20240823041145-d4df71cf37e5/go.mod h1:IXXaZkb7vGzGnGM5RRWrASAuwrVSNxuoe0DmeXx5g6k=
|
git.zhangdeman.cn/zhangdeman/consts v0.0.0-20250916024308-d378e6c57772/go.mod h1:5p8CEKGBxi7qPtTXDI3HDmqKAfIm5i/aBWdrbkbdNjc=
|
||||||
git.zhangdeman.cn/zhangdeman/easylock v0.0.0-20230731062340-983985c12eda h1:bMD6r9gjRy7cO+T4zRQVYAesgIblBdTnhzT1vN5wjvI=
|
git.zhangdeman.cn/zhangdeman/easylock v0.0.0-20230731062340-983985c12eda h1:bMD6r9gjRy7cO+T4zRQVYAesgIblBdTnhzT1vN5wjvI=
|
||||||
git.zhangdeman.cn/zhangdeman/easylock v0.0.0-20230731062340-983985c12eda/go.mod h1:dT0rmHcJ9Z9IqWeMIt7YzR88nKkNV2V3dfG0j9Q6lK0=
|
git.zhangdeman.cn/zhangdeman/easylock v0.0.0-20230731062340-983985c12eda/go.mod h1:dT0rmHcJ9Z9IqWeMIt7YzR88nKkNV2V3dfG0j9Q6lK0=
|
||||||
git.zhangdeman.cn/zhangdeman/easymap v0.0.0-20240311030808-e2a2e6a3c211 h1:I/wOsRpCSRkU9vo1u703slQsmK0wnNeZzsWQOGtIAG0=
|
git.zhangdeman.cn/zhangdeman/easymap v0.0.0-20241101082529-28a6c68e38a4 h1:s6d4b6yY+NaK1AzoBD1pxqsuygEHQz0Oie86c45geDw=
|
||||||
git.zhangdeman.cn/zhangdeman/easymap v0.0.0-20240311030808-e2a2e6a3c211/go.mod h1:SrtvrQRdzt+8KfYzvosH++gWxo2ShPTzR1m3VQ6uX7U=
|
git.zhangdeman.cn/zhangdeman/easymap v0.0.0-20241101082529-28a6c68e38a4/go.mod h1:V4Dfg1v/JVIZGEKCm6/aehs8hK+Xow1dkL1yiQymXlQ=
|
||||||
git.zhangdeman.cn/zhangdeman/gin v0.0.0-20240817122134-195e39123512 h1:j+zH8gl4aEg24GWCutddnH5hw4eAuFJLW6vvJUJiJpM=
|
git.zhangdeman.cn/zhangdeman/logger v0.0.0-20250817142254-a501f79e7894 h1:7nT1CADIAO2lhikqM1lAFlwrJXa7gNaz5bcUB+LgAIE=
|
||||||
git.zhangdeman.cn/zhangdeman/gin v0.0.0-20240817122134-195e39123512/go.mod h1:twDDFXzPJ56qfAG1ZtPhvwXmtZG+aRlk2dnnjufh/hs=
|
git.zhangdeman.cn/zhangdeman/logger v0.0.0-20250817142254-a501f79e7894/go.mod h1:UKGSNWsDmf6pBrC3SuC+jR7/Lj30c6b72hZi8dI+Vp8=
|
||||||
git.zhangdeman.cn/zhangdeman/logger v0.0.0-20240725055115-98eb52ae307a h1:22VkxGmpS58zHA8tf75lPr/3S6hmHKP00w/jUa700Ps=
|
git.zhangdeman.cn/zhangdeman/network v0.0.0-20250726060351-78810e906bfa h1:r3AK2EKbQ82ShC5+AjbE95sqm90CkpbzLpmoV3zok9Q=
|
||||||
git.zhangdeman.cn/zhangdeman/logger v0.0.0-20240725055115-98eb52ae307a/go.mod h1:phaF6LMebn7Fpp8J/mOzHRYGniKuCk78k4N53T2m8NI=
|
git.zhangdeman.cn/zhangdeman/network v0.0.0-20250726060351-78810e906bfa/go.mod h1:v0tMMfXvE4WyUxaRo1r/D20BAbMkT5QPLSW7XtgQOxo=
|
||||||
git.zhangdeman.cn/zhangdeman/network v0.0.0-20230925112156-f0eb86dd2442 h1:1eBf0C0gdpBQOqjTK3UCw/mwzQ/SCodx3iTQtidx9eE=
|
|
||||||
git.zhangdeman.cn/zhangdeman/network v0.0.0-20230925112156-f0eb86dd2442/go.mod h1:hFYWiS+ExIuJJJdwHWy4P3pVHbd/0mpv53qlbhDNdTI=
|
|
||||||
git.zhangdeman.cn/zhangdeman/op_type v0.0.0-20240122104027-4928421213c0 h1:gUDlQMuJ4xNfP2Abl1Msmpa3fASLWYkNlqDFF/6GN0Y=
|
git.zhangdeman.cn/zhangdeman/op_type v0.0.0-20240122104027-4928421213c0 h1:gUDlQMuJ4xNfP2Abl1Msmpa3fASLWYkNlqDFF/6GN0Y=
|
||||||
git.zhangdeman.cn/zhangdeman/op_type v0.0.0-20240122104027-4928421213c0/go.mod h1:VHb9qmhaPDAQDcS6vUiDCamYjZ4R5lD1XtVsh55KsMI=
|
git.zhangdeman.cn/zhangdeman/op_type v0.0.0-20240122104027-4928421213c0/go.mod h1:VHb9qmhaPDAQDcS6vUiDCamYjZ4R5lD1XtVsh55KsMI=
|
||||||
git.zhangdeman.cn/zhangdeman/serialize v0.0.0-20240618035451-8d48a6bd39dd h1:2Y37waOVCmVvx0Rp8VGEptE2/2JVMImtxB4dKKDk/3w=
|
git.zhangdeman.cn/zhangdeman/serialize v0.0.0-20250504055908-8d68e6106ea9 h1:/GLQaFoLb+ciHOtAS2BIyPNnf4O5ME3AC5PUaJY9kfs=
|
||||||
git.zhangdeman.cn/zhangdeman/serialize v0.0.0-20240618035451-8d48a6bd39dd/go.mod h1:6+7whkCmb4sJDIfH3HxNuXRveaM0gCCNWd2uXZqNtIE=
|
git.zhangdeman.cn/zhangdeman/serialize v0.0.0-20250504055908-8d68e6106ea9/go.mod h1:ABJ655C5QenQNOzf7LjCe4sSB52CXvaWLX2Zg4uwDJY=
|
||||||
git.zhangdeman.cn/zhangdeman/util v0.0.0-20240618042405-6ee2c904644e h1:Q973S6CcWr1ICZhFI1STFOJ+KUImCl2BaIXm6YppBqI=
|
git.zhangdeman.cn/zhangdeman/util v0.0.0-20240618042405-6ee2c904644e h1:Q973S6CcWr1ICZhFI1STFOJ+KUImCl2BaIXm6YppBqI=
|
||||||
git.zhangdeman.cn/zhangdeman/util v0.0.0-20240618042405-6ee2c904644e/go.mod h1:VpPjBlwz8U+OxZuxzHQBv1aEEZ3pStH6bZvT21ADEbI=
|
git.zhangdeman.cn/zhangdeman/util v0.0.0-20240618042405-6ee2c904644e/go.mod h1:VpPjBlwz8U+OxZuxzHQBv1aEEZ3pStH6bZvT21ADEbI=
|
||||||
git.zhangdeman.cn/zhangdeman/websocket v0.0.0-20240723075210-85feada512b2 h1:P2kuhU2TFWk9mPbJlZCK6FMDVS7S3NGafWKD4eNqKiI=
|
git.zhangdeman.cn/zhangdeman/websocket v0.0.0-20241125101541-c5ea194c9c1e h1:YE2Gi+M03UDImIpWa3I7jzSesyfu2RL8x/4ONs5v0oE=
|
||||||
git.zhangdeman.cn/zhangdeman/websocket v0.0.0-20240723075210-85feada512b2/go.mod h1:7KaMpQmWgiNLpEkaV7oDtep7geI1f/VoCoPVcyvMjAE=
|
git.zhangdeman.cn/zhangdeman/websocket v0.0.0-20241125101541-c5ea194c9c1e/go.mod h1:L/7JugxKZL3JP9JP/XDvPAPz0FQXG1u181Su1+u/d1c=
|
||||||
git.zhangdeman.cn/zhangdeman/wrapper v0.0.0-20240823103024-c38d16dc28d3 h1:RcWNxrHmhZksZWrP/HLEwAM8uIIHYlPLQ20HnLzC+j0=
|
git.zhangdeman.cn/zhangdeman/wrapper v0.0.0-20250321102712-1cbfbe959740 h1:zPUoylfJTbc0EcxW+NEzOTBmoeFZ2I/rLFBnEzxb4Wk=
|
||||||
git.zhangdeman.cn/zhangdeman/wrapper v0.0.0-20240823103024-c38d16dc28d3/go.mod h1:KcojKP22mv9/IZrQWlIBfa1EuBxtEOqfWMgN3SYK2N8=
|
git.zhangdeman.cn/zhangdeman/wrapper v0.0.0-20250321102712-1cbfbe959740/go.mod h1:1ct92dbVc49pmXusA/iGfcQUJzcYmJ+cjAhgc3sDv1I=
|
||||||
github.com/BurntSushi/toml v1.4.0 h1:kuoIxZQy2WRRk1pttg9asf+WVv6tWQuBNVmK8+nqPr0=
|
github.com/BurntSushi/toml v1.5.0 h1:W5quZX/G/csjUnuI8SUYlsHs9M38FC7znL0lIO+DvMg=
|
||||||
github.com/BurntSushi/toml v1.4.0/go.mod h1:ukJfTF/6rtPPRCnwkur4qwRxa8vTRFBF0uk2lLoLwho=
|
github.com/BurntSushi/toml v1.5.0/go.mod h1:ukJfTF/6rtPPRCnwkur4qwRxa8vTRFBF0uk2lLoLwho=
|
||||||
github.com/axgle/mahonia v0.0.0-20180208002826-3358181d7394 h1:OYA+5W64v3OgClL+IrOD63t4i/RW7RqrAVl9LTZ9UqQ=
|
github.com/axgle/mahonia v0.0.0-20180208002826-3358181d7394 h1:OYA+5W64v3OgClL+IrOD63t4i/RW7RqrAVl9LTZ9UqQ=
|
||||||
github.com/axgle/mahonia v0.0.0-20180208002826-3358181d7394/go.mod h1:Q8n74mJTIgjX4RBBcHnJ05h//6/k6foqmgE45jTQtxg=
|
github.com/axgle/mahonia v0.0.0-20180208002826-3358181d7394/go.mod h1:Q8n74mJTIgjX4RBBcHnJ05h//6/k6foqmgE45jTQtxg=
|
||||||
github.com/bytedance/sonic v1.12.2 h1:oaMFuRTpMHYLpCntGca65YWt5ny+wAceDERTkT2L9lg=
|
github.com/bytedance/gopkg v0.1.3 h1:TPBSwH8RsouGCBcMBktLt1AymVo2TVsBVCY4b6TnZ/M=
|
||||||
github.com/bytedance/sonic v1.12.2/go.mod h1:B8Gt/XvtZ3Fqj+iSKMypzymZxw/FVwgIGKzMzT9r/rk=
|
github.com/bytedance/gopkg v0.1.3/go.mod h1:576VvJ+eJgyCzdjS+c4+77QF3p7ubbtiKARP3TxducM=
|
||||||
github.com/bytedance/sonic/loader v0.1.1/go.mod h1:ncP89zfokxS5LZrJxl5z0UJcsk4M4yY2JpfqGeCtNLU=
|
github.com/bytedance/sonic v1.14.1 h1:FBMC0zVz5XUmE4z9wF4Jey0An5FueFvOsTKKKtwIl7w=
|
||||||
github.com/bytedance/sonic/loader v0.2.0 h1:zNprn+lsIP06C/IqCHs3gPQIvnvpKbbxyXQP1iU4kWM=
|
github.com/bytedance/sonic v1.14.1/go.mod h1:gi6uhQLMbTdeP0muCnrjHLeCUPyb70ujhnNlhOylAFc=
|
||||||
github.com/bytedance/sonic/loader v0.2.0/go.mod h1:ncP89zfokxS5LZrJxl5z0UJcsk4M4yY2JpfqGeCtNLU=
|
github.com/bytedance/sonic/loader v0.3.0 h1:dskwH8edlzNMctoruo8FPTJDF3vLtDT0sXZwvZJyqeA=
|
||||||
github.com/cloudwego/base64x v0.1.4 h1:jwCgWpFanWmN8xoIUHa2rtzmkd5J2plF/dnLS6Xd/0Y=
|
github.com/bytedance/sonic/loader v0.3.0/go.mod h1:N8A3vUdtUebEY2/VQC0MyhYeKUFosQU6FxH2JmUe6VI=
|
||||||
github.com/cloudwego/base64x v0.1.4/go.mod h1:0zlkT4Wn5C6NdauXdJRhSKRlJvmclQ1hhJgA0rcu/8w=
|
github.com/cloudwego/base64x v0.1.6 h1:t11wG9AECkCDk5fMSoxmufanudBtJ+/HemLstXDLI2M=
|
||||||
github.com/cloudwego/iasm v0.2.0 h1:1KNIy1I1H9hNNFEEH3DVnI4UujN+1zjpuk6gwHLTssg=
|
github.com/cloudwego/base64x v0.1.6/go.mod h1:OFcloc187FXDaYHvrNIjxSe8ncn0OOM8gEHfghB2IPU=
|
||||||
github.com/cloudwego/iasm v0.2.0/go.mod h1:8rXZaNYT2n95jn+zTI1sDr+IgcD2GVs0nlbbQPiEFhY=
|
|
||||||
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||||
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
|
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
|
||||||
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
|
||||||
github.com/dgrijalva/jwt-go/v4 v4.0.0-preview1 h1:CaO/zOnF8VvUfEbhRatPcwKVWamvbYd8tQGRWacE9kU=
|
github.com/dgrijalva/jwt-go/v4 v4.0.0-preview1 h1:CaO/zOnF8VvUfEbhRatPcwKVWamvbYd8tQGRWacE9kU=
|
||||||
github.com/dgrijalva/jwt-go/v4 v4.0.0-preview1/go.mod h1:+hnT3ywWDTAFrW5aE+u2Sa/wT555ZqwoCS+pk3p6ry4=
|
github.com/dgrijalva/jwt-go/v4 v4.0.0-preview1/go.mod h1:+hnT3ywWDTAFrW5aE+u2Sa/wT555ZqwoCS+pk3p6ry4=
|
||||||
github.com/gabriel-vasile/mimetype v1.4.5 h1:J7wGKdGu33ocBOhGy0z653k/lFKLFDPJMG8Gql0kxn4=
|
github.com/gabriel-vasile/mimetype v1.4.10 h1:zyueNbySn/z8mJZHLt6IPw0KoZsiQNszIpU+bX4+ZK0=
|
||||||
github.com/gabriel-vasile/mimetype v1.4.5/go.mod h1:ibHel+/kbxn9x2407k1izTA1S81ku1z/DlgOW2QE0M4=
|
github.com/gabriel-vasile/mimetype v1.4.10/go.mod h1:d+9Oxyo1wTzWdyVUPMmXFvp4F9tea18J8ufA774AB3s=
|
||||||
github.com/gin-contrib/sse v0.1.0 h1:Y/yl/+YNO8GZSjAhjMsSuLt29uWRFHdHYUb5lYOV9qE=
|
github.com/gin-contrib/sse v1.1.0 h1:n0w2GMuUpWDVp7qSpvze6fAu9iRxJY4Hmj6AmBOU05w=
|
||||||
github.com/gin-contrib/sse v0.1.0/go.mod h1:RHrZQHXnP2xjPF+u1gW/2HnVO7nvIa9PG3Gm+fLHvGI=
|
github.com/gin-contrib/sse v1.1.0/go.mod h1:hxRZ5gVpWMT7Z0B0gSNYqqsSCNIJMjzvm6fqCz9vjwM=
|
||||||
github.com/gin-gonic/gin v1.10.0 h1:nTuyha1TYqgedzytsKYqna+DfLos46nTv2ygFy86HFU=
|
github.com/gin-gonic/gin v1.10.1 h1:T0ujvqyCSqRopADpgPgiTT63DUQVSfojyME59Ei63pQ=
|
||||||
github.com/gin-gonic/gin v1.10.0/go.mod h1:4PMNQiOhvDRa013RKVbsiNwoyezlm2rm0uX/T7kzp5Y=
|
github.com/gin-gonic/gin v1.10.1/go.mod h1:4PMNQiOhvDRa013RKVbsiNwoyezlm2rm0uX/T7kzp5Y=
|
||||||
github.com/go-ini/ini v1.67.0 h1:z6ZrTEZqSWOTyH2FlglNbNgARyHG8oLW9gMELqKr06A=
|
github.com/go-ini/ini v1.67.0 h1:z6ZrTEZqSWOTyH2FlglNbNgARyHG8oLW9gMELqKr06A=
|
||||||
github.com/go-ini/ini v1.67.0/go.mod h1:ByCAeIL28uOIIG0E3PJtZPDL8WnHpFKFOtgjp+3Ies8=
|
github.com/go-ini/ini v1.67.0/go.mod h1:ByCAeIL28uOIIG0E3PJtZPDL8WnHpFKFOtgjp+3Ies8=
|
||||||
github.com/go-playground/assert/v2 v2.2.0 h1:JvknZsQTYeFEAhQwI4qEt9cyV5ONwRHC+lYKSsYSR8s=
|
github.com/go-playground/assert/v2 v2.2.0 h1:JvknZsQTYeFEAhQwI4qEt9cyV5ONwRHC+lYKSsYSR8s=
|
||||||
@ -54,16 +51,19 @@ github.com/go-playground/locales v0.14.1 h1:EWaQ/wswjilfKLTECiXz7Rh+3BjFhfDFKv/o
|
|||||||
github.com/go-playground/locales v0.14.1/go.mod h1:hxrqLVvrK65+Rwrd5Fc6F2O76J/NuW9t0sjnWqG1slY=
|
github.com/go-playground/locales v0.14.1/go.mod h1:hxrqLVvrK65+Rwrd5Fc6F2O76J/NuW9t0sjnWqG1slY=
|
||||||
github.com/go-playground/universal-translator v0.18.1 h1:Bcnm0ZwsGyWbCzImXv+pAJnYK9S473LQFuzCbDbfSFY=
|
github.com/go-playground/universal-translator v0.18.1 h1:Bcnm0ZwsGyWbCzImXv+pAJnYK9S473LQFuzCbDbfSFY=
|
||||||
github.com/go-playground/universal-translator v0.18.1/go.mod h1:xekY+UJKNuX9WP91TpwSH2VMlDf28Uj24BCp08ZFTUY=
|
github.com/go-playground/universal-translator v0.18.1/go.mod h1:xekY+UJKNuX9WP91TpwSH2VMlDf28Uj24BCp08ZFTUY=
|
||||||
github.com/go-playground/validator/v10 v10.22.0 h1:k6HsTZ0sTnROkhS//R0O+55JgM8C4Bx7ia+JlgcnOao=
|
github.com/go-playground/validator/v10 v10.27.0 h1:w8+XrWVMhGkxOaaowyKH35gFydVHOvC0/uWoy2Fzwn4=
|
||||||
github.com/go-playground/validator/v10 v10.22.0/go.mod h1:dbuPbCMFw/DrkbEynArYaCwl3amGuJotoKCe95atGMM=
|
github.com/go-playground/validator/v10 v10.27.0/go.mod h1:I5QpIEbmr8On7W0TktmJAumgzX4CA1XNl4ZmDuVHKKo=
|
||||||
github.com/go-sql-driver/mysql v1.7.0/go.mod h1:OXbVy3sEdcQ2Doequ6Z5BW6fXNQTmx+9S1MCJN5yJMI=
|
github.com/go-sql-driver/mysql v1.9.3 h1:U/N249h2WzJ3Ukj8SowVFjdtZKfu9vlLZxjPXV1aweo=
|
||||||
github.com/go-sql-driver/mysql v1.8.1 h1:LedoTUt/eveggdHS9qUFC1EFSa8bU2+1pZjSRpvNJ1Y=
|
github.com/go-sql-driver/mysql v1.9.3/go.mod h1:qn46aNg1333BRMNU69Lq93t8du/dwxI64Gl8i5p1WMU=
|
||||||
github.com/go-sql-driver/mysql v1.8.1/go.mod h1:wEBSXgmK//2ZFJyE+qWnIsVGmvmEKlqwuVSjsCm7DZg=
|
github.com/goccy/go-json v0.10.5 h1:Fq85nIqj+gXn/S5ahsiTlK3TmC85qgirsdTP/+DeaC4=
|
||||||
github.com/goccy/go-json v0.10.3 h1:KZ5WoDbxAIgm2HNbYckL0se1fHD6rz5j4ywS6ebzDqA=
|
github.com/goccy/go-json v0.10.5/go.mod h1:oq7eo15ShAhp70Anwd5lgX2pLfOS3QCiwU/PULtXL6M=
|
||||||
github.com/goccy/go-json v0.10.3/go.mod h1:oq7eo15ShAhp70Anwd5lgX2pLfOS3QCiwU/PULtXL6M=
|
github.com/google/go-cmp v0.7.0 h1:wk8382ETsv4JYUZwIsn6YpYiWiBsYLSJiTsyBybVuN8=
|
||||||
github.com/google/go-cmp v0.5.6 h1:BKbKCqvP6I+rmFHt06ZmyQtvB8xAkWdhFyr0ZUNZcxQ=
|
github.com/google/go-cmp v0.7.0/go.mod h1:pXiqmnSA92OHEEa9HXL2W4E7lf9JzCmGVUdgjX3N/iU=
|
||||||
github.com/google/go-cmp v0.5.6/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
|
|
||||||
github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
|
github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
|
||||||
|
github.com/google/gofuzz v1.2.0 h1:xRy4A+RhZaiKjJ1bPfwQ8sedCA+YS2YcCHW6ec7JMi0=
|
||||||
|
github.com/google/gofuzz v1.2.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
|
||||||
|
github.com/gopherjs/gopherjs v1.17.2 h1:fQnZVsXk8uxXIStYb0N4bGk7jeyTalG/wsZjQ25dO0g=
|
||||||
|
github.com/gopherjs/gopherjs v1.17.2/go.mod h1:pRRIvn/QzFLrKfvEz3qUuEhtE/zLCWfreZ6J5gM2i+k=
|
||||||
github.com/gorilla/websocket v1.5.3 h1:saDtZ6Pbx/0u+bgYQ3q96pZgCzfhKXGPqt7kZ72aNNg=
|
github.com/gorilla/websocket v1.5.3 h1:saDtZ6Pbx/0u+bgYQ3q96pZgCzfhKXGPqt7kZ72aNNg=
|
||||||
github.com/gorilla/websocket v1.5.3/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE=
|
github.com/gorilla/websocket v1.5.3/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE=
|
||||||
github.com/jinzhu/inflection v1.0.0 h1:K317FqzuhWc8YvSVlFMCCUb36O/S9MCKRDI7QkRKD/E=
|
github.com/jinzhu/inflection v1.0.0 h1:K317FqzuhWc8YvSVlFMCCUb36O/S9MCKRDI7QkRKD/E=
|
||||||
@ -74,64 +74,72 @@ github.com/jonboulle/clockwork v0.3.0 h1:9BSCMi8C+0qdApAp4auwX0RkLGUjs956h0EkuQy
|
|||||||
github.com/jonboulle/clockwork v0.3.0/go.mod h1:Pkfl5aHPm1nk2H9h0bjmnJD/BcgbGXUBGnn1kMkgxc8=
|
github.com/jonboulle/clockwork v0.3.0/go.mod h1:Pkfl5aHPm1nk2H9h0bjmnJD/BcgbGXUBGnn1kMkgxc8=
|
||||||
github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM=
|
github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM=
|
||||||
github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo=
|
github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo=
|
||||||
github.com/klauspost/cpuid/v2 v2.0.9/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa0213Md/qVLRg=
|
github.com/jtolds/gls v4.20.0+incompatible h1:xdiiI2gbIgH/gLH7ADydsJ1uDOEzR8yvV7C0MuV77Wo=
|
||||||
github.com/klauspost/cpuid/v2 v2.2.8 h1:+StwCXwm9PdpiEkPyzBXIy+M9KUb4ODm0Zarf1kS5BM=
|
github.com/jtolds/gls v4.20.0+incompatible/go.mod h1:QJZ7F/aHp+rZTRtaJ1ow/lLfFfVYBRgL+9YlvaHOwJU=
|
||||||
github.com/klauspost/cpuid/v2 v2.2.8/go.mod h1:Lcz8mBdAVJIBVzewtcLocK12l3Y+JytZYpaMropDUws=
|
github.com/klauspost/cpuid/v2 v2.3.0 h1:S4CRMLnYUhGeDFDqkGriYKdfoFlDnMtqTiI/sFzhA9Y=
|
||||||
github.com/knz/go-libedit v1.10.1/go.mod h1:MZTVkCWyz0oBc7JOWP3wNAzd002ZbM/5hgShxwh4x8M=
|
github.com/klauspost/cpuid/v2 v2.3.0/go.mod h1:hqwkgyIinND0mEev00jJYCxPNVRVXFQeu1XKlok6oO0=
|
||||||
|
github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY=
|
||||||
|
github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE=
|
||||||
github.com/leodido/go-urn v1.4.0 h1:WT9HwE9SGECu3lg4d/dIA+jxlljEa1/ffXKmRjqdmIQ=
|
github.com/leodido/go-urn v1.4.0 h1:WT9HwE9SGECu3lg4d/dIA+jxlljEa1/ffXKmRjqdmIQ=
|
||||||
github.com/leodido/go-urn v1.4.0/go.mod h1:bvxc+MVxLKB4z00jd1z+Dvzr47oO32F/QSNjSBOlFxI=
|
github.com/leodido/go-urn v1.4.0/go.mod h1:bvxc+MVxLKB4z00jd1z+Dvzr47oO32F/QSNjSBOlFxI=
|
||||||
github.com/lestrrat-go/envload v0.0.0-20180220234015-a3eb8ddeffcc h1:RKf14vYWi2ttpEmkA4aQ3j4u9dStX2t4M8UM6qqNsG8=
|
github.com/lestrrat-go/envload v0.0.0-20180220234015-a3eb8ddeffcc h1:RKf14vYWi2ttpEmkA4aQ3j4u9dStX2t4M8UM6qqNsG8=
|
||||||
github.com/lestrrat-go/envload v0.0.0-20180220234015-a3eb8ddeffcc/go.mod h1:kopuH9ugFRkIXf3YoqHKyrJ9YfUFsckUU9S7B+XP+is=
|
github.com/lestrrat-go/envload v0.0.0-20180220234015-a3eb8ddeffcc/go.mod h1:kopuH9ugFRkIXf3YoqHKyrJ9YfUFsckUU9S7B+XP+is=
|
||||||
github.com/lestrrat-go/file-rotatelogs v2.4.0+incompatible h1:Y6sqxHMyB1D2YSzWkLibYKgg+SwmyFU9dF2hn6MdTj4=
|
github.com/lestrrat-go/file-rotatelogs v2.4.0+incompatible h1:Y6sqxHMyB1D2YSzWkLibYKgg+SwmyFU9dF2hn6MdTj4=
|
||||||
github.com/lestrrat-go/file-rotatelogs v2.4.0+incompatible/go.mod h1:ZQnN8lSECaebrkQytbHj4xNgtg8CR7RYXnPok8e0EHA=
|
github.com/lestrrat-go/file-rotatelogs v2.4.0+incompatible/go.mod h1:ZQnN8lSECaebrkQytbHj4xNgtg8CR7RYXnPok8e0EHA=
|
||||||
github.com/lestrrat-go/strftime v1.1.0 h1:gMESpZy44/4pXLO/m+sL0yBd1W6LjgjrrD4a68Gapyg=
|
github.com/lestrrat-go/strftime v1.1.1 h1:zgf8QCsgj27GlKBy3SU9/8MMgegZ8UCzlCyHYrUF0QU=
|
||||||
github.com/lestrrat-go/strftime v1.1.0/go.mod h1:uzeIB52CeUJenCo1syghlugshMysrqUT51HlxphXVeI=
|
github.com/lestrrat-go/strftime v1.1.1/go.mod h1:YDrzHJAODYQ+xxvrn5SG01uFIQAeDTzpxNVppCz7Nmw=
|
||||||
github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWEY=
|
github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWEY=
|
||||||
github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y=
|
github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y=
|
||||||
github.com/mattn/go-sqlite3 v1.14.23 h1:gbShiuAP1W5j9UOksQ06aiiqPMxYecovVGwmTxWtuw0=
|
github.com/mattn/go-sqlite3 v1.14.32 h1:JD12Ag3oLy1zQA+BNn74xRgaBbdhbNIDYvQUEuuErjs=
|
||||||
github.com/mattn/go-sqlite3 v1.14.23/go.mod h1:Uh1q+B4BYcTPb+yiD3kU8Ct7aC0hY9fxUwlHK0RXw+Y=
|
github.com/mattn/go-sqlite3 v1.14.32/go.mod h1:Uh1q+B4BYcTPb+yiD3kU8Ct7aC0hY9fxUwlHK0RXw+Y=
|
||||||
github.com/mitchellh/go-homedir v1.1.0 h1:lukF9ziXFxDFPkA1vsr5zpc1XuPDn/wFntq5mG+4E0Y=
|
github.com/mitchellh/go-homedir v1.1.0 h1:lukF9ziXFxDFPkA1vsr5zpc1XuPDn/wFntq5mG+4E0Y=
|
||||||
github.com/mitchellh/go-homedir v1.1.0/go.mod h1:SfyaCUpYCn1Vlf4IUYiD9fPX4A5wJrkLzIz1N1q0pr0=
|
github.com/mitchellh/go-homedir v1.1.0/go.mod h1:SfyaCUpYCn1Vlf4IUYiD9fPX4A5wJrkLzIz1N1q0pr0=
|
||||||
github.com/mitchellh/mapstructure v1.5.0 h1:jeMsZIYE/09sWLaz43PL7Gy6RuMjD2eJVyuac5Z2hdY=
|
|
||||||
github.com/mitchellh/mapstructure v1.5.0/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo=
|
|
||||||
github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q=
|
github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q=
|
||||||
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg=
|
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg=
|
||||||
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q=
|
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q=
|
||||||
github.com/modern-go/reflect2 v1.0.2 h1:xBagoLtFs94CBntxluKeaWgTMpvLxC4ur3nMaC9Gz0M=
|
github.com/modern-go/reflect2 v1.0.2 h1:xBagoLtFs94CBntxluKeaWgTMpvLxC4ur3nMaC9Gz0M=
|
||||||
github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk=
|
github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk=
|
||||||
github.com/mozillazg/go-pinyin v0.20.0 h1:BtR3DsxpApHfKReaPO1fCqF4pThRwH9uwvXzm+GnMFQ=
|
github.com/mozillazg/go-pinyin v0.21.0 h1:Wo8/NT45z7P3er/9YSLHA3/kjZzbLz5hR7i+jGeIGao=
|
||||||
github.com/mozillazg/go-pinyin v0.20.0/go.mod h1:iR4EnMMRXkfpFVV5FMi4FNB6wGq9NV6uDWbUuPhP4Yc=
|
github.com/mozillazg/go-pinyin v0.21.0/go.mod h1:iR4EnMMRXkfpFVV5FMi4FNB6wGq9NV6uDWbUuPhP4Yc=
|
||||||
github.com/mssola/user_agent v0.6.0 h1:uwPR4rtWlCHRFyyP9u2KOV0u8iQXmS7Z7feTrstQwk4=
|
github.com/mssola/user_agent v0.6.0 h1:uwPR4rtWlCHRFyyP9u2KOV0u8iQXmS7Z7feTrstQwk4=
|
||||||
github.com/mssola/user_agent v0.6.0/go.mod h1:TTPno8LPY3wAIEKRpAtkdMT0f8SE24pLRGPahjCH4uw=
|
github.com/mssola/user_agent v0.6.0/go.mod h1:TTPno8LPY3wAIEKRpAtkdMT0f8SE24pLRGPahjCH4uw=
|
||||||
github.com/pelletier/go-toml/v2 v2.2.3 h1:YmeHyLY8mFWbdkNWwpr+qIL2bEqT0o95WSdkNHvL12M=
|
github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e h1:fD57ERR4JtEqsWbfPhv4DMiApHyliiK5xCTNVSPiaAs=
|
||||||
github.com/pelletier/go-toml/v2 v2.2.3/go.mod h1:MfCQTFTvCcUyyvvwm1+G6H/jORL20Xlb6rzQu9GuUkc=
|
github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e/go.mod h1:zD1mROLANZcx1PVRCS0qkT7pwLkGfwJo4zjcN/Tysno=
|
||||||
|
github.com/pelletier/go-toml/v2 v2.2.4 h1:mye9XuhQ6gvn5h28+VilKrrPoQVanw5PMw/TB0t5Ec4=
|
||||||
|
github.com/pelletier/go-toml/v2 v2.2.4/go.mod h1:2gIqNv+qfxSVS7cM2xJQKtLSTLUE9V8t9Stt+h56mCY=
|
||||||
github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4=
|
github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4=
|
||||||
github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
||||||
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
||||||
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
||||||
|
github.com/sbabiv/xml2map v1.2.1 h1:1lT7t0hhUvXZCkdxqtq4n8/ZCnwLWGq4rDuDv5XOoFE=
|
||||||
|
github.com/sbabiv/xml2map v1.2.1/go.mod h1:2TPoAfcaM7+Sd4iriPvzyntb2mx7GY+kkQpB/GQa/eo=
|
||||||
|
github.com/smarty/assertions v1.15.0 h1:cR//PqUBUiQRakZWqBiFFQ9wb8emQGDb0HeGdqGByCY=
|
||||||
|
github.com/smarty/assertions v1.15.0/go.mod h1:yABtdzeQs6l1brC900WlRNwj6ZR55d7B+E8C6HtKdec=
|
||||||
|
github.com/smartystreets/goconvey v1.8.1 h1:qGjIddxOk4grTu9JPOU31tVfq3cNdBlNa5sSznIX1xY=
|
||||||
|
github.com/smartystreets/goconvey v1.8.1/go.mod h1:+/u4qLyY6x1jReYOp7GOM2FSt8aP9CzCZL03bI28W60=
|
||||||
github.com/spaolacci/murmur3 v1.1.0 h1:7c1g84S4BPRrfL5Xrdp6fOJ206sU9y293DDHaoy0bLI=
|
github.com/spaolacci/murmur3 v1.1.0 h1:7c1g84S4BPRrfL5Xrdp6fOJ206sU9y293DDHaoy0bLI=
|
||||||
github.com/spaolacci/murmur3 v1.1.0/go.mod h1:JwIasOWyU6f++ZhiEuf87xNszmSA2myDM2Kzu9HwQUA=
|
github.com/spaolacci/murmur3 v1.1.0/go.mod h1:JwIasOWyU6f++ZhiEuf87xNszmSA2myDM2Kzu9HwQUA=
|
||||||
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
||||||
github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw=
|
github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw=
|
||||||
github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo=
|
github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo=
|
||||||
github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
|
github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
|
||||||
github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
|
||||||
github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
|
||||||
github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU=
|
github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU=
|
||||||
github.com/stretchr/testify v1.8.1/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4=
|
github.com/stretchr/testify v1.8.1/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4=
|
||||||
github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg=
|
github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA=
|
||||||
github.com/stretchr/testify v1.9.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
|
github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
|
||||||
github.com/tidwall/gjson v1.17.3 h1:bwWLZU7icoKRG+C+0PNwIKC6FCJO/Q3p2pZvuP0jN94=
|
github.com/tidwall/gjson v1.18.0 h1:FIDeeyB800efLX89e5a8Y0BNH+LOngJyGrIWxG2FKQY=
|
||||||
github.com/tidwall/gjson v1.17.3/go.mod h1:/wbyibRr2FHMks5tjHJ5F8dMZh3AcwJEMf5vlfC0lxk=
|
github.com/tidwall/gjson v1.18.0/go.mod h1:/wbyibRr2FHMks5tjHJ5F8dMZh3AcwJEMf5vlfC0lxk=
|
||||||
github.com/tidwall/match v1.1.1 h1:+Ho715JplO36QYgwN9PGYNhgZvoUSc9X2c80KVTi+GA=
|
|
||||||
github.com/tidwall/match v1.1.1/go.mod h1:eRSPERbgtNPcGhD8UCthc6PmLEQXEWd3PRB5JTxsfmM=
|
github.com/tidwall/match v1.1.1/go.mod h1:eRSPERbgtNPcGhD8UCthc6PmLEQXEWd3PRB5JTxsfmM=
|
||||||
|
github.com/tidwall/match v1.2.0 h1:0pt8FlkOwjN2fPt4bIl4BoNxb98gGHN2ObFEDkrfZnM=
|
||||||
|
github.com/tidwall/match v1.2.0/go.mod h1:eRSPERbgtNPcGhD8UCthc6PmLEQXEWd3PRB5JTxsfmM=
|
||||||
github.com/tidwall/pretty v1.2.0/go.mod h1:ITEVvHYasfjBbM0u2Pg8T2nJnzm8xPwvNhhsoaGGjNU=
|
github.com/tidwall/pretty v1.2.0/go.mod h1:ITEVvHYasfjBbM0u2Pg8T2nJnzm8xPwvNhhsoaGGjNU=
|
||||||
github.com/tidwall/pretty v1.2.1 h1:qjsOFOWWQl+N3RsoF5/ssm1pHmJJwhjlSbZ51I6wMl4=
|
github.com/tidwall/pretty v1.2.1 h1:qjsOFOWWQl+N3RsoF5/ssm1pHmJJwhjlSbZ51I6wMl4=
|
||||||
github.com/tidwall/pretty v1.2.1/go.mod h1:ITEVvHYasfjBbM0u2Pg8T2nJnzm8xPwvNhhsoaGGjNU=
|
github.com/tidwall/pretty v1.2.1/go.mod h1:ITEVvHYasfjBbM0u2Pg8T2nJnzm8xPwvNhhsoaGGjNU=
|
||||||
github.com/twitchyliquid64/golang-asm v0.15.1 h1:SU5vSMR7hnwNxj24w34ZyCi/FmDZTkS4MhqMhdFk5YI=
|
github.com/twitchyliquid64/golang-asm v0.15.1 h1:SU5vSMR7hnwNxj24w34ZyCi/FmDZTkS4MhqMhdFk5YI=
|
||||||
github.com/twitchyliquid64/golang-asm v0.15.1/go.mod h1:a1lVb/DtPvCB8fslRZhAngC2+aY1QWCk3Cedj/Gdt08=
|
github.com/twitchyliquid64/golang-asm v0.15.1/go.mod h1:a1lVb/DtPvCB8fslRZhAngC2+aY1QWCk3Cedj/Gdt08=
|
||||||
github.com/ugorji/go/codec v1.2.12 h1:9LC83zGrHhuUA9l16C9AHXAqEV/2wBQ4nkvumAE65EE=
|
github.com/ugorji/go/codec v1.3.0 h1:Qd2W2sQawAfG8XSvzwhBeoGq71zXOC/Q1E9y/wUcsUA=
|
||||||
github.com/ugorji/go/codec v1.2.12/go.mod h1:UNopzCgEMSXjBc6AOMqYvWC1ktqTAfzJZUZgYf6w6lg=
|
github.com/ugorji/go/codec v1.3.0/go.mod h1:pRBVtBSKl77K30Bv8R2P+cLSGaTtex6fsA2Wjqmfxj4=
|
||||||
github.com/xwb1989/sqlparser v0.0.0-20180606152119-120387863bf2 h1:zzrxE1FKn5ryBNl9eKOeqQ58Y/Qpo3Q9QNxKHX5uzzQ=
|
github.com/xwb1989/sqlparser v0.0.0-20180606152119-120387863bf2 h1:zzrxE1FKn5ryBNl9eKOeqQ58Y/Qpo3Q9QNxKHX5uzzQ=
|
||||||
github.com/xwb1989/sqlparser v0.0.0-20180606152119-120387863bf2/go.mod h1:hzfGeIUDq/j97IG+FhNqkowIyEcD88LrW6fyU3K3WqY=
|
github.com/xwb1989/sqlparser v0.0.0-20180606152119-120387863bf2/go.mod h1:hzfGeIUDq/j97IG+FhNqkowIyEcD88LrW6fyU3K3WqY=
|
||||||
go.uber.org/goleak v1.3.0 h1:2K3zAYmnTNqV73imy9J1T3WC+gmCePx2hEGkimedGto=
|
go.uber.org/goleak v1.3.0 h1:2K3zAYmnTNqV73imy9J1T3WC+gmCePx2hEGkimedGto=
|
||||||
@ -140,35 +148,33 @@ go.uber.org/multierr v1.11.0 h1:blXXJkSxSSfBVBlC76pxqeO+LN3aDfLQo+309xJstO0=
|
|||||||
go.uber.org/multierr v1.11.0/go.mod h1:20+QtiLqy0Nd6FdQB9TLXag12DsQkrbs3htMFfDN80Y=
|
go.uber.org/multierr v1.11.0/go.mod h1:20+QtiLqy0Nd6FdQB9TLXag12DsQkrbs3htMFfDN80Y=
|
||||||
go.uber.org/zap v1.27.0 h1:aJMhYGrd5QSmlpLMr2MftRKl7t8J8PTZPA732ud/XR8=
|
go.uber.org/zap v1.27.0 h1:aJMhYGrd5QSmlpLMr2MftRKl7t8J8PTZPA732ud/XR8=
|
||||||
go.uber.org/zap v1.27.0/go.mod h1:GB2qFLM7cTU87MWRP2mPIjqfIDnGu+VIO4V/SdhGo2E=
|
go.uber.org/zap v1.27.0/go.mod h1:GB2qFLM7cTU87MWRP2mPIjqfIDnGu+VIO4V/SdhGo2E=
|
||||||
golang.org/x/arch v0.10.0 h1:S3huipmSclq3PJMNe76NGwkBR504WFkQ5dhzWzP8ZW8=
|
golang.org/x/arch v0.21.0 h1:iTC9o7+wP6cPWpDWkivCvQFGAHDQ59SrSxsLPcnkArw=
|
||||||
golang.org/x/arch v0.10.0/go.mod h1:FEVrYAQjsQXMVJ1nsMoVVXPZg6p2JE2mx8psSWTDQys=
|
golang.org/x/arch v0.21.0/go.mod h1:dNHoOeKiyja7GTvF9NJS1l3Z2yntpQNzgrjh1cU103A=
|
||||||
golang.org/x/crypto v0.26.0 h1:RrRspgV4mU+YwB4FYnuBoKsUapNIL5cohGAmSH3azsw=
|
golang.org/x/crypto v0.42.0 h1:chiH31gIWm57EkTXpwnqf8qeuMUi0yekh6mT2AvFlqI=
|
||||||
golang.org/x/crypto v0.26.0/go.mod h1:GY7jblb9wI+FOo5y8/S2oY4zWP07AkOJ4+jxCqdqn54=
|
golang.org/x/crypto v0.42.0/go.mod h1:4+rDnOTJhQCx2q7/j6rAN5XDw8kPjeaXEUR2eL94ix8=
|
||||||
golang.org/x/net v0.28.0 h1:a9JDOJc5GMUJ0+UDqmLT86WiEy7iWyIhz8gz8E4e5hE=
|
golang.org/x/net v0.44.0 h1:evd8IRDyfNBMBTTY5XRF1vaZlD+EmWx6x8PkhR04H/I=
|
||||||
golang.org/x/net v0.28.0/go.mod h1:yqtgsTWOOnlGLG9GFRrK3++bGOUEkNBoHZc8MEDWPNg=
|
golang.org/x/net v0.44.0/go.mod h1:ECOoLqd5U3Lhyeyo/QDCEVQ4sNgYsqvCZ722XogGieY=
|
||||||
golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
|
||||||
golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
golang.org/x/sys v0.25.0 h1:r+8e+loiHxRqhXVl6ML1nO3l1+oFoWbnlu2Ehimmi34=
|
golang.org/x/sys v0.36.0 h1:KVRy2GtZBrk1cBYA7MKu5bEZFxQk4NIDV6RLVcC8o0k=
|
||||||
golang.org/x/sys v0.25.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
|
golang.org/x/sys v0.36.0/go.mod h1:OgkHotnGiDImocRcuBABYBEXf8A9a87e/uXjp9XT3ks=
|
||||||
golang.org/x/text v0.18.0 h1:XvMDiNzPAl0jr17s6W9lcaIhGUfUORdGCNsuLmPG224=
|
golang.org/x/text v0.29.0 h1:1neNs90w9YzJ9BocxfsQNHKuAT4pkghyXc4nhZ6sJvk=
|
||||||
golang.org/x/text v0.18.0/go.mod h1:BuEKDfySbSR4drPmRPG/7iBdf8hvFMuRexcpahXilzY=
|
golang.org/x/text v0.29.0/go.mod h1:7MhJOA9CD2qZyOKYazxdYMF85OwPdEr9jTtBpO7ydH4=
|
||||||
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
golang.org/x/xerrors v0.0.0-20231012003039-104605ab7028 h1:+cNy6SZtPcJQH3LJVLOSmiC7MMxXNOb3PU/VUEz+EhU=
|
golang.org/x/xerrors v0.0.0-20231012003039-104605ab7028 h1:+cNy6SZtPcJQH3LJVLOSmiC7MMxXNOb3PU/VUEz+EhU=
|
||||||
golang.org/x/xerrors v0.0.0-20231012003039-104605ab7028/go.mod h1:NDW/Ps6MPRej6fsCIbMTohpP40sJ/P/vI1MoTEGwX90=
|
golang.org/x/xerrors v0.0.0-20231012003039-104605ab7028/go.mod h1:NDW/Ps6MPRej6fsCIbMTohpP40sJ/P/vI1MoTEGwX90=
|
||||||
google.golang.org/protobuf v1.34.2 h1:6xV6lTsCfpGD21XK49h7MhtcApnLqkfYgPcdHftf6hg=
|
google.golang.org/protobuf v1.36.9 h1:w2gp2mA27hUeUzj9Ex9FBjsBm40zfaDtEWow293U7Iw=
|
||||||
google.golang.org/protobuf v1.34.2/go.mod h1:qYOHts0dSfpeUzUFpOMr/WGzszTmLH+DiWniOlNbLDw=
|
google.golang.org/protobuf v1.36.9/go.mod h1:fuxRtAxBytpl4zzqUh6/eyUujkJdNiuEkXntxiD/uRU=
|
||||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405 h1:yhCVgyC4o1eVCa2tZl7eS0r+SDo693bJlVdllGtEeKM=
|
|
||||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||||
|
gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f h1:BLraFXnmrev5lT+xlilqcH8XK9/i0At2xKjWk4p6zsU=
|
||||||
|
gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||||
gopkg.in/olahol/melody.v1 v1.0.0-20170518105555-d52139073376 h1:sY2a+y0j4iDrajJcorb+a0hJIQ6uakU5gybjfLWHlXo=
|
gopkg.in/olahol/melody.v1 v1.0.0-20170518105555-d52139073376 h1:sY2a+y0j4iDrajJcorb+a0hJIQ6uakU5gybjfLWHlXo=
|
||||||
gopkg.in/olahol/melody.v1 v1.0.0-20170518105555-d52139073376/go.mod h1:BHKOc1m5wm8WwQkMqYBoo4vNxhmF7xg8+xhG8L+Cy3M=
|
gopkg.in/olahol/melody.v1 v1.0.0-20170518105555-d52139073376/go.mod h1:BHKOc1m5wm8WwQkMqYBoo4vNxhmF7xg8+xhG8L+Cy3M=
|
||||||
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||||
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
|
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
|
||||||
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
|
||||||
gorm.io/driver/mysql v1.5.7 h1:MndhOPYOfEp2rHKgkZIhJ16eVUIRf2HmzgoPmh7FCWo=
|
gorm.io/driver/mysql v1.6.0 h1:eNbLmNTpPpTOVZi8MMxCi2aaIm0ZpInbORNXDwyLGvg=
|
||||||
gorm.io/driver/mysql v1.5.7/go.mod h1:sEtPWMiqiN1N1cMXoXmBbd8C6/l+TESwriotuRRpkDM=
|
gorm.io/driver/mysql v1.6.0/go.mod h1:D/oCC2GWK3M/dqoLxnOlaNKmXz8WNTfcS9y5ovaSqKo=
|
||||||
gorm.io/driver/sqlite v1.5.6 h1:fO/X46qn5NUEEOZtnjJRWRzZMe8nqJiQ9E+0hi+hKQE=
|
gorm.io/driver/sqlite v1.6.0 h1:WHRRrIiulaPiPFmDcod6prc4l2VGVWHz80KspNsxSfQ=
|
||||||
gorm.io/driver/sqlite v1.5.6/go.mod h1:U+J8craQU6Fzkcvu8oLeAQmi50TkwPEhHDEjQZXDah4=
|
gorm.io/driver/sqlite v1.6.0/go.mod h1:AO9V1qIQddBESngQUKWL9yoH93HIeA1X6V633rBwyT8=
|
||||||
gorm.io/gorm v1.25.7/go.mod h1:hbnx/Oo0ChWMn1BIhpy1oYozzpM15i4YPuHDmfYtwg8=
|
gorm.io/gorm v1.31.0 h1:0VlycGreVhK7RF/Bwt51Fk8v0xLiiiFdbGDPIZQ7mJY=
|
||||||
gorm.io/gorm v1.25.11 h1:/Wfyg1B/je1hnDx3sMkX+gAlxrlZpn6X0BXRlwXlvHg=
|
gorm.io/gorm v1.31.0/go.mod h1:XyQVbO2k6YkOis7C2437jSit3SsDK72s7n7rsSHd+Gs=
|
||||||
gorm.io/gorm v1.25.11/go.mod h1:xh7N7RHfYlNc5EmcI/El95gXusucDrQnHXe0+CgWcLQ=
|
|
||||||
nullprogram.com/x/optparse v1.0.0/go.mod h1:KdyPE+Igbe0jQUrVfMqDMeJQIJZEuyV7pjYmp6pbG50=
|
|
||||||
|
32
option.go
32
option.go
@ -69,6 +69,13 @@ func WithLimit[T op_type.Int](limit T, offset T) define.SetOption {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func WithClearLimit() define.SetOption {
|
||||||
|
return func(o *define.Option) {
|
||||||
|
o.Limit = 0
|
||||||
|
o.Offset = 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// WithLimitByPageAndSize 通过page和size构建条件
|
// WithLimitByPageAndSize 通过page和size构建条件
|
||||||
//
|
//
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
// Author : go_developer@163.com<白茶清欢>
|
||||||
@ -341,6 +348,17 @@ func WithOR(orConditionList ...define.SetOption) define.SetOption {
|
|||||||
// Date : 20:15 2022/10/20
|
// Date : 20:15 2022/10/20
|
||||||
func WithOrder(orderRuleList ...string) define.SetOption {
|
func WithOrder(orderRuleList ...string) define.SetOption {
|
||||||
return func(o *define.Option) {
|
return func(o *define.Option) {
|
||||||
|
if len(orderRuleList) != 2 {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if len(orderRuleList[0]) == 0 {
|
||||||
|
// 未指定排序字段
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if len(orderRuleList[1]) == 0 {
|
||||||
|
// 未指定排序规则, 默认倒序
|
||||||
|
orderRuleList[1] = "DESC"
|
||||||
|
}
|
||||||
o.Order = orderRuleList
|
o.Order = orderRuleList
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -351,12 +369,7 @@ func WithOrder(orderRuleList ...string) define.SetOption {
|
|||||||
//
|
//
|
||||||
// Date : 15:09 2023/4/3
|
// Date : 15:09 2023/4/3
|
||||||
func WithOrderDesc(field string) define.SetOption {
|
func WithOrderDesc(field string) define.SetOption {
|
||||||
return func(o *define.Option) {
|
return WithOrder(field, "DESC")
|
||||||
if nil == o.Order {
|
|
||||||
o.Order = make([]string, 0)
|
|
||||||
}
|
|
||||||
o.Order = append(o.Order, field+" desc")
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// WithOrderAsc 升序排序
|
// WithOrderAsc 升序排序
|
||||||
@ -365,12 +378,7 @@ func WithOrderDesc(field string) define.SetOption {
|
|||||||
//
|
//
|
||||||
// Date : 15:09 2023/4/3
|
// Date : 15:09 2023/4/3
|
||||||
func WithOrderAsc(field string) define.SetOption {
|
func WithOrderAsc(field string) define.SetOption {
|
||||||
return func(o *define.Option) {
|
return WithOrder(field, "ASC")
|
||||||
if nil == o.Order {
|
|
||||||
o.Order = make([]string, 0)
|
|
||||||
}
|
|
||||||
o.Order = append(o.Order, field+" asc")
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// newOption 生成新的option
|
// newOption 生成新的option
|
||||||
|
@ -7,47 +7,50 @@
|
|||||||
// Date : 2021-10-25 4:50 下午
|
// Date : 2021-10-25 4:50 下午
|
||||||
package sql2go
|
package sql2go
|
||||||
|
|
||||||
|
import "git.zhangdeman.cn/zhangdeman/consts"
|
||||||
|
|
||||||
// sqlTypeMap mysql数据类型 => go 数据类型映射
|
// sqlTypeMap mysql数据类型 => go 数据类型映射
|
||||||
//
|
//
|
||||||
// Author : go_developer@163.com<白茶清欢>
|
// Author : go_developer@163.com<白茶清欢>
|
||||||
//
|
//
|
||||||
// Date : 4:50 下午 2021/10/25
|
// Date : 4:50 下午 2021/10/25
|
||||||
var sqlTypeMap = map[string]string{
|
var sqlTypeMap = map[string]string{
|
||||||
"int": "int",
|
"int": consts.DataTypeInt.String(),
|
||||||
"integer": "int",
|
"integer": consts.DataTypeInt.String(),
|
||||||
"tinyint": "int8",
|
"tinyint": consts.DataTypeInt8.String(),
|
||||||
"smallint": "int16",
|
"smallint": consts.DataTypeInt16.String(),
|
||||||
"mediumint": "int32",
|
"mediumint": consts.DataTypeInt32.String(),
|
||||||
"bigint": "int64",
|
"bigint": consts.DataTypeInt64.String(),
|
||||||
"int unsigned": "uint",
|
"int unsigned": consts.DataTypeUint.String(),
|
||||||
"integer unsigned": "uint",
|
"integer unsigned": consts.DataTypeUint.String(),
|
||||||
"tinyint unsigned": "uint8",
|
"tinyint unsigned": consts.DataTypeUint8.String(),
|
||||||
"smallint unsigned": "uint16",
|
"smallint unsigned": consts.DataTypeUint16.String(),
|
||||||
"mediumint unsigned": "uint32",
|
"mediumint unsigned": consts.DataTypeUint32.String(),
|
||||||
"bigint unsigned": "uint64",
|
"bigint unsigned": consts.DataTypeUint64.String(),
|
||||||
"bit": "byte",
|
"bit": "byte",
|
||||||
"bool": "bool",
|
"bool": consts.DataTypeBool.String(),
|
||||||
"enum": "string",
|
"enum": consts.DataTypeString.String(),
|
||||||
"set": "string",
|
"set": consts.DataTypeString.String(),
|
||||||
"varchar": "string",
|
"varchar": consts.DataTypeString.String(),
|
||||||
"char": "string",
|
"char": consts.DataTypeString.String(),
|
||||||
"tinytext": "string",
|
"tinytext": consts.DataTypeString.String(),
|
||||||
"mediumtext": "string",
|
"mediumtext": consts.DataTypeString.String(),
|
||||||
"text": "string",
|
"text": consts.DataTypeString.String(),
|
||||||
"longtext": "string",
|
"longtext": consts.DataTypeString.String(),
|
||||||
"blob": "string",
|
"blob": consts.DataTypeString.String(),
|
||||||
"tinyblob": "string",
|
"tinyblob": consts.DataTypeString.String(),
|
||||||
"mediumblob": "string",
|
"mediumblob": consts.DataTypeString.String(),
|
||||||
"longblob": "string",
|
"longblob": consts.DataTypeString.String(),
|
||||||
"date": "time.Time",
|
"date": "time.Time",
|
||||||
"datetime": "time.Time",
|
"datetime": "time.Time",
|
||||||
"timestamp": "time.Time",
|
"timestamp": "time.Time",
|
||||||
"time": "time.Time",
|
"time": "time.Time",
|
||||||
"float": "float64",
|
"float": consts.DataTypeFloat64.String(),
|
||||||
"double": "float64",
|
"double": consts.DataTypeFloat64.String(),
|
||||||
"decimal": "float64",
|
"decimal": consts.DataTypeFloat64.String(),
|
||||||
"binary": "string",
|
"binary": consts.DataTypeString.String(),
|
||||||
"varbinary": "string",
|
"varbinary": consts.DataTypeString.String(),
|
||||||
|
"json": consts.DataTypeString.String(),
|
||||||
}
|
}
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
@ -9,15 +9,16 @@ package sql2go
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
wrapperType "git.zhangdeman.cn/zhangdeman/wrapper"
|
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
wrapperType "git.zhangdeman.cn/zhangdeman/wrapper"
|
||||||
|
|
||||||
"github.com/xwb1989/sqlparser"
|
"github.com/xwb1989/sqlparser"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
// CreateSQLColumnTPL 每个字段的模版
|
// CreateSQLColumnTPL 每个字段的模版
|
||||||
CreateSQLColumnTPL = " {FIELD} {TYPE} `json:\"{JSON_TAG}\" gorm:\"column:{COLUMN};default:{DEFAULT_VALUE};{NOT_NULL}\"` // {COMMENT}"
|
CreateSQLColumnTPL = " {FIELD} {TYPE} `json:\"{JSON_TAG}\" gorm:\"column:{COLUMN};default:{DEFAULT_VALUE};{NOT_NULL}\" dc:\"{COMMENT}\"`"
|
||||||
// TableColumnTpl 每个字段的模版
|
// TableColumnTpl 每个字段的模版
|
||||||
TableColumnTpl = " {FIELD} string `json:\"{JSON_TAG}\"`"
|
TableColumnTpl = " {FIELD} string `json:\"{JSON_TAG}\"`"
|
||||||
// TableColumnDescTpl 字段描述
|
// TableColumnDescTpl 字段描述
|
||||||
@ -93,11 +94,14 @@ func generateTable(tableName string, modelStructName string, columnList []*sqlpa
|
|||||||
|
|
||||||
for _, item := range columnList {
|
for _, item := range columnList {
|
||||||
comment := ""
|
comment := ""
|
||||||
if item.Type.Comment == nil {
|
if item.Type.Comment == nil || item.Type.Comment.Val == nil {
|
||||||
comment = item.Name.String()
|
comment = item.Name.String()
|
||||||
} else {
|
} else {
|
||||||
comment = string(item.Type.Comment.Val)
|
comment = string(item.Type.Comment.Val)
|
||||||
}
|
}
|
||||||
|
if comment == "" {
|
||||||
|
comment = item.Name.String()
|
||||||
|
}
|
||||||
data := map[string]string{
|
data := map[string]string{
|
||||||
"{FIELD}": wrapperType.String(item.Name.String()).SnakeCaseToCamel(),
|
"{FIELD}": wrapperType.String(item.Name.String()).SnakeCaseToCamel(),
|
||||||
"{COLUMN}": item.Name.String(),
|
"{COLUMN}": item.Name.String(),
|
||||||
@ -106,6 +110,10 @@ func generateTable(tableName string, modelStructName string, columnList []*sqlpa
|
|||||||
"{COMMENT}": comment,
|
"{COMMENT}": comment,
|
||||||
"{TYPE}": sqlTypeMap[item.Type.Type],
|
"{TYPE}": sqlTypeMap[item.Type.Type],
|
||||||
}
|
}
|
||||||
|
if item.Type.Unsigned {
|
||||||
|
// 无符号
|
||||||
|
data["{TYPE}"] = sqlTypeMap[item.Type.Type+" unsigned"]
|
||||||
|
}
|
||||||
/*if data["{FIELD}"] == "ID" {
|
/*if data["{FIELD}"] == "ID" {
|
||||||
basic.PrimaryFieldType = data["{TYPE}"]
|
basic.PrimaryFieldType = data["{TYPE}"]
|
||||||
}*/
|
}*/
|
||||||
@ -150,17 +158,20 @@ return "{{TABLE_NAME}}"
|
|||||||
func generateTableColumnDefined(modelStructName string, columnList []*sqlparser.ColumnDefinition) (string, string, string) {
|
func generateTableColumnDefined(modelStructName string, columnList []*sqlparser.ColumnDefinition) (string, string, string) {
|
||||||
columnDefineName := modelStructName + "Column"
|
columnDefineName := modelStructName + "Column"
|
||||||
structFieldResult := "type " + columnDefineName + " struct { \n"
|
structFieldResult := "type " + columnDefineName + " struct { \n"
|
||||||
structFieldDescInstanceResult := "&" + columnDefineName + "{ \n"
|
structFieldDescInstanceResult := columnDefineName + "{ \n"
|
||||||
structFieldCommentInstanceResult := "map[string]string{ \n"
|
structFieldCommentInstanceResult := "map[string]string{ \n"
|
||||||
for _, column := range columnList {
|
for _, column := range columnList {
|
||||||
|
comment := column.Name.String()
|
||||||
|
if nil != column.Type.Comment {
|
||||||
|
comment = string(column.Type.Comment.Val)
|
||||||
|
}
|
||||||
|
if comment == "" {
|
||||||
|
comment = column.Name.String()
|
||||||
|
}
|
||||||
dataMap := map[string]string{
|
dataMap := map[string]string{
|
||||||
"{FIELD}": wrapperType.String(column.Name.String()).SnakeCaseToCamel(),
|
"{FIELD}": wrapperType.String(column.Name.String()).SnakeCaseToCamel(),
|
||||||
"{JSON_TAG}": column.Name.String(),
|
"{JSON_TAG}": column.Name.String(),
|
||||||
"{FIELD_COMMENT}": wrapperType.TernaryOperator.String(
|
"{FIELD_COMMENT}": comment,
|
||||||
column.Type.Comment == nil,
|
|
||||||
wrapperType.String(column.Name.String()),
|
|
||||||
wrapperType.String(string(column.Type.Comment.Val)),
|
|
||||||
).Value(),
|
|
||||||
}
|
}
|
||||||
|
|
||||||
structFieldDefine := TableColumnTpl
|
structFieldDefine := TableColumnTpl
|
||||||
@ -181,7 +192,7 @@ func generateTableColumnDefined(modelStructName string, columnList []*sqlparser.
|
|||||||
tableColumnFunction := `
|
tableColumnFunction := `
|
||||||
|
|
||||||
// Columns 获取表字段定义
|
// Columns 获取表字段定义
|
||||||
func ({TABLE_FIRST} {MODEL_STRUCT_NAME}) Columns() *{COLUMN_DEFINED} {
|
func ({TABLE_FIRST} {MODEL_STRUCT_NAME}) Columns() {COLUMN_DEFINED} {
|
||||||
return {STRUCT_FIELD_DESC_DEFINED_RESULT}
|
return {STRUCT_FIELD_DESC_DEFINED_RESULT}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11,14 +11,15 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"path/filepath"
|
||||||
|
"strings"
|
||||||
|
"sync"
|
||||||
|
|
||||||
"git.zhangdeman.cn/zhangdeman/consts"
|
"git.zhangdeman.cn/zhangdeman/consts"
|
||||||
"git.zhangdeman.cn/zhangdeman/database/abstract"
|
"git.zhangdeman.cn/zhangdeman/database/abstract"
|
||||||
"git.zhangdeman.cn/zhangdeman/database/define"
|
"git.zhangdeman.cn/zhangdeman/database/define"
|
||||||
"git.zhangdeman.cn/zhangdeman/serialize"
|
"git.zhangdeman.cn/zhangdeman/serialize"
|
||||||
"go.uber.org/zap"
|
"go.uber.org/zap"
|
||||||
"path/filepath"
|
|
||||||
"strings"
|
|
||||||
"sync"
|
|
||||||
|
|
||||||
"gorm.io/gorm"
|
"gorm.io/gorm"
|
||||||
)
|
)
|
||||||
@ -32,7 +33,7 @@ func init() {
|
|||||||
WrapperClient = NewWrapperClient()
|
WrapperClient = NewWrapperClient()
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewWrapperClient() *wrapperClient {
|
func NewWrapperClient() abstract.IWrapperClient {
|
||||||
return &wrapperClient{
|
return &wrapperClient{
|
||||||
lock: &sync.RWMutex{},
|
lock: &sync.RWMutex{},
|
||||||
clientTable: make(map[string]abstract.IWrapperDatabaseClient),
|
clientTable: make(map[string]abstract.IWrapperDatabaseClient),
|
||||||
@ -114,7 +115,7 @@ func (c *wrapperClient) getCfg(cfgPath string) (*define.CfgFile, error) {
|
|||||||
// 获取不到类型
|
// 获取不到类型
|
||||||
return nil, errors.New("文件格式必须是JSON或者YAML")
|
return nil, errors.New("文件格式必须是JSON或者YAML")
|
||||||
}
|
}
|
||||||
fileType := strings.ToLower(fileArr[len(fileArr)-1])
|
fileType := consts.FileType(strings.ToLower(fileArr[len(fileArr)-1]))
|
||||||
fileFlagArr := strings.Split(fileArr[0], string(filepath.Separator))
|
fileFlagArr := strings.Split(fileArr[0], string(filepath.Separator))
|
||||||
result := &define.CfgFile{
|
result := &define.CfgFile{
|
||||||
Path: cfgPath,
|
Path: cfgPath,
|
||||||
|
@ -133,6 +133,15 @@ func (dc *DBClient) GetDatabaseClient(conf *define.Driver, logInstance *zap.Logg
|
|||||||
return nil, fmt.Errorf("%v : db driver is not support", conf.DBType)
|
return nil, fmt.Errorf("%v : db driver is not support", conf.DBType)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
dbInstance, _ := instance.DB()
|
||||||
|
if nil == conf.Connection {
|
||||||
|
conf.Connection = &define.Connection{
|
||||||
|
MaxOpen: 100,
|
||||||
|
MaxIdle: 100,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
dbInstance.SetMaxIdleConns(conf.Connection.MaxIdle)
|
||||||
|
dbInstance.SetMaxOpenConns(conf.Connection.MaxOpen)
|
||||||
instance.Logger = wrapper.NewGormLoggerWithInstance(nil, instance, logInstance, "", nil)
|
instance.Logger = wrapper.NewGormLoggerWithInstance(nil, instance, logInstance, "", nil)
|
||||||
|
|
||||||
return instance, nil
|
return instance, nil
|
||||||
|
Reference in New Issue
Block a user