69 lines
1.0 KiB
Go
69 lines
1.0 KiB
Go
package db
|
|
|
|
import (
|
|
"context"
|
|
"io"
|
|
|
|
"ultone/internal/opt"
|
|
"ultone/internal/tool"
|
|
|
|
"gorm.io/gorm"
|
|
)
|
|
|
|
var Default *Client
|
|
|
|
type DBType string
|
|
|
|
const (
|
|
DBTypeSqlite = "sqlite"
|
|
DBTypeMysql = "mysql"
|
|
DBTypePostgres = "postgres"
|
|
)
|
|
|
|
type Client struct {
|
|
ctx context.Context
|
|
cli *gorm.DB
|
|
dbType DBType
|
|
cfgSqlite *cfgSqlite
|
|
}
|
|
|
|
func (c *Client) Type() DBType {
|
|
return c.dbType
|
|
}
|
|
|
|
func (c *Client) Session(ctxs ...context.Context) *gorm.DB {
|
|
var ctx context.Context
|
|
if len(ctxs) > 0 && ctxs[0] != nil {
|
|
ctx = ctxs[0]
|
|
} else {
|
|
ctx = tool.Timeout(30)
|
|
}
|
|
|
|
session := c.cli.Session(&gorm.Session{Context: ctx})
|
|
|
|
if opt.Debug {
|
|
session = session.Debug()
|
|
}
|
|
|
|
return session
|
|
}
|
|
|
|
func (c *Client) Close() {
|
|
d, _ := c.cli.DB()
|
|
d.Close()
|
|
}
|
|
|
|
// Dump
|
|
// Only for sqlite with mem mode to dump data to bytes(io.Reader)
|
|
func (c *Client) Dump() (reader io.ReadSeekCloser, ok bool) {
|
|
if c.dbType != DBTypeSqlite {
|
|
return nil, false
|
|
}
|
|
|
|
if c.cfgSqlite.fsType != "mem" {
|
|
return nil, false
|
|
}
|
|
|
|
return c.cfgSqlite.memDump.Dump(), true
|
|
}
|