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.
127 lines
3.0 KiB
127 lines
3.0 KiB
package golog
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"go.dtapp.net/library/utils/dorm"
|
|
"go.dtapp.net/library/utils/goip"
|
|
"go.mongodb.org/mongo-driver/bson/primitive"
|
|
"gorm.io/datatypes"
|
|
"gorm.io/gorm"
|
|
"log"
|
|
"os"
|
|
"runtime"
|
|
"strings"
|
|
"unicode/utf8"
|
|
)
|
|
|
|
// ApiClient 接口
|
|
type ApiClient struct {
|
|
gormClient *gorm.DB // 驱动
|
|
mongoCollectionClient *dorm.MongoClient // 驱动(温馨提示:需要已选择库)
|
|
config struct {
|
|
logType string // 日志类型
|
|
tableName string // 表名
|
|
insideIp string // 内网ip
|
|
hostname string // 主机名
|
|
goVersion string // go版本
|
|
} // 配置
|
|
}
|
|
|
|
// NewApiClient 创建接口实例化
|
|
// WithGormClient && WithTableName
|
|
// WithMongoCollectionClient && WithTableName
|
|
func NewApiClient(attrs ...*OperationAttr) (*ApiClient, error) {
|
|
|
|
c := &ApiClient{}
|
|
for _, attr := range attrs {
|
|
log.Println(attr)
|
|
c.gormClient = attr.gormClient
|
|
c.mongoCollectionClient = attr.mongoCollectionClient
|
|
c.config.logType = attr.logType
|
|
c.config.tableName = attr.tableName
|
|
}
|
|
|
|
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(&ApiPostgresqlLog{})
|
|
if err != nil {
|
|
return nil, errors.New("创建表失败:" + err.Error())
|
|
}
|
|
|
|
case logTypeMongo:
|
|
|
|
if c.mongoCollectionClient.Db == nil {
|
|
return nil, errors.New("驱动不能为空")
|
|
}
|
|
|
|
if c.config.tableName == "" {
|
|
return nil, errors.New("表名不能为空")
|
|
}
|
|
|
|
c.mongoCollectionClient = c.mongoCollectionClient.Collection(c.config.tableName)
|
|
|
|
default:
|
|
return nil, errors.New("驱动为空")
|
|
}
|
|
|
|
hostname, _ := os.Hostname()
|
|
|
|
c.config.hostname = hostname
|
|
c.config.insideIp = goip.GetInsideIp()
|
|
c.config.goVersion = strings.TrimPrefix(runtime.Version(), "go")
|
|
|
|
return c, nil
|
|
}
|
|
|
|
// GormRecord 记录日志
|
|
func (c *ApiClient) GormRecord(postgresqlLog ApiPostgresqlLog) error {
|
|
|
|
if utf8.ValidString(string(postgresqlLog.ResponseBody)) == false {
|
|
log.Println("内容格式无法记录")
|
|
postgresqlLog.ResponseBody = datatypes.JSON("")
|
|
}
|
|
|
|
postgresqlLog.SystemHostName = c.config.hostname
|
|
if postgresqlLog.SystemInsideIp == "" {
|
|
postgresqlLog.SystemInsideIp = c.config.insideIp
|
|
}
|
|
postgresqlLog.GoVersion = c.config.goVersion
|
|
|
|
return c.gormClient.Table(c.config.tableName).Create(&postgresqlLog).Error
|
|
}
|
|
|
|
// GormQuery 查询
|
|
func (c *ApiClient) GormQuery() *gorm.DB {
|
|
return c.gormClient.Table(c.config.tableName)
|
|
}
|
|
|
|
// MongoRecord 记录日志
|
|
func (c *ApiClient) MongoRecord(mongoLog ApiMongoLog) error {
|
|
|
|
mongoLog.SystemHostName = c.config.hostname
|
|
if mongoLog.SystemInsideIp == "" {
|
|
mongoLog.SystemInsideIp = c.config.insideIp
|
|
}
|
|
mongoLog.GoVersion = c.config.goVersion
|
|
|
|
mongoLog.LogId = primitive.NewObjectID()
|
|
|
|
_, err := c.mongoCollectionClient.InsertOne(context.Background(), mongoLog)
|
|
return err
|
|
}
|
|
|
|
// MongoQuery 查询
|
|
func (c *ApiClient) MongoQuery() *dorm.MongoClient {
|
|
return c.mongoCollectionClient
|
|
}
|