You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
123 lines
2.7 KiB
123 lines
2.7 KiB
package golog
|
|
|
|
import (
|
|
"bytes"
|
|
"context"
|
|
"encoding/json"
|
|
"errors"
|
|
"github.com/dtapps/go-library/utils/dorm"
|
|
"github.com/dtapps/go-library/utils/goip"
|
|
"github.com/gin-gonic/gin"
|
|
"gorm.io/gorm"
|
|
"os"
|
|
"runtime"
|
|
)
|
|
|
|
// GinClient 框架
|
|
type GinClient struct {
|
|
gormClient *gorm.DB // 数据库驱动
|
|
mongoClient *dorm.MongoClient // 数据库驱动
|
|
ipService *goip.Client // ip服务
|
|
config struct {
|
|
logType string // 日志类型
|
|
tableName string // 表名
|
|
databaseName string // 库名
|
|
collectionName string // 表名
|
|
insideIp string // 内网ip
|
|
hostname string // 主机名
|
|
goVersion string // go版本
|
|
} // 配置
|
|
}
|
|
|
|
// NewGinClient 创建框架实例化
|
|
// WithGormClient && WithTableName
|
|
// WithMongoCollectionClient && WithDatabaseName && WithCollectionName
|
|
func NewGinClient(attrs ...*OperationAttr) (*GinClient, error) {
|
|
|
|
c := &GinClient{}
|
|
for _, attr := range attrs {
|
|
if attr.gormClient != nil {
|
|
c.gormClient = attr.gormClient
|
|
c.config.logType = attr.logType
|
|
}
|
|
if attr.mongoClient != nil {
|
|
c.mongoClient = attr.mongoClient
|
|
c.config.logType = attr.logType
|
|
}
|
|
if attr.tableName != "" {
|
|
c.config.tableName = attr.tableName
|
|
}
|
|
if attr.databaseName != "" {
|
|
c.config.databaseName = attr.databaseName
|
|
}
|
|
if attr.collectionName != "" {
|
|
c.config.collectionName = attr.collectionName
|
|
}
|
|
if attr.ipService != nil {
|
|
c.ipService = attr.ipService
|
|
}
|
|
}
|
|
|
|
switch c.config.logType {
|
|
case logTypeGorm:
|
|
|
|
if c.gormClient == nil {
|
|
return nil, errors.New("没有设置驱动")
|
|
}
|
|
|
|
if c.config.tableName == "" {
|
|
return nil, errors.New("没有设置表名")
|
|
}
|
|
|
|
err := c.gormClient.Table(c.config.tableName).AutoMigrate(&ginPostgresqlLog{})
|
|
if err != nil {
|
|
return nil, errors.New("创建表失败:" + err.Error())
|
|
}
|
|
|
|
case logTypeMongo:
|
|
|
|
if c.mongoClient.Db == nil {
|
|
return nil, errors.New("没有设置驱动")
|
|
}
|
|
|
|
if c.config.databaseName == "" {
|
|
return nil, errors.New("没有设置库名")
|
|
}
|
|
|
|
if c.config.collectionName == "" {
|
|
return nil, errors.New("没有设置表名")
|
|
}
|
|
|
|
default:
|
|
return nil, errors.New("驱动为空")
|
|
}
|
|
|
|
hostname, _ := os.Hostname()
|
|
|
|
c.config.hostname = hostname
|
|
c.config.insideIp = goip.GetInsideIp(context.Background())
|
|
c.config.goVersion = runtime.Version()
|
|
|
|
return c, nil
|
|
}
|
|
|
|
type bodyLogWriter struct {
|
|
gin.ResponseWriter
|
|
body *bytes.Buffer
|
|
}
|
|
|
|
func (w bodyLogWriter) Write(b []byte) (int, error) {
|
|
w.body.Write(b)
|
|
return w.ResponseWriter.Write(b)
|
|
}
|
|
|
|
func (w bodyLogWriter) WriteString(s string) (int, error) {
|
|
w.body.WriteString(s)
|
|
return w.ResponseWriter.WriteString(s)
|
|
}
|
|
|
|
func (c *GinClient) jsonUnmarshal(data string) (result interface{}) {
|
|
_ = json.Unmarshal([]byte(data), &result)
|
|
return
|
|
}
|