feat: 接入计划广场后端主链路

This commit is contained in:
Losita
2026-05-04 20:38:49 +08:00
parent 786c8925a0
commit 46874f0806
22 changed files with 3439 additions and 104 deletions

View File

@@ -24,6 +24,7 @@ import (
"github.com/LoveLosita/smartflow/backend/bootstrap"
"github.com/LoveLosita/smartflow/backend/dao"
gatewayrouter "github.com/LoveLosita/smartflow/backend/gateway/router"
gatewaytaskclassforum "github.com/LoveLosita/smartflow/backend/gateway/taskclassforum"
gatewayuserauth "github.com/LoveLosita/smartflow/backend/gateway/userauth"
kafkabus "github.com/LoveLosita/smartflow/backend/infra/kafka"
outboxinfra "github.com/LoveLosita/smartflow/backend/infra/outbox"
@@ -73,6 +74,7 @@ type appRuntime struct {
limiter *pkg.RateLimiter
handlers *api.ApiHandlers
userAuthClient *gatewayuserauth.Client
taskClassForumClient *gatewaytaskclassforum.Client
}
// loadConfig 锻炼?
@@ -215,6 +217,14 @@ func buildRuntime(ctx context.Context) (*appRuntime, error) {
if err != nil {
return nil, fmt.Errorf("failed to initialize userauth zrpc client: %w", err)
}
taskClassForumClient, err := gatewaytaskclassforum.NewClient(gatewaytaskclassforum.ClientConfig{
Endpoints: viper.GetStringSlice("taskclassforum.rpc.endpoints"),
Target: viper.GetString("taskclassforum.rpc.target"),
Timeout: viper.GetDuration("taskclassforum.rpc.timeout"),
})
if err != nil {
return nil, fmt.Errorf("failed to initialize taskclassforum zrpc client: %w", err)
}
taskSv := service.NewTaskService(taskRepo, cacheRepo, eventBus)
taskSv.SetActiveScheduleDAO(manager.ActiveSchedule)
courseService := buildCourseService(llmService, courseRepo, scheduleRepo)
@@ -324,6 +334,7 @@ func buildRuntime(ctx context.Context) (*appRuntime, error) {
limiter: limiter,
handlers: handlers,
userAuthClient: userAuthClient,
taskClassForumClient: taskClassForumClient,
}
if runtime.eventBus != nil {
if err := runtime.registerEventHandlers(); err != nil {
@@ -904,7 +915,7 @@ func (r *appRuntime) registerEventHandlers() error {
}
func (r *appRuntime) startHTTP(ctx context.Context) {
router := gatewayrouter.RegisterRouters(r.handlers, r.userAuthClient, r.cacheRepo, r.limiter)
router := gatewayrouter.RegisterRouters(r.handlers, r.userAuthClient, r.taskClassForumClient, r.cacheRepo, r.limiter)
gatewayrouter.StartEngine(ctx, router)
}

View File

@@ -4,6 +4,8 @@ import (
"log"
"github.com/LoveLosita/smartflow/backend/bootstrap"
legacydao "github.com/LoveLosita/smartflow/backend/dao"
"github.com/LoveLosita/smartflow/backend/services/taskclassforum/adapter"
forumdao "github.com/LoveLosita/smartflow/backend/services/taskclassforum/dao"
forumrpc "github.com/LoveLosita/smartflow/backend/services/taskclassforum/rpc"
forumsv "github.com/LoveLosita/smartflow/backend/services/taskclassforum/sv"
@@ -20,10 +22,14 @@ func main() {
log.Fatalf("failed to connect taskclassforum database: %v", err)
}
// 1. 当前阶段只启动计划广场自身 RPC 壳
// 2. TaskClass legacy adapter 会在第三步业务主链路接入,避免现在抢改 task 模块
// 3. 未实现的业务方法会明确返回 Unimplemented而不是伪装成可用能力
svc := forumsv.New(forumsv.Options{DB: db})
// 1. 复用同一个 DB 句柄装配 legacy TaskClass DAO避免本轮抢改 task-class 模块
// 2. 计划广场只通过快照端口读取和创建 TaskClass不直接写 schedule
// 3. 后续 task-class 独立成服务后,只替换这里的 adapter 注入点
taskClassPort := adapter.NewLegacyTaskClassAdapter(legacydao.NewTaskClassDAO(db))
svc := forumsv.New(forumsv.Options{
DB: db,
TaskClassPort: taskClassPort,
})
forumrpc.Start(forumrpc.ServerOptions{
ListenOn: viper.GetString("taskclassforum.rpc.listenOn"),
Timeout: viper.GetDuration("taskclassforum.rpc.timeout"),