Files
2026-06-01 14:39:45 +08:00

65 lines
2.0 KiB
Go

package haiyuapi
import (
"time"
"tyapi-server/internal/config"
"tyapi-server/internal/shared/external_logger"
)
// NewHaiyuapiServiceWithConfig 使用配置创建海宇API服务
func NewHaiyuapiServiceWithConfig(cfg *config.Config) (*HaiyuapiService, error) {
loggingConfig := external_logger.ExternalServiceLoggingConfig{
Enabled: cfg.Haiyuapi.Logging.Enabled,
LogDir: cfg.Haiyuapi.Logging.LogDir,
ServiceName: "haiyuapi",
UseDaily: cfg.Haiyuapi.Logging.UseDaily,
EnableLevelSeparation: cfg.Haiyuapi.Logging.EnableLevelSeparation,
LevelConfigs: make(map[string]external_logger.ExternalServiceLevelFileConfig),
}
for level, levelCfg := range cfg.Haiyuapi.Logging.LevelConfigs {
loggingConfig.LevelConfigs[level] = external_logger.ExternalServiceLevelFileConfig{
MaxSize: levelCfg.MaxSize,
MaxBackups: levelCfg.MaxBackups,
MaxAge: levelCfg.MaxAge,
Compress: levelCfg.Compress,
}
}
logger, err := external_logger.NewExternalServiceLogger(loggingConfig)
if err != nil {
return nil, err
}
timeout := cfg.Haiyuapi.Timeout
if timeout <= 0 {
timeout = defaultRequestTimeout
}
return NewHaiyuapiService(
cfg.Haiyuapi.BaseURL,
cfg.Haiyuapi.AccessID,
cfg.Haiyuapi.SecretKey,
timeout,
logger,
), nil
}
// NewHaiyuapiServiceWithLogging 使用自定义日志配置创建海宇API服务
func NewHaiyuapiServiceWithLogging(baseURL, accessID, secretKey string, timeout time.Duration, loggingConfig external_logger.ExternalServiceLoggingConfig) (*HaiyuapiService, error) {
loggingConfig.ServiceName = "haiyuapi"
logger, err := external_logger.NewExternalServiceLogger(loggingConfig)
if err != nil {
return nil, err
}
return NewHaiyuapiService(baseURL, accessID, secretKey, timeout, logger), nil
}
// NewHaiyuapiServiceSimple 创建无日志的海宇API服务
func NewHaiyuapiServiceSimple(baseURL, accessID, secretKey string, timeout time.Duration) *HaiyuapiService {
return NewHaiyuapiService(baseURL, accessID, secretKey, timeout, nil)
}