- Updated main.go to initialize email service and include it in the dependency injection container. - Refactored handlers to utilize context in service method calls, improving consistency and error handling. - Introduced new service options for upload, security, and captcha services, enhancing modularity and testability. - Removed unused repository implementations to streamline the codebase. This commit continues the effort to improve the architecture by ensuring all services are properly injected and utilized across the application.
52 lines
903 B
Go
52 lines
903 B
Go
package logger
|
||
|
||
import (
|
||
"carrotskin/pkg/config"
|
||
"fmt"
|
||
"sync"
|
||
|
||
"go.uber.org/zap"
|
||
)
|
||
|
||
var (
|
||
// loggerInstance 全局日志实例
|
||
loggerInstance *zap.Logger
|
||
// once 确保只初始化一次
|
||
once sync.Once
|
||
// initError 初始化错误
|
||
initError error
|
||
)
|
||
|
||
// Init 初始化日志记录器(线程安全,只会执行一次)
|
||
func Init(cfg config.LogConfig) error {
|
||
once.Do(func() {
|
||
loggerInstance, initError = New(cfg)
|
||
if initError != nil {
|
||
return
|
||
}
|
||
})
|
||
return initError
|
||
}
|
||
|
||
// GetLogger 获取日志实例(线程安全)
|
||
func GetLogger() (*zap.Logger, error) {
|
||
if loggerInstance == nil {
|
||
return nil, fmt.Errorf("日志未初始化,请先调用 logger.Init()")
|
||
}
|
||
return loggerInstance, nil
|
||
}
|
||
|
||
// MustGetLogger 获取日志实例,如果未初始化则panic
|
||
func MustGetLogger() *zap.Logger {
|
||
logger, err := GetLogger()
|
||
if err != nil {
|
||
panic(err)
|
||
}
|
||
return logger
|
||
}
|
||
|
||
|
||
|
||
|
||
|