TinySkin/server/provide.go
2023-09-03 20:50:42 +08:00

90 lines
2.0 KiB
Go

package server
import (
"context"
"database/sql"
"fmt"
"log/slog"
"os"
entsql "entgo.io/ent/dialect/sql"
"github.com/bwmarrin/snowflake"
"github.com/go-playground/validator/v10"
_ "github.com/go-sql-driver/mysql"
"github.com/google/wire"
"github.com/xmdhs/authlib-skin/config"
"github.com/xmdhs/authlib-skin/db/cache"
"github.com/xmdhs/authlib-skin/db/ent"
)
func ProvideSlog(c config.Config) slog.Handler {
var level slog.Level
switch c.Log.Level {
case "debug":
level = slog.LevelDebug
case "info":
level = slog.LevelInfo
case "warn":
level = slog.LevelWarn
case "error":
level = slog.LevelError
}
o := &slog.HandlerOptions{Level: level}
var h slog.Handler
if c.Log.Json {
h = slog.NewJSONHandler(os.Stderr, o)
} else {
h = slog.NewTextHandler(os.Stderr, o)
}
return h
}
func ProvideDB(c config.Config) (*sql.DB, func(), error) {
db, err := sql.Open("mysql", c.Sql.MysqlDsn)
if err != nil {
return nil, nil, fmt.Errorf("ProvideDB: %w", err)
}
db.SetMaxOpenConns(20)
db.SetMaxIdleConns(10)
return db, func() { db.Close() }, nil
}
func ProvideEnt(ctx context.Context, db *sql.DB, c config.Config, sl *slog.Logger) (*ent.Client, func(), error) {
drv := entsql.OpenDB("mysql", db)
opts := []ent.Option{ent.Driver(drv), ent.Log(
func(a ...any) {
sl.Debug(fmt.Sprint(a))
},
)}
if c.Debug {
opts = append(opts, ent.Debug())
}
e := ent.NewClient(opts...)
err := e.Schema.Create(ctx)
if err != nil {
return nil, nil, fmt.Errorf("ProvideEnt: %w", err)
}
return e, func() { e.Close() }, nil
}
func ProvideValidate() *validator.Validate {
return validator.New()
}
func ProvideSnowflake(c config.Config) (*snowflake.Node, error) {
snowflake.Epoch = c.Epoch
n, err := snowflake.NewNode(c.Node)
if err != nil {
return nil, fmt.Errorf("ProvideSnowflake: %w", err)
}
return n, nil
}
func ProvideCache(c config.Config) cache.Cache {
return cache.NewFastCache(c.Cache.Ram)
}
var Set = wire.NewSet(ProvideSlog, ProvideDB, ProvideEnt, ProvideValidate, ProvideSnowflake, ProvideCache)