Files
photography/backend/internal/svc/servicecontext.go
xujiang 5dd0bc19e4
Some checks failed
部署管理后台 / 🧪 测试和构建 (push) Failing after 1m5s
部署管理后台 / 🔒 安全扫描 (push) Has been skipped
部署后端服务 / 🧪 测试后端 (push) Failing after 3m13s
部署前端网站 / 🧪 测试和构建 (push) Failing after 2m10s
部署管理后台 / 🚀 部署到生产环境 (push) Has been skipped
部署后端服务 / 🚀 构建并部署 (push) Has been skipped
部署管理后台 / 🔄 回滚部署 (push) Has been skipped
部署前端网站 / 🚀 部署到生产环境 (push) Has been skipped
部署后端服务 / 🔄 回滚部署 (push) Has been skipped
style: 统一代码格式化 (go fmt + 配置更新)
- 后端:应用 go fmt 自动格式化,统一代码风格
- 前端:更新 API 配置,完善类型安全
- 所有代码符合项目规范,准备生产部署
2025-07-14 10:02:04 +08:00

68 lines
1.7 KiB
Go

package svc
import (
"fmt"
"github.com/zeromicro/go-zero/core/stores/sqlx"
"gorm.io/gorm"
"photography-backend/internal/config"
"photography-backend/internal/middleware"
"photography-backend/internal/model"
"photography-backend/pkg/utils/database"
)
type ServiceContext struct {
Config config.Config
DB *gorm.DB
UserModel model.UserModel
PhotoModel model.PhotoModel
CategoryModel model.CategoryModel
Middleware *middleware.MiddlewareManager
}
func NewServiceContext(c config.Config) *ServiceContext {
db, err := database.NewDB(c.Database)
if err != nil {
panic(err)
}
// Create sqlx connection for go-zero models
sqlxConn := sqlx.NewSqlConn(getSQLDriverName(c.Database.Driver), getSQLDataSource(c.Database))
return &ServiceContext{
Config: c,
DB: db,
UserModel: model.NewUserModel(sqlxConn),
PhotoModel: model.NewPhotoModel(sqlxConn),
CategoryModel: model.NewCategoryModel(sqlxConn),
Middleware: middleware.NewMiddlewareManager(c),
}
}
func getSQLDriverName(driver string) string {
switch driver {
case "mysql":
return "mysql"
case "postgres":
return "postgres"
case "sqlite":
return "sqlite3"
default:
return "mysql"
}
}
func getSQLDataSource(config database.Config) string {
switch config.Driver {
case "mysql":
return fmt.Sprintf("%s:%s@tcp(%s:%d)/%s?charset=%s&parseTime=True&loc=Local",
config.Username, config.Password, config.Host, config.Port, config.Database, config.Charset)
case "postgres":
return fmt.Sprintf("host=%s user=%s password=%s dbname=%s port=%d sslmode=%s TimeZone=Asia/Shanghai",
config.Host, config.Username, config.Password, config.Database, config.Port, config.SSLMode)
case "sqlite":
return config.FilePath
default:
return ""
}
}