From e60827487a918289bb961c48003a28cc6633117a Mon Sep 17 00:00:00 2001 From: mayiming <1627832236@qq.com> Date: Tue, 28 Oct 2025 22:57:51 +0800 Subject: [PATCH] =?UTF-8?q?=E5=AE=8C=E6=88=90=E4=BC=9A=E8=AE=AE=E7=AE=A1?= =?UTF-8?q?=E7=90=86?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../internal/model/etc/meetingspeakerapi.yaml | 3 + .../internal/model/internal/config/config.go | 10 ++ .../meeting_speaker/createspeakerhandler.go | 31 +++++ .../meeting_speaker/deletespeakerhandler.go | 31 +++++ .../meeting_speaker/getspeakerhandler.go | 31 +++++ .../listspeakersbymeetinghandler.go | 31 +++++ .../meeting_speaker/updatespeakerhandler.go | 31 +++++ .../internal/model/internal/handler/routes.go | 46 +++++++ .../meeting_speaker/createspeakerlogic.go | 33 +++++ .../meeting_speaker/deletespeakerlogic.go | 33 +++++ .../logic/meeting_speaker/getspeakerlogic.go | 33 +++++ .../listspeakersbymeetinglogic.go | 33 +++++ .../meeting_speaker/updatespeakerlogic.go | 33 +++++ .../model/internal/svc/servicecontext.go | 18 +++ .../internal/model/internal/types/types.go | 72 +++++++++++ .../internal/model/meetingspeakerapi.go | 34 +++++ server/go.mod | 53 ++++---- server/go.sum | 118 +++++++++--------- .../meeting_speaker/createspeakerhandler.go | 50 ++++++++ .../meeting_speaker/deletespeakerhandler.go | 49 ++++++++ .../meeting_speaker/getspeakerhandler.go | 50 ++++++++ .../listspeakersbymeetinghandler.go | 50 ++++++++ .../meeting_speaker/updatespeakerhandler.go | 50 ++++++++ .../meeting_speaker/createspeakerlogic.go | 36 ++++++ .../meeting_speaker/deletespeakerlogic.go | 36 ++++++ .../logic/meeting_speaker/getspeakerlogic.go | 36 ++++++ .../listspeakersbymeetinglogic.go | 36 ++++++ .../meeting_speaker/updatespeakerlogic.go | 36 ++++++ .../internal/model/meetingspeakermodel.go | 29 +++++ .../internal/model/meetingspeakermodel_gen.go | 90 +++++++++++++ .../meetingspeaker/internal/model/vars.go | 5 + .../meetingspeaker/internal/types/types.go | 72 +++++++++++ 32 files changed, 1214 insertions(+), 85 deletions(-) create mode 100644 server/.ã/internal/meetingspeaker/internal/model/etc/meetingspeakerapi.yaml create mode 100644 server/.ã/internal/meetingspeaker/internal/model/internal/config/config.go create mode 100644 server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/createspeakerhandler.go create mode 100644 server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/deletespeakerhandler.go create mode 100644 server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/getspeakerhandler.go create mode 100644 server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/listspeakersbymeetinghandler.go create mode 100644 server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/updatespeakerhandler.go create mode 100644 server/.ã/internal/meetingspeaker/internal/model/internal/handler/routes.go create mode 100644 server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/createspeakerlogic.go create mode 100644 server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/deletespeakerlogic.go create mode 100644 server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/getspeakerlogic.go create mode 100644 server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/listspeakersbymeetinglogic.go create mode 100644 server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/updatespeakerlogic.go create mode 100644 server/.ã/internal/meetingspeaker/internal/model/internal/svc/servicecontext.go create mode 100644 server/.ã/internal/meetingspeaker/internal/model/internal/types/types.go create mode 100644 server/.ã/internal/meetingspeaker/internal/model/meetingspeakerapi.go create mode 100644 server/internal/meetingspeaker/handler/meeting_speaker/createspeakerhandler.go create mode 100644 server/internal/meetingspeaker/handler/meeting_speaker/deletespeakerhandler.go create mode 100644 server/internal/meetingspeaker/handler/meeting_speaker/getspeakerhandler.go create mode 100644 server/internal/meetingspeaker/handler/meeting_speaker/listspeakersbymeetinghandler.go create mode 100644 server/internal/meetingspeaker/handler/meeting_speaker/updatespeakerhandler.go create mode 100644 server/internal/meetingspeaker/internal/logic/meeting_speaker/createspeakerlogic.go create mode 100644 server/internal/meetingspeaker/internal/logic/meeting_speaker/deletespeakerlogic.go create mode 100644 server/internal/meetingspeaker/internal/logic/meeting_speaker/getspeakerlogic.go create mode 100644 server/internal/meetingspeaker/internal/logic/meeting_speaker/listspeakersbymeetinglogic.go create mode 100644 server/internal/meetingspeaker/internal/logic/meeting_speaker/updatespeakerlogic.go create mode 100644 server/internal/meetingspeaker/internal/model/meetingspeakermodel.go create mode 100644 server/internal/meetingspeaker/internal/model/meetingspeakermodel_gen.go create mode 100644 server/internal/meetingspeaker/internal/model/vars.go create mode 100644 server/internal/meetingspeaker/internal/types/types.go diff --git a/server/.ã/internal/meetingspeaker/internal/model/etc/meetingspeakerapi.yaml b/server/.ã/internal/meetingspeaker/internal/model/etc/meetingspeakerapi.yaml new file mode 100644 index 00000000..e44b0b03 --- /dev/null +++ b/server/.ã/internal/meetingspeaker/internal/model/etc/meetingspeakerapi.yaml @@ -0,0 +1,3 @@ +Name: meeting_speaker_api +Host: 0.0.0.0 +Port: 8888 diff --git a/server/.ã/internal/meetingspeaker/internal/model/internal/config/config.go b/server/.ã/internal/meetingspeaker/internal/model/internal/config/config.go new file mode 100644 index 00000000..7fbd0898 --- /dev/null +++ b/server/.ã/internal/meetingspeaker/internal/model/internal/config/config.go @@ -0,0 +1,10 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package config + +import "github.com/zeromicro/go-zero/rest" + +type Config struct { + rest.RestConf +} diff --git a/server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/createspeakerhandler.go b/server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/createspeakerhandler.go new file mode 100644 index 00000000..231c6957 --- /dev/null +++ b/server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/createspeakerhandler.go @@ -0,0 +1,31 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "net/http" + + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/svc" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/types" + "github.com/zeromicro/go-zero/rest/httpx" +) + +func CreateSpeakerHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { + return func(w http.ResponseWriter, r *http.Request) { + var req types.CreateSpeakerReq + if err := httpx.Parse(r, &req); err != nil { + httpx.ErrorCtx(r.Context(), w, err) + return + } + + l := meeting_speaker.NewCreateSpeakerLogic(r.Context(), svcCtx) + resp, err := l.CreateSpeaker(&req) + if err != nil { + httpx.ErrorCtx(r.Context(), w, err) + } else { + httpx.OkJsonCtx(r.Context(), w, resp) + } + } +} diff --git a/server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/deletespeakerhandler.go b/server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/deletespeakerhandler.go new file mode 100644 index 00000000..092de238 --- /dev/null +++ b/server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/deletespeakerhandler.go @@ -0,0 +1,31 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "net/http" + + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/svc" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/types" + "github.com/zeromicro/go-zero/rest/httpx" +) + +func DeleteSpeakerHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { + return func(w http.ResponseWriter, r *http.Request) { + var req types.DeleteSpeakerReq + if err := httpx.Parse(r, &req); err != nil { + httpx.ErrorCtx(r.Context(), w, err) + return + } + + l := meeting_speaker.NewDeleteSpeakerLogic(r.Context(), svcCtx) + resp, err := l.DeleteSpeaker(&req) + if err != nil { + httpx.ErrorCtx(r.Context(), w, err) + } else { + httpx.OkJsonCtx(r.Context(), w, resp) + } + } +} diff --git a/server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/getspeakerhandler.go b/server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/getspeakerhandler.go new file mode 100644 index 00000000..f98ff5d9 --- /dev/null +++ b/server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/getspeakerhandler.go @@ -0,0 +1,31 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "net/http" + + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/svc" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/types" + "github.com/zeromicro/go-zero/rest/httpx" +) + +func GetSpeakerHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { + return func(w http.ResponseWriter, r *http.Request) { + var req types.GetSpeakerReq + if err := httpx.Parse(r, &req); err != nil { + httpx.ErrorCtx(r.Context(), w, err) + return + } + + l := meeting_speaker.NewGetSpeakerLogic(r.Context(), svcCtx) + resp, err := l.GetSpeaker(&req) + if err != nil { + httpx.ErrorCtx(r.Context(), w, err) + } else { + httpx.OkJsonCtx(r.Context(), w, resp) + } + } +} diff --git a/server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/listspeakersbymeetinghandler.go b/server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/listspeakersbymeetinghandler.go new file mode 100644 index 00000000..7d6e05b4 --- /dev/null +++ b/server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/listspeakersbymeetinghandler.go @@ -0,0 +1,31 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "net/http" + + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/svc" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/types" + "github.com/zeromicro/go-zero/rest/httpx" +) + +func ListSpeakersByMeetingHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { + return func(w http.ResponseWriter, r *http.Request) { + var req types.ListSpeakersByMeetingReq + if err := httpx.Parse(r, &req); err != nil { + httpx.ErrorCtx(r.Context(), w, err) + return + } + + l := meeting_speaker.NewListSpeakersByMeetingLogic(r.Context(), svcCtx) + resp, err := l.ListSpeakersByMeeting(&req) + if err != nil { + httpx.ErrorCtx(r.Context(), w, err) + } else { + httpx.OkJsonCtx(r.Context(), w, resp) + } + } +} diff --git a/server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/updatespeakerhandler.go b/server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/updatespeakerhandler.go new file mode 100644 index 00000000..f1337d4e --- /dev/null +++ b/server/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker/updatespeakerhandler.go @@ -0,0 +1,31 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "net/http" + + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/svc" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/types" + "github.com/zeromicro/go-zero/rest/httpx" +) + +func UpdateSpeakerHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { + return func(w http.ResponseWriter, r *http.Request) { + var req types.UpdateSpeakerReq + if err := httpx.Parse(r, &req); err != nil { + httpx.ErrorCtx(r.Context(), w, err) + return + } + + l := meeting_speaker.NewUpdateSpeakerLogic(r.Context(), svcCtx) + resp, err := l.UpdateSpeaker(&req) + if err != nil { + httpx.ErrorCtx(r.Context(), w, err) + } else { + httpx.OkJsonCtx(r.Context(), w, resp) + } + } +} diff --git a/server/.ã/internal/meetingspeaker/internal/model/internal/handler/routes.go b/server/.ã/internal/meetingspeaker/internal/model/internal/handler/routes.go new file mode 100644 index 00000000..f067aa7b --- /dev/null +++ b/server/.ã/internal/meetingspeaker/internal/model/internal/handler/routes.go @@ -0,0 +1,46 @@ +// Code generated by goctl. DO NOT EDIT. +// goctl 1.9.1 + +package handler + +import ( + "net/http" + + meeting_speaker "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/handler/meeting_speaker" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/svc" + + "github.com/zeromicro/go-zero/rest" +) + +func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) { + server.AddRoutes( + []rest.Route{ + { + Method: http.MethodGet, + Path: "/api/meetings/:meetingId/speakers", + Handler: meeting_speaker.ListSpeakersByMeetingHandler(serverCtx), + }, + { + Method: http.MethodPost, + Path: "/api/speakers", + Handler: meeting_speaker.CreateSpeakerHandler(serverCtx), + }, + { + Method: http.MethodPut, + Path: "/api/speakers", + Handler: meeting_speaker.UpdateSpeakerHandler(serverCtx), + }, + { + Method: http.MethodGet, + Path: "/api/speakers/:id", + Handler: meeting_speaker.GetSpeakerHandler(serverCtx), + }, + { + Method: http.MethodDelete, + Path: "/api/speakers/:id", + Handler: meeting_speaker.DeleteSpeakerHandler(serverCtx), + }, + }, + rest.WithPrefix("/api/meetingspeaker"), + ) +} diff --git a/server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/createspeakerlogic.go b/server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/createspeakerlogic.go new file mode 100644 index 00000000..3487e924 --- /dev/null +++ b/server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/createspeakerlogic.go @@ -0,0 +1,33 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "context" + + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/svc" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/types" + + "github.com/zeromicro/go-zero/core/logx" +) + +type CreateSpeakerLogic struct { + logx.Logger + ctx context.Context + svcCtx *svc.ServiceContext +} + +func NewCreateSpeakerLogic(ctx context.Context, svcCtx *svc.ServiceContext) *CreateSpeakerLogic { + return &CreateSpeakerLogic{ + Logger: logx.WithContext(ctx), + ctx: ctx, + svcCtx: svcCtx, + } +} + +func (l *CreateSpeakerLogic) CreateSpeaker(req *types.CreateSpeakerReq) (resp *types.CreateSpeakerResp, err error) { + // todo: add your logic here and delete this line + + return +} diff --git a/server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/deletespeakerlogic.go b/server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/deletespeakerlogic.go new file mode 100644 index 00000000..c4586590 --- /dev/null +++ b/server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/deletespeakerlogic.go @@ -0,0 +1,33 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "context" + + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/svc" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/types" + + "github.com/zeromicro/go-zero/core/logx" +) + +type DeleteSpeakerLogic struct { + logx.Logger + ctx context.Context + svcCtx *svc.ServiceContext +} + +func NewDeleteSpeakerLogic(ctx context.Context, svcCtx *svc.ServiceContext) *DeleteSpeakerLogic { + return &DeleteSpeakerLogic{ + Logger: logx.WithContext(ctx), + ctx: ctx, + svcCtx: svcCtx, + } +} + +func (l *DeleteSpeakerLogic) DeleteSpeaker(req *types.DeleteSpeakerReq) (resp *types.DeleteSpeakerResp, err error) { + // todo: add your logic here and delete this line + + return +} diff --git a/server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/getspeakerlogic.go b/server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/getspeakerlogic.go new file mode 100644 index 00000000..45a3af45 --- /dev/null +++ b/server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/getspeakerlogic.go @@ -0,0 +1,33 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "context" + + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/svc" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/types" + + "github.com/zeromicro/go-zero/core/logx" +) + +type GetSpeakerLogic struct { + logx.Logger + ctx context.Context + svcCtx *svc.ServiceContext +} + +func NewGetSpeakerLogic(ctx context.Context, svcCtx *svc.ServiceContext) *GetSpeakerLogic { + return &GetSpeakerLogic{ + Logger: logx.WithContext(ctx), + ctx: ctx, + svcCtx: svcCtx, + } +} + +func (l *GetSpeakerLogic) GetSpeaker(req *types.GetSpeakerReq) (resp *types.GetSpeakerResp, err error) { + // todo: add your logic here and delete this line + + return +} diff --git a/server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/listspeakersbymeetinglogic.go b/server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/listspeakersbymeetinglogic.go new file mode 100644 index 00000000..1d5d6611 --- /dev/null +++ b/server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/listspeakersbymeetinglogic.go @@ -0,0 +1,33 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "context" + + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/svc" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/types" + + "github.com/zeromicro/go-zero/core/logx" +) + +type ListSpeakersByMeetingLogic struct { + logx.Logger + ctx context.Context + svcCtx *svc.ServiceContext +} + +func NewListSpeakersByMeetingLogic(ctx context.Context, svcCtx *svc.ServiceContext) *ListSpeakersByMeetingLogic { + return &ListSpeakersByMeetingLogic{ + Logger: logx.WithContext(ctx), + ctx: ctx, + svcCtx: svcCtx, + } +} + +func (l *ListSpeakersByMeetingLogic) ListSpeakersByMeeting(req *types.ListSpeakersByMeetingReq) (resp *types.ListSpeakersByMeetingResp, err error) { + // todo: add your logic here and delete this line + + return +} diff --git a/server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/updatespeakerlogic.go b/server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/updatespeakerlogic.go new file mode 100644 index 00000000..c64ada48 --- /dev/null +++ b/server/.ã/internal/meetingspeaker/internal/model/internal/logic/meeting_speaker/updatespeakerlogic.go @@ -0,0 +1,33 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "context" + + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/svc" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/types" + + "github.com/zeromicro/go-zero/core/logx" +) + +type UpdateSpeakerLogic struct { + logx.Logger + ctx context.Context + svcCtx *svc.ServiceContext +} + +func NewUpdateSpeakerLogic(ctx context.Context, svcCtx *svc.ServiceContext) *UpdateSpeakerLogic { + return &UpdateSpeakerLogic{ + Logger: logx.WithContext(ctx), + ctx: ctx, + svcCtx: svcCtx, + } +} + +func (l *UpdateSpeakerLogic) UpdateSpeaker(req *types.UpdateSpeakerReq) (resp *types.UpdateSpeakerResp, err error) { + // todo: add your logic here and delete this line + + return +} diff --git a/server/.ã/internal/meetingspeaker/internal/model/internal/svc/servicecontext.go b/server/.ã/internal/meetingspeaker/internal/model/internal/svc/servicecontext.go new file mode 100644 index 00000000..ed6c0cd5 --- /dev/null +++ b/server/.ã/internal/meetingspeaker/internal/model/internal/svc/servicecontext.go @@ -0,0 +1,18 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package svc + +import ( + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/config" +) + +type ServiceContext struct { + Config config.Config +} + +func NewServiceContext(c config.Config) *ServiceContext { + return &ServiceContext{ + Config: c, + } +} diff --git a/server/.ã/internal/meetingspeaker/internal/model/internal/types/types.go b/server/.ã/internal/meetingspeaker/internal/model/internal/types/types.go new file mode 100644 index 00000000..a393fbaf --- /dev/null +++ b/server/.ã/internal/meetingspeaker/internal/model/internal/types/types.go @@ -0,0 +1,72 @@ +// Code generated by goctl. DO NOT EDIT. +// goctl 1.9.1 + +package types + +type CreateSpeakerReq struct { + MeetingId int64 `json:"meeting_id" validate:"required,min=1"` // 关联会议ID(必填,需存在对应的会议) + Name string `json:"name" validate:"required,min=1,max=100"` // 嘉宾姓名(必填,长度限制) + Title string `json:"title,omitempty" validate:"max=200"` // 嘉宾头衔(可选,最长200字) + Avatar string `json:"avatar,omitempty" validate:"max=512"` // 头像URL(可选,最长512字符) + Intro string `json:"intro,omitempty"` // 嘉宾简介(可选,长文本) + Sort int `json:"sort,omitempty" validate:"min=0"` // 排序(可选,默认0,非负整数) +} + +type CreateSpeakerResp struct { + Msg string `json:"message"` // 操作提示(如:"嘉宾创建成功") + SpeakerId int64 `json:"speaker_id"` // 新增嘉宾的ID +} + +type DeleteSpeakerReq struct { + Id int64 `path:"id" validate:"required,min=1"` // 嘉宾ID(从路径参数获取,必填) +} + +type DeleteSpeakerResp struct { + Msg string `json:"message"` // 操作提示(如:"嘉宾已删除") +} + +type GetSpeakerReq struct { + Id int64 `path:"id" validate:"required,min=1"` // 嘉宾ID(从路径参数获取,必填) +} + +type GetSpeakerResp struct { + Msg string `json:"message"` // 操作提示 + Speaker *SpeakerDetail `json:"speaker"` // 嘉宾详情(查询成功返回) +} + +type ListSpeakersByMeetingReq struct { + MeetingId int64 `path:"meetingId" validate:"required,min=1"` // 会议ID(从路径参数获取,必填) + Page int `query:"page" validate:"min=1"` // 页码(默认1) + PageSize int `query:"page_size" validate:"min=1,max=100"` // 每页条数(默认10,最大100) +} + +type ListSpeakersByMeetingResp struct { + Msg string `json:"message"` // 操作提示 + Total int64 `json:"total"` // 该会议下的嘉宾总数 + Speakers []*SpeakerDetail `json:"speakers"` // 嘉宾列表(当前页数据,按sort升序排列) +} + +type SpeakerDetail struct { + Id int64 `json:"id"` // 嘉宾ID(主键) + MeetingId int64 `json:"meeting_id"` // 关联会议ID(外键) + Name string `json:"name"` // 嘉宾姓名 + Title string `json:"title"` // 嘉宾头衔 + Avatar string `json:"avatar"` // 嘉宾头像URL + Intro string `json:"intro"` // 嘉宾简介 + Sort int `json:"sort"` // 排序(数字越小越靠前) + IsDelete int `json:"is_delete"` // 软删除标识(0-未删,1-已删) +} + +type UpdateSpeakerReq struct { + Id int64 `json:"id" validate:"required,min=1"` // 嘉宾ID(必填,定位要更新的记录) + MeetingId int64 `json:"meeting_id,omitempty" validate:"min=1"` // 关联会议ID(可选,不填则不更新) + Name string `json:"name,omitempty" validate:"min=1,max=100"` // 嘉宾姓名(可选,更新时需非空) + Title string `json:"title,omitempty" validate:"max=200"` // 嘉宾头衔(可选) + Avatar string `json:"avatar,omitempty" validate:"max=512"` // 头像URL(可选) + Intro string `json:"intro,omitempty"` // 嘉宾简介(可选) + Sort int `json:"sort,omitempty" validate:"min=0"` // 排序(可选) +} + +type UpdateSpeakerResp struct { + Msg string `json:"message"` // 操作提示(如:"嘉宾信息更新成功") +} diff --git a/server/.ã/internal/meetingspeaker/internal/model/meetingspeakerapi.go b/server/.ã/internal/meetingspeaker/internal/model/meetingspeakerapi.go new file mode 100644 index 00000000..ec8ca755 --- /dev/null +++ b/server/.ã/internal/meetingspeaker/internal/model/meetingspeakerapi.go @@ -0,0 +1,34 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package main + +import ( + "flag" + "fmt" + + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/config" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/handler" + "github.com/JACKYMYPERSON/hldrCenter/.ã/internal/meetingspeaker/internal/model/internal/svc" + + "github.com/zeromicro/go-zero/core/conf" + "github.com/zeromicro/go-zero/rest" +) + +var configFile = flag.String("f", "etc/meetingspeakerapi.yaml", "the config file") + +func main() { + flag.Parse() + + var c config.Config + conf.MustLoad(*configFile, &c) + + server := rest.MustNewServer(c.RestConf) + defer server.Stop() + + ctx := svc.NewServiceContext(c) + handler.RegisterHandlers(server, ctx) + + fmt.Printf("Starting server at %s:%d...\n", c.Host, c.Port) + server.Start() +} diff --git a/server/go.mod b/server/go.mod index 6326aa2f..eac80025 100644 --- a/server/go.mod +++ b/server/go.mod @@ -6,7 +6,7 @@ require ( github.com/aliyun/aliyun-oss-go-sdk v3.0.2+incompatible github.com/gin-gonic/gin v1.11.0 github.com/go-playground/validator/v10 v10.28.0 - github.com/zeromicro/go-zero v1.9.1 + github.com/zeromicro/go-zero v1.9.2 gopkg.in/yaml.v3 v3.0.1 ) @@ -16,57 +16,56 @@ require ( github.com/bytedance/gopkg v0.1.3 // indirect github.com/bytedance/sonic v1.14.1 // indirect github.com/bytedance/sonic/loader v0.3.0 // indirect - github.com/cenkalti/backoff/v4 v4.3.0 // indirect + github.com/cenkalti/backoff/v5 v5.0.3 // indirect github.com/cespare/xxhash/v2 v2.3.0 // indirect github.com/cloudwego/base64x v0.1.6 // indirect github.com/fatih/color v1.18.0 // indirect github.com/gabriel-vasile/mimetype v1.4.10 // indirect github.com/gin-contrib/sse v1.1.0 // indirect - github.com/go-logr/logr v1.4.2 // indirect + github.com/go-logr/logr v1.4.3 // indirect github.com/go-logr/stdr v1.2.2 // indirect github.com/go-playground/locales v0.14.1 // indirect github.com/go-playground/universal-translator v0.18.1 // indirect - github.com/go-sql-driver/mysql v1.9.0 // indirect + github.com/go-sql-driver/mysql v1.9.3 // indirect github.com/goccy/go-json v0.10.5 // indirect github.com/goccy/go-yaml v1.18.0 // indirect - github.com/golang-jwt/jwt/v4 v4.5.2 // indirect github.com/google/uuid v1.6.0 // indirect - github.com/grafana/pyroscope-go v1.2.7 // indirect - github.com/grafana/pyroscope-go/godeltaprof v0.1.9 // indirect - github.com/grpc-ecosystem/grpc-gateway/v2 v2.20.0 // indirect + github.com/grpc-ecosystem/grpc-gateway/v2 v2.27.3 // indirect github.com/json-iterator/go v1.1.12 // indirect - github.com/klauspost/compress v1.17.11 // indirect + github.com/klauspost/compress v1.18.1 // indirect github.com/klauspost/cpuid/v2 v2.3.0 // indirect github.com/leodido/go-urn v1.4.0 // indirect - github.com/mattn/go-colorable v0.1.13 // indirect + github.com/mattn/go-colorable v0.1.14 // indirect github.com/mattn/go-isatty v0.0.20 // indirect github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect github.com/modern-go/reflect2 v1.0.2 // indirect github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 // indirect github.com/openzipkin/zipkin-go v0.4.3 // indirect github.com/pelletier/go-toml/v2 v2.2.4 // indirect - github.com/prometheus/client_golang v1.21.1 // indirect - github.com/prometheus/client_model v0.6.1 // indirect - github.com/prometheus/common v0.62.0 // indirect - github.com/prometheus/procfs v0.15.1 // indirect + github.com/prometheus/client_golang v1.23.2 // indirect + github.com/prometheus/client_model v0.6.2 // indirect + github.com/prometheus/common v0.67.2 // indirect + github.com/prometheus/procfs v0.19.1 // indirect github.com/quic-go/qpack v0.5.1 // indirect github.com/quic-go/quic-go v0.55.0 // indirect github.com/spaolacci/murmur3 v1.1.0 // indirect github.com/twitchyliquid64/golang-asm v0.15.1 // indirect github.com/ugorji/go/codec v1.3.0 // indirect - go.opentelemetry.io/otel v1.24.0 // indirect + go.opentelemetry.io/auto/sdk v1.2.1 // indirect + go.opentelemetry.io/otel v1.38.0 // indirect go.opentelemetry.io/otel/exporters/jaeger v1.17.0 // indirect - go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.24.0 // indirect - go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.24.0 // indirect - go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.24.0 // indirect - go.opentelemetry.io/otel/exporters/stdout/stdouttrace v1.24.0 // indirect - go.opentelemetry.io/otel/exporters/zipkin v1.24.0 // indirect - go.opentelemetry.io/otel/metric v1.24.0 // indirect - go.opentelemetry.io/otel/sdk v1.24.0 // indirect - go.opentelemetry.io/otel/trace v1.24.0 // indirect - go.opentelemetry.io/proto/otlp v1.3.1 // indirect + go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.38.0 // indirect + go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.38.0 // indirect + go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.38.0 // indirect + go.opentelemetry.io/otel/exporters/stdout/stdouttrace v1.38.0 // indirect + go.opentelemetry.io/otel/exporters/zipkin v1.38.0 // indirect + go.opentelemetry.io/otel/metric v1.38.0 // indirect + go.opentelemetry.io/otel/sdk v1.38.0 // indirect + go.opentelemetry.io/otel/trace v1.38.0 // indirect + go.opentelemetry.io/proto/otlp v1.8.0 // indirect go.uber.org/automaxprocs v1.6.0 // indirect go.uber.org/mock v0.6.0 // indirect + go.yaml.in/yaml/v2 v2.4.3 // indirect golang.org/x/arch v0.22.0 // indirect golang.org/x/crypto v0.43.0 // indirect golang.org/x/mod v0.29.0 // indirect @@ -76,9 +75,9 @@ require ( golang.org/x/text v0.30.0 // indirect golang.org/x/time v0.13.0 // indirect golang.org/x/tools v0.38.0 // indirect - google.golang.org/genproto/googleapis/api v0.0.0-20240711142825-46eb208f015d // indirect - google.golang.org/genproto/googleapis/rpc v0.0.0-20240701130421-f6361c86f094 // indirect - google.golang.org/grpc v1.65.0 // indirect + google.golang.org/genproto/googleapis/api v0.0.0-20251022142026-3a174f9686a8 // indirect + google.golang.org/genproto/googleapis/rpc v0.0.0-20251022142026-3a174f9686a8 // indirect + google.golang.org/grpc v1.76.0 // indirect google.golang.org/protobuf v1.36.10 // indirect gopkg.in/yaml.v2 v2.4.0 // indirect ) diff --git a/server/go.sum b/server/go.sum index acc0b6b3..cf45d814 100644 --- a/server/go.sum +++ b/server/go.sum @@ -12,8 +12,8 @@ github.com/bytedance/sonic v1.14.1 h1:FBMC0zVz5XUmE4z9wF4Jey0An5FueFvOsTKKKtwIl7 github.com/bytedance/sonic v1.14.1/go.mod h1:gi6uhQLMbTdeP0muCnrjHLeCUPyb70ujhnNlhOylAFc= github.com/bytedance/sonic/loader v0.3.0 h1:dskwH8edlzNMctoruo8FPTJDF3vLtDT0sXZwvZJyqeA= github.com/bytedance/sonic/loader v0.3.0/go.mod h1:N8A3vUdtUebEY2/VQC0MyhYeKUFosQU6FxH2JmUe6VI= -github.com/cenkalti/backoff/v4 v4.3.0 h1:MyRJ/UdXutAwSAT+s3wNd7MfTIcy71VQueUuFK343L8= -github.com/cenkalti/backoff/v4 v4.3.0/go.mod h1:Y3VNntkOUPxTVeUxJ/G5vcM//AlwfmyYozVcomhLiZE= +github.com/cenkalti/backoff/v5 v5.0.3 h1:ZN+IMa753KfX5hd8vVaMixjnqRZ3y8CuJKRKj1xcsSM= +github.com/cenkalti/backoff/v5 v5.0.3/go.mod h1:rkhZdG3JZukswDf7f0cwqPNk4K0sa+F97BxZthm/crw= github.com/cespare/xxhash/v2 v2.3.0 h1:UL815xU9SqsFlibzuggzjXhog7bL6oX9BbNZnL2UFvs= github.com/cespare/xxhash/v2 v2.3.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= github.com/cloudwego/base64x v0.1.6 h1:t11wG9AECkCDk5fMSoxmufanudBtJ+/HemLstXDLI2M= @@ -30,8 +30,8 @@ github.com/gin-contrib/sse v1.1.0/go.mod h1:hxRZ5gVpWMT7Z0B0gSNYqqsSCNIJMjzvm6fq github.com/gin-gonic/gin v1.11.0 h1:OW/6PLjyusp2PPXtyxKHU0RbX6I/l28FTdDlae5ueWk= github.com/gin-gonic/gin v1.11.0/go.mod h1:+iq/FyxlGzII0KHiBGjuNn4UNENUlKbGlNmc+W50Dls= github.com/go-logr/logr v1.2.2/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= -github.com/go-logr/logr v1.4.2 h1:6pFjapn8bFcIbiKo3XT4j/BhANplGihG6tvd+8rYgrY= -github.com/go-logr/logr v1.4.2/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY= +github.com/go-logr/logr v1.4.3 h1:CjnDlHq8ikf6E492q6eKboGOC0T8CDaOvkHCIg8idEI= +github.com/go-logr/logr v1.4.3/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY= github.com/go-logr/stdr v1.2.2 h1:hSWxHoqTgW2S2qGc0LTAI563KZ5YKYRhT3MFKZMbjag= github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre4VKE= github.com/go-playground/assert/v2 v2.2.0 h1:JvknZsQTYeFEAhQwI4qEt9cyV5ONwRHC+lYKSsYSR8s= @@ -42,31 +42,27 @@ github.com/go-playground/universal-translator v0.18.1 h1:Bcnm0ZwsGyWbCzImXv+pAJn github.com/go-playground/universal-translator v0.18.1/go.mod h1:xekY+UJKNuX9WP91TpwSH2VMlDf28Uj24BCp08ZFTUY= github.com/go-playground/validator/v10 v10.28.0 h1:Q7ibns33JjyW48gHkuFT91qX48KG0ktULL6FgHdG688= github.com/go-playground/validator/v10 v10.28.0/go.mod h1:GoI6I1SjPBh9p7ykNE/yj3fFYbyDOpwMn5KXd+m2hUU= -github.com/go-sql-driver/mysql v1.9.0 h1:Y0zIbQXhQKmQgTp44Y1dp3wTXcn804QoTptLZT1vtvo= -github.com/go-sql-driver/mysql v1.9.0/go.mod h1:pDetrLJeA3oMujJuvXc8RJoasr589B6A9fwzD3QMrqw= +github.com/go-sql-driver/mysql v1.9.3 h1:U/N249h2WzJ3Ukj8SowVFjdtZKfu9vlLZxjPXV1aweo= +github.com/go-sql-driver/mysql v1.9.3/go.mod h1:qn46aNg1333BRMNU69Lq93t8du/dwxI64Gl8i5p1WMU= github.com/goccy/go-json v0.10.5 h1:Fq85nIqj+gXn/S5ahsiTlK3TmC85qgirsdTP/+DeaC4= github.com/goccy/go-json v0.10.5/go.mod h1:oq7eo15ShAhp70Anwd5lgX2pLfOS3QCiwU/PULtXL6M= github.com/goccy/go-yaml v1.18.0 h1:8W7wMFS12Pcas7KU+VVkaiCng+kG8QiFeFwzFb+rwuw= github.com/goccy/go-yaml v1.18.0/go.mod h1:XBurs7gK8ATbW4ZPGKgcbrY1Br56PdM69F7LkFRi1kA= -github.com/golang-jwt/jwt/v4 v4.5.2 h1:YtQM7lnr8iZ+j5q71MGKkNw9Mn7AjHM68uc9g5fXeUI= -github.com/golang-jwt/jwt/v4 v4.5.2/go.mod h1:m21LjoU+eqJr34lmDMbreY2eSTRJ1cv77w39/MY0Ch0= +github.com/golang/protobuf v1.5.4 h1:i7eJL8qZTpSEXOPTxNKhASYpMn+8e5Q6AdndVa1dWek= +github.com/golang/protobuf v1.5.4/go.mod h1:lnTiLA8Wa4RWRcIUkrtSVa5nRhsEGBg48fD6rSs7xps= github.com/google/go-cmp v0.7.0 h1:wk8382ETsv4JYUZwIsn6YpYiWiBsYLSJiTsyBybVuN8= github.com/google/go-cmp v0.7.0/go.mod h1:pXiqmnSA92OHEEa9HXL2W4E7lf9JzCmGVUdgjX3N/iU= github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0= github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= -github.com/grafana/pyroscope-go v1.2.7 h1:VWBBlqxjyR0Cwk2W6UrE8CdcdD80GOFNutj0Kb1T8ac= -github.com/grafana/pyroscope-go v1.2.7/go.mod h1:o/bpSLiJYYP6HQtvcoVKiE9s5RiNgjYTj1DhiddP2Pc= -github.com/grafana/pyroscope-go/godeltaprof v0.1.9 h1:c1Us8i6eSmkW+Ez05d3co8kasnuOY813tbMN8i/a3Og= -github.com/grafana/pyroscope-go/godeltaprof v0.1.9/go.mod h1:2+l7K7twW49Ct4wFluZD3tZ6e0SjanjcUUBPVD/UuGU= -github.com/grpc-ecosystem/grpc-gateway/v2 v2.20.0 h1:bkypFPDjIYGfCYD5mRBvpqxfYX1YCS1PXdKYWi8FsN0= -github.com/grpc-ecosystem/grpc-gateway/v2 v2.20.0/go.mod h1:P+Lt/0by1T8bfcF3z737NnSbmxQAppXMRziHUxPOC8k= +github.com/grpc-ecosystem/grpc-gateway/v2 v2.27.3 h1:NmZ1PKzSTQbuGHw9DGPFomqkkLWMC+vZCkfs+FHv1Vg= +github.com/grpc-ecosystem/grpc-gateway/v2 v2.27.3/go.mod h1:zQrxl1YP88HQlA6i9c63DSVPFklWpGX4OWAc9bFuaH4= github.com/h2non/parth v0.0.0-20190131123155-b4df798d6542 h1:2VTzZjLZBgl62/EtslCrtky5vbi9dd7HrQPQIx6wqiw= github.com/h2non/parth v0.0.0-20190131123155-b4df798d6542/go.mod h1:Ow0tF8D4Kplbc8s8sSb3V2oUCygFHVp8gC3Dn6U4MNI= github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM= github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo= -github.com/klauspost/compress v1.17.11 h1:In6xLpyWOi1+C7tXUUWv2ot1QvBjxevKAaI6IXrJmUc= -github.com/klauspost/compress v1.17.11/go.mod h1:pMDklpSncoRMuLFrf1W9Ss9KT+0rH90U12bZKk7uwG0= +github.com/klauspost/compress v1.18.1 h1:bcSGx7UbpBqMChDtsF28Lw6v/G94LPrrbMbdC3JH2co= +github.com/klauspost/compress v1.18.1/go.mod h1:ZQFFVG+MdnR0P+l6wpXgIL4NTtwiKIdBnrBd8Nrxr+0= github.com/klauspost/cpuid/v2 v2.3.0 h1:S4CRMLnYUhGeDFDqkGriYKdfoFlDnMtqTiI/sFzhA9Y= github.com/klauspost/cpuid/v2 v2.3.0/go.mod h1:hqwkgyIinND0mEev00jJYCxPNVRVXFQeu1XKlok6oO0= github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE= @@ -77,9 +73,8 @@ github.com/kylelemons/godebug v1.1.0 h1:RPNrshWIDI6G2gRW9EHilWtl7Z6Sb1BR0xunSBf0 github.com/kylelemons/godebug v1.1.0/go.mod h1:9/0rRGxNHcop5bhtWyNeEfOS8JIWk580+fNqagV/RAw= github.com/leodido/go-urn v1.4.0 h1:WT9HwE9SGECu3lg4d/dIA+jxlljEa1/ffXKmRjqdmIQ= github.com/leodido/go-urn v1.4.0/go.mod h1:bvxc+MVxLKB4z00jd1z+Dvzr47oO32F/QSNjSBOlFxI= -github.com/mattn/go-colorable v0.1.13 h1:fFA4WZxdEF4tXPZVKMLwD8oUnCTTo08duU7wxecdEvA= -github.com/mattn/go-colorable v0.1.13/go.mod h1:7S9/ev0klgBDR4GtXTXX8a3vIGJpMovkB8vQcUbaXHg= -github.com/mattn/go-isatty v0.0.16/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM= +github.com/mattn/go-colorable v0.1.14 h1:9A9LHSqF/7dyVVX6g0U9cwm9pG3kP9gSzcuIPHPsaIE= +github.com/mattn/go-colorable v0.1.14/go.mod h1:6LmQG8QLFO4G5z1gPvYEzlUgJ2wF+stgPZH1UqBm1s8= github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWEY= github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= @@ -97,20 +92,20 @@ github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZb github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= github.com/prashantv/gostub v1.1.0 h1:BTyx3RfQjRHnUWaGF9oQos79AlQ5k8WNktv7VGvVH4g= github.com/prashantv/gostub v1.1.0/go.mod h1:A5zLQHz7ieHGG7is6LLXLz7I8+3LZzsrV0P1IAHhP5U= -github.com/prometheus/client_golang v1.21.1 h1:DOvXXTqVzvkIewV/CDPFdejpMCGeMcbGCQ8YOmu+Ibk= -github.com/prometheus/client_golang v1.21.1/go.mod h1:U9NM32ykUErtVBxdvD3zfi+EuFkkaBvMb09mIfe0Zgg= -github.com/prometheus/client_model v0.6.1 h1:ZKSh/rekM+n3CeS952MLRAdFwIKqeY8b62p8ais2e9E= -github.com/prometheus/client_model v0.6.1/go.mod h1:OrxVMOVHjw3lKMa8+x6HeMGkHMQyHDk9E3jmP2AmGiY= -github.com/prometheus/common v0.62.0 h1:xasJaQlnWAeyHdUBeGjXmutelfJHWMRr+Fg4QszZ2Io= -github.com/prometheus/common v0.62.0/go.mod h1:vyBcEuLSvWos9B1+CyL7JZ2up+uFzXhkqml0W5zIY1I= -github.com/prometheus/procfs v0.15.1 h1:YagwOFzUgYfKKHX6Dr+sHT7km/hxC76UB0learggepc= -github.com/prometheus/procfs v0.15.1/go.mod h1:fB45yRUv8NstnjriLhBQLuOUt+WW4BsoGhij/e3PBqk= +github.com/prometheus/client_golang v1.23.2 h1:Je96obch5RDVy3FDMndoUsjAhG5Edi49h0RJWRi/o0o= +github.com/prometheus/client_golang v1.23.2/go.mod h1:Tb1a6LWHB3/SPIzCoaDXI4I8UHKeFTEQ1YCr+0Gyqmg= +github.com/prometheus/client_model v0.6.2 h1:oBsgwpGs7iVziMvrGhE53c/GrLUsZdHnqNwqPLxwZyk= +github.com/prometheus/client_model v0.6.2/go.mod h1:y3m2F6Gdpfy6Ut/GBsUqTWZqCUvMVzSfMLjcu6wAwpE= +github.com/prometheus/common v0.67.2 h1:PcBAckGFTIHt2+L3I33uNRTlKTplNzFctXcWhPyAEN8= +github.com/prometheus/common v0.67.2/go.mod h1:63W3KZb1JOKgcjlIr64WW/LvFGAqKPj0atm+knVGEko= +github.com/prometheus/procfs v0.19.1 h1:QVtROpTkphuXuNlnCv3m1ut3JytkXHtQ3xvck/YmzMM= +github.com/prometheus/procfs v0.19.1/go.mod h1:M0aotyiemPhBCM0z5w87kL22CxfcH05ZpYlu+b4J7mw= github.com/quic-go/qpack v0.5.1 h1:giqksBPnT/HDtZ6VhtFKgoLOWmlyo9Ei6u9PqzIMbhI= github.com/quic-go/qpack v0.5.1/go.mod h1:+PC4XFrEskIVkcLzpEkbLqq1uCoxPhQuvK5rH1ZgaEg= github.com/quic-go/quic-go v0.55.0 h1:zccPQIqYCXDt5NmcEabyYvOnomjs8Tlwl7tISjJh9Mk= github.com/quic-go/quic-go v0.55.0/go.mod h1:DR51ilwU1uE164KuWXhinFcKWGlEjzys2l8zUl5Ss1U= -github.com/rogpeppe/go-internal v1.10.0 h1:TMyTOH3F/DB16zRVcYyreMH6GnZZrwQVAoYjRBZyWFQ= -github.com/rogpeppe/go-internal v1.10.0/go.mod h1:UQnix2H7Ngw/k4C5ijL5+65zddjncjaFoBhdsK/akog= +github.com/rogpeppe/go-internal v1.14.1 h1:UQB4HGPB6osV0SQTLymcB4TgvyWu6ZyliaW0tI/otEQ= +github.com/rogpeppe/go-internal v1.14.1/go.mod h1:MaRKkUm5W0goXpeCfT7UZI6fk/L7L7so1lCWt35ZSgc= github.com/spaolacci/murmur3 v1.1.0 h1:7c1g84S4BPRrfL5Xrdp6fOJ206sU9y293DDHaoy0bLI= github.com/spaolacci/murmur3 v1.1.0/go.mod h1:JwIasOWyU6f++ZhiEuf87xNszmSA2myDM2Kzu9HwQUA= github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= @@ -128,36 +123,42 @@ github.com/twitchyliquid64/golang-asm v0.15.1 h1:SU5vSMR7hnwNxj24w34ZyCi/FmDZTkS github.com/twitchyliquid64/golang-asm v0.15.1/go.mod h1:a1lVb/DtPvCB8fslRZhAngC2+aY1QWCk3Cedj/Gdt08= github.com/ugorji/go/codec v1.3.0 h1:Qd2W2sQawAfG8XSvzwhBeoGq71zXOC/Q1E9y/wUcsUA= github.com/ugorji/go/codec v1.3.0/go.mod h1:pRBVtBSKl77K30Bv8R2P+cLSGaTtex6fsA2Wjqmfxj4= -github.com/zeromicro/go-zero v1.9.1 h1:GZCl4jun/ZgZHnSvX3SSNDHf+tEGmEQ8x2Z23xjHa9g= -github.com/zeromicro/go-zero v1.9.1/go.mod h1:bHOl7Xr7EV/iHZWEqsUNJwFc/9WgAMrPpPagYvOaMtY= -go.opentelemetry.io/otel v1.24.0 h1:0LAOdjNmQeSTzGBzduGe/rU4tZhMwL5rWgtp9Ku5Jfo= -go.opentelemetry.io/otel v1.24.0/go.mod h1:W7b9Ozg4nkF5tWI5zsXkaKKDjdVjpD4oAt9Qi/MArHo= +github.com/zeromicro/go-zero v1.9.2 h1:ZXOXBIcazZ1pWAMiHyVnDQ3Sxwy7DYPzjE89Qtj9vqM= +github.com/zeromicro/go-zero v1.9.2/go.mod h1:k8YBMEFZKjTd4q/qO5RCW+zDgUlNyAs5vue3P4/Kmn0= +go.opentelemetry.io/auto/sdk v1.2.1 h1:jXsnJ4Lmnqd11kwkBV2LgLoFMZKizbCi5fNZ/ipaZ64= +go.opentelemetry.io/auto/sdk v1.2.1/go.mod h1:KRTj+aOaElaLi+wW1kO/DZRXwkF4C5xPbEe3ZiIhN7Y= +go.opentelemetry.io/otel v1.38.0 h1:RkfdswUDRimDg0m2Az18RKOsnI8UDzppJAtj01/Ymk8= +go.opentelemetry.io/otel v1.38.0/go.mod h1:zcmtmQ1+YmQM9wrNsTGV/q/uyusom3P8RxwExxkZhjM= go.opentelemetry.io/otel/exporters/jaeger v1.17.0 h1:D7UpUy2Xc2wsi1Ras6V40q806WM07rqoCWzXu7Sqy+4= go.opentelemetry.io/otel/exporters/jaeger v1.17.0/go.mod h1:nPCqOnEH9rNLKqH/+rrUjiMzHJdV1BlpKcTwRTyKkKI= -go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.24.0 h1:t6wl9SPayj+c7lEIFgm4ooDBZVb01IhLB4InpomhRw8= -go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.24.0/go.mod h1:iSDOcsnSA5INXzZtwaBPrKp/lWu/V14Dd+llD0oI2EA= -go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.24.0 h1:Mw5xcxMwlqoJd97vwPxA8isEaIoxsta9/Q51+TTJLGE= -go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.24.0/go.mod h1:CQNu9bj7o7mC6U7+CA/schKEYakYXWr79ucDHTMGhCM= -go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.24.0 h1:Xw8U6u2f8DK2XAkGRFV7BBLENgnTGX9i4rQRxJf+/vs= -go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.24.0/go.mod h1:6KW1Fm6R/s6Z3PGXwSJN2K4eT6wQB3vXX6CVnYX9NmM= -go.opentelemetry.io/otel/exporters/stdout/stdouttrace v1.24.0 h1:s0PHtIkN+3xrbDOpt2M8OTG92cWqUESvzh2MxiR5xY8= -go.opentelemetry.io/otel/exporters/stdout/stdouttrace v1.24.0/go.mod h1:hZlFbDbRt++MMPCCfSJfmhkGIWnX1h3XjkfxZUjLrIA= -go.opentelemetry.io/otel/exporters/zipkin v1.24.0 h1:3evrL5poBuh1KF51D9gO/S+N/1msnm4DaBqs/rpXUqY= -go.opentelemetry.io/otel/exporters/zipkin v1.24.0/go.mod h1:0EHgD8R0+8yRhUYJOGR8Hfg2dpiJQxDOszd5smVO9wM= -go.opentelemetry.io/otel/metric v1.24.0 h1:6EhoGWWK28x1fbpA4tYTOWBkPefTDQnb8WSGXlc88kI= -go.opentelemetry.io/otel/metric v1.24.0/go.mod h1:VYhLe1rFfxuTXLgj4CBiyz+9WYBA8pNGJgDcSFRKBco= -go.opentelemetry.io/otel/sdk v1.24.0 h1:YMPPDNymmQN3ZgczicBY3B6sf9n62Dlj9pWD3ucgoDw= -go.opentelemetry.io/otel/sdk v1.24.0/go.mod h1:KVrIYw6tEubO9E96HQpcmpTKDVn9gdv35HoYiQWGDFg= -go.opentelemetry.io/otel/trace v1.24.0 h1:CsKnnL4dUAr/0llH9FKuc698G04IrpWV0MQA/Y1YELI= -go.opentelemetry.io/otel/trace v1.24.0/go.mod h1:HPc3Xr/cOApsBI154IU0OI0HJexz+aw5uPdbs3UCjNU= -go.opentelemetry.io/proto/otlp v1.3.1 h1:TrMUixzpM0yuc/znrFTP9MMRh8trP93mkCiDVeXrui0= -go.opentelemetry.io/proto/otlp v1.3.1/go.mod h1:0X1WI4de4ZsLrrJNLAQbFeLCm3T7yBkR0XqQ7niQU+8= +go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.38.0 h1:GqRJVj7UmLjCVyVJ3ZFLdPRmhDUp2zFmQe3RHIOsw24= +go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.38.0/go.mod h1:ri3aaHSmCTVYu2AWv44YMauwAQc0aqI9gHKIcSbI1pU= +go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.38.0 h1:lwI4Dc5leUqENgGuQImwLo4WnuXFPetmPpkLi2IrX54= +go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.38.0/go.mod h1:Kz/oCE7z5wuyhPxsXDuaPteSWqjSBD5YaSdbxZYGbGk= +go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.38.0 h1:aTL7F04bJHUlztTsNGJ2l+6he8c+y/b//eR0jjjemT4= +go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.38.0/go.mod h1:kldtb7jDTeol0l3ewcmd8SDvx3EmIE7lyvqbasU3QC4= +go.opentelemetry.io/otel/exporters/stdout/stdouttrace v1.38.0 h1:kJxSDN4SgWWTjG/hPp3O7LCGLcHXFlvS2/FFOrwL+SE= +go.opentelemetry.io/otel/exporters/stdout/stdouttrace v1.38.0/go.mod h1:mgIOzS7iZeKJdeB8/NYHrJ48fdGc71Llo5bJ1J4DWUE= +go.opentelemetry.io/otel/exporters/zipkin v1.38.0 h1:0rJ2TmzpHDG+Ib9gPmu3J3cE0zXirumQcKS4wCoZUa0= +go.opentelemetry.io/otel/exporters/zipkin v1.38.0/go.mod h1:Su/nq/K5zRjDKKC3Il0xbViE3juWgG3JDoqLumFx5G0= +go.opentelemetry.io/otel/metric v1.38.0 h1:Kl6lzIYGAh5M159u9NgiRkmoMKjvbsKtYRwgfrA6WpA= +go.opentelemetry.io/otel/metric v1.38.0/go.mod h1:kB5n/QoRM8YwmUahxvI3bO34eVtQf2i4utNVLr9gEmI= +go.opentelemetry.io/otel/sdk v1.38.0 h1:l48sr5YbNf2hpCUj/FoGhW9yDkl+Ma+LrVl8qaM5b+E= +go.opentelemetry.io/otel/sdk v1.38.0/go.mod h1:ghmNdGlVemJI3+ZB5iDEuk4bWA3GkTpW+DOoZMYBVVg= +go.opentelemetry.io/otel/sdk/metric v1.38.0 h1:aSH66iL0aZqo//xXzQLYozmWrXxyFkBJ6qT5wthqPoM= +go.opentelemetry.io/otel/sdk/metric v1.38.0/go.mod h1:dg9PBnW9XdQ1Hd6ZnRz689CbtrUp0wMMs9iPcgT9EZA= +go.opentelemetry.io/otel/trace v1.38.0 h1:Fxk5bKrDZJUH+AMyyIXGcFAPah0oRcT+LuNtJrmcNLE= +go.opentelemetry.io/otel/trace v1.38.0/go.mod h1:j1P9ivuFsTceSWe1oY+EeW3sc+Pp42sO++GHkg4wwhs= +go.opentelemetry.io/proto/otlp v1.8.0 h1:fRAZQDcAFHySxpJ1TwlA1cJ4tvcrw7nXl9xWWC8N5CE= +go.opentelemetry.io/proto/otlp v1.8.0/go.mod h1:tIeYOeNBU4cvmPqpaji1P+KbB4Oloai8wN4rWzRrFF0= go.uber.org/automaxprocs v1.6.0 h1:O3y2/QNTOdbF+e/dpXNNW7Rx2hZ4sTIPyybbxyNqTUs= go.uber.org/automaxprocs v1.6.0/go.mod h1:ifeIMSnPZuznNm6jmdzmU3/bfk01Fe2fotchwEFJ8r8= go.uber.org/goleak v1.3.0 h1:2K3zAYmnTNqV73imy9J1T3WC+gmCePx2hEGkimedGto= go.uber.org/goleak v1.3.0/go.mod h1:CoHD4mav9JJNrW/WLlf7HGZPjdw8EucARQHekz1X6bE= go.uber.org/mock v0.6.0 h1:hyF9dfmbgIX5EfOdasqLsWD6xqpNZlXblLB/Dbnwv3Y= go.uber.org/mock v0.6.0/go.mod h1:KiVJ4BqZJaMj4svdfmHM0AUx4NJYO8ZNpPnZn1Z+BBU= +go.yaml.in/yaml/v2 v2.4.3 h1:6gvOSjQoTB3vt1l+CU+tSyi/HOjfOjRLJ4YwYZGwRO0= +go.yaml.in/yaml/v2 v2.4.3/go.mod h1:zSxWcmIDjOzPXpjlTTbAsKokqkDNAVtZO0WOMiT90s8= golang.org/x/arch v0.22.0 h1:c/Zle32i5ttqRXjdLyyHZESLD/bB90DCU1g9l/0YBDI= golang.org/x/arch v0.22.0/go.mod h1:dNHoOeKiyja7GTvF9NJS1l3Z2yntpQNzgrjh1cU103A= golang.org/x/crypto v0.43.0 h1:dduJYIi3A3KOfdGOHX8AVZ/jGiyPa3IbBozJ5kNuE04= @@ -168,7 +169,6 @@ golang.org/x/net v0.46.0 h1:giFlY12I07fugqwPuWJi68oOnpfqFnJIJzaIIm2JVV4= golang.org/x/net v0.46.0/go.mod h1:Q9BGdFy1y4nkUwiLvT5qtyhAnEHgnQ/zd8PfU6nc210= golang.org/x/sync v0.17.0 h1:l60nONMj9l5drqw6jlhIELNv9I0A4OFgRsG9k2oT9Ug= golang.org/x/sync v0.17.0/go.mod h1:9KTHXmSnoGruLpwFjVSX0lNNA75CykiMECbovNTZqGI= -golang.org/x/sys v0.0.0-20220811171246-fbc7d0a398ab/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.37.0 h1:fdNQudmxPjkdUTPnLn5mdQv7Zwvbvpaxqs831goi9kQ= golang.org/x/sys v0.37.0/go.mod h1:OgkHotnGiDImocRcuBABYBEXf8A9a87e/uXjp9XT3ks= @@ -178,12 +178,14 @@ golang.org/x/time v0.13.0 h1:eUlYslOIt32DgYD6utsuUeHs4d7AsEYLuIAdg7FlYgI= golang.org/x/time v0.13.0/go.mod h1:eL/Oa2bBBK0TkX57Fyni+NgnyQQN4LitPmob2Hjnqw4= golang.org/x/tools v0.38.0 h1:Hx2Xv8hISq8Lm16jvBZ2VQf+RLmbd7wVUsALibYI/IQ= golang.org/x/tools v0.38.0/go.mod h1:yEsQ/d/YK8cjh0L6rZlY8tgtlKiBNTL14pGDJPJpYQs= -google.golang.org/genproto/googleapis/api v0.0.0-20240711142825-46eb208f015d h1:kHjw/5UfflP/L5EbledDrcG4C2597RtymmGRZvHiCuY= -google.golang.org/genproto/googleapis/api v0.0.0-20240711142825-46eb208f015d/go.mod h1:mw8MG/Qz5wfgYr6VqVCiZcHe/GJEfI+oGGDCohaVgB0= -google.golang.org/genproto/googleapis/rpc v0.0.0-20240701130421-f6361c86f094 h1:BwIjyKYGsK9dMCBOorzRri8MQwmi7mT9rGHsCEinZkA= -google.golang.org/genproto/googleapis/rpc v0.0.0-20240701130421-f6361c86f094/go.mod h1:Ue6ibwXGpU+dqIcODieyLOcgj7z8+IcskoNIgZxtrFY= -google.golang.org/grpc v1.65.0 h1:bs/cUb4lp1G5iImFFd3u5ixQzweKizoZJAwBNLR42lc= -google.golang.org/grpc v1.65.0/go.mod h1:WgYC2ypjlB0EiQi6wdKixMqukr6lBc0Vo+oOgjrM5ZQ= +gonum.org/v1/gonum v0.16.0 h1:5+ul4Swaf3ESvrOnidPp4GZbzf0mxVQpDCYUQE7OJfk= +gonum.org/v1/gonum v0.16.0/go.mod h1:fef3am4MQ93R2HHpKnLk4/Tbh/s0+wqD5nfa6Pnwy4E= +google.golang.org/genproto/googleapis/api v0.0.0-20251022142026-3a174f9686a8 h1:mepRgnBZa07I4TRuomDE4sTIYieg/osKmzIf4USdWS4= +google.golang.org/genproto/googleapis/api v0.0.0-20251022142026-3a174f9686a8/go.mod h1:fDMmzKV90WSg1NbozdqrE64fkuTv6mlq2zxo9ad+3yo= +google.golang.org/genproto/googleapis/rpc v0.0.0-20251022142026-3a174f9686a8 h1:M1rk8KBnUsBDg1oPGHNCxG4vc1f49epmTO7xscSajMk= +google.golang.org/genproto/googleapis/rpc v0.0.0-20251022142026-3a174f9686a8/go.mod h1:7i2o+ce6H/6BluujYR+kqX3GKH+dChPTQU19wjRPiGk= +google.golang.org/grpc v1.76.0 h1:UnVkv1+uMLYXoIz6o7chp59WfQUYA2ex/BXQ9rHZu7A= +google.golang.org/grpc v1.76.0/go.mod h1:Ju12QI8M6iQJtbcsV+awF5a4hfJMLi4X0JLo94ULZ6c= google.golang.org/protobuf v1.36.10 h1:AYd7cD/uASjIL6Q9LiTjz8JLcrh/88q5UObnmY3aOOE= google.golang.org/protobuf v1.36.10/go.mod h1:HTf+CrKn2C3g5S8VImy6tdcUvCska2kB7j23XfzDpco= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= diff --git a/server/internal/meetingspeaker/handler/meeting_speaker/createspeakerhandler.go b/server/internal/meetingspeaker/handler/meeting_speaker/createspeakerhandler.go new file mode 100644 index 00000000..24075e11 --- /dev/null +++ b/server/internal/meetingspeaker/handler/meeting_speaker/createspeakerhandler.go @@ -0,0 +1,50 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "fmt" + "net/http" + + "github.com/JACKYMYPERSON/hldrCenter/config" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/logic/meeting_speaker" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/model" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/types" + "github.com/zeromicro/go-zero/core/stores/sqlx" + "github.com/zeromicro/go-zero/rest/httpx" +) + +func CreateSpeakerHandler(cfg *config.Config) http.HandlerFunc { + return func(w http.ResponseWriter, r *http.Request) { + var req types.CreateSpeakerReq + if err := httpx.Parse(r, &req); err != nil { + httpx.ErrorCtx(r.Context(), w, err) + return + } + + mysqlCfg := cfg.MySQL + dsn := fmt.Sprintf( + "%s:%s@tcp(%s:%d)/%s?charset=%s&parseTime=true&loc=Local", + mysqlCfg.Username, + mysqlCfg.Password, + mysqlCfg.Host, + mysqlCfg.Port, + mysqlCfg.Database, + mysqlCfg.Charset, + ) + fmt.Println("接收到articlePost请求") + + conn := sqlx.NewSqlConn("mysql", dsn) + + speakerModel := model.NewMeetingSpeakerModel(conn) + + l := meeting_speaker.NewCreateSpeakerLogic(r.Context(), cfg, speakerModel) + resp, err := l.CreateSpeaker(&req) + if err != nil { + httpx.ErrorCtx(r.Context(), w, err) + } else { + httpx.OkJsonCtx(r.Context(), w, resp) + } + } +} diff --git a/server/internal/meetingspeaker/handler/meeting_speaker/deletespeakerhandler.go b/server/internal/meetingspeaker/handler/meeting_speaker/deletespeakerhandler.go new file mode 100644 index 00000000..d6859c72 --- /dev/null +++ b/server/internal/meetingspeaker/handler/meeting_speaker/deletespeakerhandler.go @@ -0,0 +1,49 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "fmt" + "net/http" + + "github.com/JACKYMYPERSON/hldrCenter/config" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/logic/meeting_speaker" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/model" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/types" + "github.com/zeromicro/go-zero/core/stores/sqlx" + "github.com/zeromicro/go-zero/rest/httpx" +) + +func DeleteSpeakerHandler(cfg *config.Config) http.HandlerFunc { + return func(w http.ResponseWriter, r *http.Request) { + var req types.DeleteSpeakerReq + if err := httpx.Parse(r, &req); err != nil { + httpx.ErrorCtx(r.Context(), w, err) + return + } + + mysqlCfg := cfg.MySQL + dsn := fmt.Sprintf( + "%s:%s@tcp(%s:%d)/%s?charset=%s&parseTime=true&loc=Local", + mysqlCfg.Username, + mysqlCfg.Password, + mysqlCfg.Host, + mysqlCfg.Port, + mysqlCfg.Database, + mysqlCfg.Charset, + ) + fmt.Println("接收到articlePost请求") + + conn := sqlx.NewSqlConn("mysql", dsn) + speakerModel := model.NewMeetingSpeakerModel(conn) + + l := meeting_speaker.NewDeleteSpeakerLogic(r.Context(), cfg, speakerModel) + resp, err := l.DeleteSpeaker(&req) + if err != nil { + httpx.ErrorCtx(r.Context(), w, err) + } else { + httpx.OkJsonCtx(r.Context(), w, resp) + } + } +} diff --git a/server/internal/meetingspeaker/handler/meeting_speaker/getspeakerhandler.go b/server/internal/meetingspeaker/handler/meeting_speaker/getspeakerhandler.go new file mode 100644 index 00000000..c94d52a8 --- /dev/null +++ b/server/internal/meetingspeaker/handler/meeting_speaker/getspeakerhandler.go @@ -0,0 +1,50 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "fmt" + "net/http" + + "github.com/JACKYMYPERSON/hldrCenter/config" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/logic/meeting_speaker" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/model" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/types" + "github.com/zeromicro/go-zero/core/stores/sqlx" + "github.com/zeromicro/go-zero/rest/httpx" +) + +func GetSpeakerHandler(cfg *config.Config) http.HandlerFunc { + return func(w http.ResponseWriter, r *http.Request) { + var req types.GetSpeakerReq + if err := httpx.Parse(r, &req); err != nil { + httpx.ErrorCtx(r.Context(), w, err) + return + } + + mysqlCfg := cfg.MySQL + dsn := fmt.Sprintf( + "%s:%s@tcp(%s:%d)/%s?charset=%s&parseTime=true&loc=Local", + mysqlCfg.Username, + mysqlCfg.Password, + mysqlCfg.Host, + mysqlCfg.Port, + mysqlCfg.Database, + mysqlCfg.Charset, + ) + fmt.Println("接收到articlePost请求") + + conn := sqlx.NewSqlConn("mysql", dsn) + + speakerModel := model.NewMeetingSpeakerModel(conn) + + l := meeting_speaker.NewGetSpeakerLogic(r.Context(), cfg, speakerModel) + resp, err := l.GetSpeaker(&req) + if err != nil { + httpx.ErrorCtx(r.Context(), w, err) + } else { + httpx.OkJsonCtx(r.Context(), w, resp) + } + } +} diff --git a/server/internal/meetingspeaker/handler/meeting_speaker/listspeakersbymeetinghandler.go b/server/internal/meetingspeaker/handler/meeting_speaker/listspeakersbymeetinghandler.go new file mode 100644 index 00000000..081e2db4 --- /dev/null +++ b/server/internal/meetingspeaker/handler/meeting_speaker/listspeakersbymeetinghandler.go @@ -0,0 +1,50 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "fmt" + "net/http" + + "github.com/JACKYMYPERSON/hldrCenter/config" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/logic/meeting_speaker" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/model" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/types" + "github.com/zeromicro/go-zero/core/stores/sqlx" + "github.com/zeromicro/go-zero/rest/httpx" +) + +func ListSpeakersByMeetingHandler(cfg *config.Config) http.HandlerFunc { + return func(w http.ResponseWriter, r *http.Request) { + var req types.ListSpeakersByMeetingReq + if err := httpx.Parse(r, &req); err != nil { + httpx.ErrorCtx(r.Context(), w, err) + return + } + + mysqlCfg := cfg.MySQL + dsn := fmt.Sprintf( + "%s:%s@tcp(%s:%d)/%s?charset=%s&parseTime=true&loc=Local", + mysqlCfg.Username, + mysqlCfg.Password, + mysqlCfg.Host, + mysqlCfg.Port, + mysqlCfg.Database, + mysqlCfg.Charset, + ) + fmt.Println("接收到articlePost请求") + + conn := sqlx.NewSqlConn("mysql", dsn) + + speakerModel := model.NewMeetingSpeakerModel(conn) + + l := meeting_speaker.NewListSpeakersByMeetingLogic(r.Context(), cfg, speakerModel) + resp, err := l.ListSpeakersByMeeting(&req) + if err != nil { + httpx.ErrorCtx(r.Context(), w, err) + } else { + httpx.OkJsonCtx(r.Context(), w, resp) + } + } +} diff --git a/server/internal/meetingspeaker/handler/meeting_speaker/updatespeakerhandler.go b/server/internal/meetingspeaker/handler/meeting_speaker/updatespeakerhandler.go new file mode 100644 index 00000000..6fbf5da7 --- /dev/null +++ b/server/internal/meetingspeaker/handler/meeting_speaker/updatespeakerhandler.go @@ -0,0 +1,50 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "fmt" + "net/http" + + "github.com/JACKYMYPERSON/hldrCenter/config" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/logic/meeting_speaker" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/model" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/types" + "github.com/zeromicro/go-zero/core/stores/sqlx" + "github.com/zeromicro/go-zero/rest/httpx" +) + +func UpdateSpeakerHandler(cfg *config.Config) http.HandlerFunc { + return func(w http.ResponseWriter, r *http.Request) { + var req types.UpdateSpeakerReq + if err := httpx.Parse(r, &req); err != nil { + httpx.ErrorCtx(r.Context(), w, err) + return + } + + mysqlCfg := cfg.MySQL + dsn := fmt.Sprintf( + "%s:%s@tcp(%s:%d)/%s?charset=%s&parseTime=true&loc=Local", + mysqlCfg.Username, + mysqlCfg.Password, + mysqlCfg.Host, + mysqlCfg.Port, + mysqlCfg.Database, + mysqlCfg.Charset, + ) + fmt.Println("接收到articlePost请求") + + conn := sqlx.NewSqlConn("mysql", dsn) + + speakerModel := model.NewMeetingSpeakerModel(conn) + + l := meeting_speaker.NewUpdateSpeakerLogic(r.Context(), cfg, speakerModel) + resp, err := l.UpdateSpeaker(&req) + if err != nil { + httpx.ErrorCtx(r.Context(), w, err) + } else { + httpx.OkJsonCtx(r.Context(), w, resp) + } + } +} diff --git a/server/internal/meetingspeaker/internal/logic/meeting_speaker/createspeakerlogic.go b/server/internal/meetingspeaker/internal/logic/meeting_speaker/createspeakerlogic.go new file mode 100644 index 00000000..7e2a531f --- /dev/null +++ b/server/internal/meetingspeaker/internal/logic/meeting_speaker/createspeakerlogic.go @@ -0,0 +1,36 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "context" + + "github.com/JACKYMYPERSON/hldrCenter/config" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/model" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/types" + + "github.com/zeromicro/go-zero/core/logx" +) + +type CreateSpeakerLogic struct { + logx.Logger + ctx context.Context + cfg *config.Config + model model.MeetingSpeakerModel +} + +func NewCreateSpeakerLogic(ctx context.Context, cfg *config.Config, model model.MeetingSpeakerModel) *CreateSpeakerLogic { + return &CreateSpeakerLogic{ + Logger: logx.WithContext(ctx), + ctx: ctx, + cfg: cfg, + model: model, + } +} + +func (l *CreateSpeakerLogic) CreateSpeaker(req *types.CreateSpeakerReq) (resp *types.CreateSpeakerResp, err error) { + // todo: add your logic here and delete this line + + return +} diff --git a/server/internal/meetingspeaker/internal/logic/meeting_speaker/deletespeakerlogic.go b/server/internal/meetingspeaker/internal/logic/meeting_speaker/deletespeakerlogic.go new file mode 100644 index 00000000..44330145 --- /dev/null +++ b/server/internal/meetingspeaker/internal/logic/meeting_speaker/deletespeakerlogic.go @@ -0,0 +1,36 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "context" + + "github.com/JACKYMYPERSON/hldrCenter/config" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/model" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/types" + + "github.com/zeromicro/go-zero/core/logx" +) + +type DeleteSpeakerLogic struct { + logx.Logger + ctx context.Context + cfg *config.Config + model model.MeetingSpeakerModel +} + +func NewDeleteSpeakerLogic(ctx context.Context, cfg *config.Config, model model.MeetingSpeakerModel) *DeleteSpeakerLogic { + return &DeleteSpeakerLogic{ + Logger: logx.WithContext(ctx), + ctx: ctx, + cfg: cfg, + model: model, + } +} + +func (l *DeleteSpeakerLogic) DeleteSpeaker(req *types.DeleteSpeakerReq) (resp *types.DeleteSpeakerResp, err error) { + // todo: add your logic here and delete this line + + return +} diff --git a/server/internal/meetingspeaker/internal/logic/meeting_speaker/getspeakerlogic.go b/server/internal/meetingspeaker/internal/logic/meeting_speaker/getspeakerlogic.go new file mode 100644 index 00000000..8be448ff --- /dev/null +++ b/server/internal/meetingspeaker/internal/logic/meeting_speaker/getspeakerlogic.go @@ -0,0 +1,36 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "context" + + "github.com/JACKYMYPERSON/hldrCenter/config" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/model" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/types" + + "github.com/zeromicro/go-zero/core/logx" +) + +type GetSpeakerLogic struct { + logx.Logger + ctx context.Context + cfg *config.Config + model model.MeetingSpeakerModel +} + +func NewGetSpeakerLogic(ctx context.Context, cfg *config.Config, model model.MeetingSpeakerModel) *GetSpeakerLogic { + return &GetSpeakerLogic{ + Logger: logx.WithContext(ctx), + ctx: ctx, + cfg: cfg, + model: model, + } +} + +func (l *GetSpeakerLogic) GetSpeaker(req *types.GetSpeakerReq) (resp *types.GetSpeakerResp, err error) { + // todo: add your logic here and delete this line + + return +} diff --git a/server/internal/meetingspeaker/internal/logic/meeting_speaker/listspeakersbymeetinglogic.go b/server/internal/meetingspeaker/internal/logic/meeting_speaker/listspeakersbymeetinglogic.go new file mode 100644 index 00000000..cd619df1 --- /dev/null +++ b/server/internal/meetingspeaker/internal/logic/meeting_speaker/listspeakersbymeetinglogic.go @@ -0,0 +1,36 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "context" + + "github.com/JACKYMYPERSON/hldrCenter/config" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/model" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/types" + + "github.com/zeromicro/go-zero/core/logx" +) + +type ListSpeakersByMeetingLogic struct { + logx.Logger + ctx context.Context + cfg *config.Config + model model.MeetingSpeakerModel +} + +func NewListSpeakersByMeetingLogic(ctx context.Context, cfg *config.Config, model model.MeetingSpeakerModel) *ListSpeakersByMeetingLogic { + return &ListSpeakersByMeetingLogic{ + Logger: logx.WithContext(ctx), + ctx: ctx, + cfg: cfg, + model: model, + } +} + +func (l *ListSpeakersByMeetingLogic) ListSpeakersByMeeting(req *types.ListSpeakersByMeetingReq) (resp *types.ListSpeakersByMeetingResp, err error) { + // todo: add your logic here and delete this line + + return +} diff --git a/server/internal/meetingspeaker/internal/logic/meeting_speaker/updatespeakerlogic.go b/server/internal/meetingspeaker/internal/logic/meeting_speaker/updatespeakerlogic.go new file mode 100644 index 00000000..514d5655 --- /dev/null +++ b/server/internal/meetingspeaker/internal/logic/meeting_speaker/updatespeakerlogic.go @@ -0,0 +1,36 @@ +// Code scaffolded by goctl. Safe to edit. +// goctl 1.9.1 + +package meeting_speaker + +import ( + "context" + + "github.com/JACKYMYPERSON/hldrCenter/config" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/model" + "github.com/JACKYMYPERSON/hldrCenter/internal/meetingspeaker/internal/types" + + "github.com/zeromicro/go-zero/core/logx" +) + +type UpdateSpeakerLogic struct { + logx.Logger + ctx context.Context + cfg *config.Config + model model.MeetingSpeakerModel +} + +func NewUpdateSpeakerLogic(ctx context.Context, cfg *config.Config, model model.MeetingSpeakerModel) *UpdateSpeakerLogic { + return &UpdateSpeakerLogic{ + Logger: logx.WithContext(ctx), + ctx: ctx, + cfg: cfg, + model: model, + } +} + +func (l *UpdateSpeakerLogic) UpdateSpeaker(req *types.UpdateSpeakerReq) (resp *types.UpdateSpeakerResp, err error) { + // todo: add your logic here and delete this line + + return +} diff --git a/server/internal/meetingspeaker/internal/model/meetingspeakermodel.go b/server/internal/meetingspeaker/internal/model/meetingspeakermodel.go new file mode 100644 index 00000000..fa0398d7 --- /dev/null +++ b/server/internal/meetingspeaker/internal/model/meetingspeakermodel.go @@ -0,0 +1,29 @@ +package model + +import "github.com/zeromicro/go-zero/core/stores/sqlx" + +var _ MeetingSpeakerModel = (*customMeetingSpeakerModel)(nil) + +type ( + // MeetingSpeakerModel is an interface to be customized, add more methods here, + // and implement the added methods in customMeetingSpeakerModel. + MeetingSpeakerModel interface { + meetingSpeakerModel + withSession(session sqlx.Session) MeetingSpeakerModel + } + + customMeetingSpeakerModel struct { + *defaultMeetingSpeakerModel + } +) + +// NewMeetingSpeakerModel returns a model for the database table. +func NewMeetingSpeakerModel(conn sqlx.SqlConn) MeetingSpeakerModel { + return &customMeetingSpeakerModel{ + defaultMeetingSpeakerModel: newMeetingSpeakerModel(conn), + } +} + +func (m *customMeetingSpeakerModel) withSession(session sqlx.Session) MeetingSpeakerModel { + return NewMeetingSpeakerModel(sqlx.NewSqlConnFromSession(session)) +} diff --git a/server/internal/meetingspeaker/internal/model/meetingspeakermodel_gen.go b/server/internal/meetingspeaker/internal/model/meetingspeakermodel_gen.go new file mode 100644 index 00000000..935f5212 --- /dev/null +++ b/server/internal/meetingspeaker/internal/model/meetingspeakermodel_gen.go @@ -0,0 +1,90 @@ +// Code generated by goctl. DO NOT EDIT. +// versions: +// goctl version: 1.9.1 + +package model + +import ( + "context" + "database/sql" + "fmt" + "strings" + + "github.com/zeromicro/go-zero/core/stores/builder" + "github.com/zeromicro/go-zero/core/stores/sqlx" + "github.com/zeromicro/go-zero/core/stringx" +) + +var ( + meetingSpeakerFieldNames = builder.RawFieldNames(&MeetingSpeaker{}) + meetingSpeakerRows = strings.Join(meetingSpeakerFieldNames, ",") + meetingSpeakerRowsExpectAutoSet = strings.Join(stringx.Remove(meetingSpeakerFieldNames, "`id`", "`create_at`", "`create_time`", "`created_at`", "`update_at`", "`update_time`", "`updated_at`"), ",") + meetingSpeakerRowsWithPlaceHolder = strings.Join(stringx.Remove(meetingSpeakerFieldNames, "`id`", "`create_at`", "`create_time`", "`created_at`", "`update_at`", "`update_time`", "`updated_at`"), "=?,") + "=?" +) + +type ( + meetingSpeakerModel interface { + Insert(ctx context.Context, data *MeetingSpeaker) (sql.Result, error) + FindOne(ctx context.Context, id int64) (*MeetingSpeaker, error) + Update(ctx context.Context, data *MeetingSpeaker) error + Delete(ctx context.Context, id int64) error + } + + defaultMeetingSpeakerModel struct { + conn sqlx.SqlConn + table string + } + + MeetingSpeaker struct { + Id int64 `db:"id"` // 嘉宾ID(主键) + MeetingId int64 `db:"meeting_id"` // 关联会议ID(对应meeting表id) + Name string `db:"name"` // 嘉宾姓名 + Title string `db:"title"` // 嘉宾头衔(如:XX公司技术总监) + Avatar string `db:"avatar"` // 嘉宾头像URL + Intro sql.NullString `db:"intro"` // 嘉宾简介 + Sort int64 `db:"sort"` // 嘉宾排序(数字越小越靠前) + } +) + +func newMeetingSpeakerModel(conn sqlx.SqlConn) *defaultMeetingSpeakerModel { + return &defaultMeetingSpeakerModel{ + conn: conn, + table: "`meeting_speaker`", + } +} + +func (m *defaultMeetingSpeakerModel) Delete(ctx context.Context, id int64) error { + query := fmt.Sprintf("delete from %s where `id` = ?", m.table) + _, err := m.conn.ExecCtx(ctx, query, id) + return err +} + +func (m *defaultMeetingSpeakerModel) FindOne(ctx context.Context, id int64) (*MeetingSpeaker, error) { + query := fmt.Sprintf("select %s from %s where `id` = ? limit 1", meetingSpeakerRows, m.table) + var resp MeetingSpeaker + err := m.conn.QueryRowCtx(ctx, &resp, query, id) + switch err { + case nil: + return &resp, nil + case sqlx.ErrNotFound: + return nil, ErrNotFound + default: + return nil, err + } +} + +func (m *defaultMeetingSpeakerModel) Insert(ctx context.Context, data *MeetingSpeaker) (sql.Result, error) { + query := fmt.Sprintf("insert into %s (%s) values (?, ?, ?, ?, ?, ?)", m.table, meetingSpeakerRowsExpectAutoSet) + ret, err := m.conn.ExecCtx(ctx, query, data.MeetingId, data.Name, data.Title, data.Avatar, data.Intro, data.Sort) + return ret, err +} + +func (m *defaultMeetingSpeakerModel) Update(ctx context.Context, data *MeetingSpeaker) error { + query := fmt.Sprintf("update %s set %s where `id` = ?", m.table, meetingSpeakerRowsWithPlaceHolder) + _, err := m.conn.ExecCtx(ctx, query, data.MeetingId, data.Name, data.Title, data.Avatar, data.Intro, data.Sort, data.Id) + return err +} + +func (m *defaultMeetingSpeakerModel) tableName() string { + return m.table +} diff --git a/server/internal/meetingspeaker/internal/model/vars.go b/server/internal/meetingspeaker/internal/model/vars.go new file mode 100644 index 00000000..69ca814e --- /dev/null +++ b/server/internal/meetingspeaker/internal/model/vars.go @@ -0,0 +1,5 @@ +package model + +import "github.com/zeromicro/go-zero/core/stores/sqlx" + +var ErrNotFound = sqlx.ErrNotFound diff --git a/server/internal/meetingspeaker/internal/types/types.go b/server/internal/meetingspeaker/internal/types/types.go new file mode 100644 index 00000000..a393fbaf --- /dev/null +++ b/server/internal/meetingspeaker/internal/types/types.go @@ -0,0 +1,72 @@ +// Code generated by goctl. DO NOT EDIT. +// goctl 1.9.1 + +package types + +type CreateSpeakerReq struct { + MeetingId int64 `json:"meeting_id" validate:"required,min=1"` // 关联会议ID(必填,需存在对应的会议) + Name string `json:"name" validate:"required,min=1,max=100"` // 嘉宾姓名(必填,长度限制) + Title string `json:"title,omitempty" validate:"max=200"` // 嘉宾头衔(可选,最长200字) + Avatar string `json:"avatar,omitempty" validate:"max=512"` // 头像URL(可选,最长512字符) + Intro string `json:"intro,omitempty"` // 嘉宾简介(可选,长文本) + Sort int `json:"sort,omitempty" validate:"min=0"` // 排序(可选,默认0,非负整数) +} + +type CreateSpeakerResp struct { + Msg string `json:"message"` // 操作提示(如:"嘉宾创建成功") + SpeakerId int64 `json:"speaker_id"` // 新增嘉宾的ID +} + +type DeleteSpeakerReq struct { + Id int64 `path:"id" validate:"required,min=1"` // 嘉宾ID(从路径参数获取,必填) +} + +type DeleteSpeakerResp struct { + Msg string `json:"message"` // 操作提示(如:"嘉宾已删除") +} + +type GetSpeakerReq struct { + Id int64 `path:"id" validate:"required,min=1"` // 嘉宾ID(从路径参数获取,必填) +} + +type GetSpeakerResp struct { + Msg string `json:"message"` // 操作提示 + Speaker *SpeakerDetail `json:"speaker"` // 嘉宾详情(查询成功返回) +} + +type ListSpeakersByMeetingReq struct { + MeetingId int64 `path:"meetingId" validate:"required,min=1"` // 会议ID(从路径参数获取,必填) + Page int `query:"page" validate:"min=1"` // 页码(默认1) + PageSize int `query:"page_size" validate:"min=1,max=100"` // 每页条数(默认10,最大100) +} + +type ListSpeakersByMeetingResp struct { + Msg string `json:"message"` // 操作提示 + Total int64 `json:"total"` // 该会议下的嘉宾总数 + Speakers []*SpeakerDetail `json:"speakers"` // 嘉宾列表(当前页数据,按sort升序排列) +} + +type SpeakerDetail struct { + Id int64 `json:"id"` // 嘉宾ID(主键) + MeetingId int64 `json:"meeting_id"` // 关联会议ID(外键) + Name string `json:"name"` // 嘉宾姓名 + Title string `json:"title"` // 嘉宾头衔 + Avatar string `json:"avatar"` // 嘉宾头像URL + Intro string `json:"intro"` // 嘉宾简介 + Sort int `json:"sort"` // 排序(数字越小越靠前) + IsDelete int `json:"is_delete"` // 软删除标识(0-未删,1-已删) +} + +type UpdateSpeakerReq struct { + Id int64 `json:"id" validate:"required,min=1"` // 嘉宾ID(必填,定位要更新的记录) + MeetingId int64 `json:"meeting_id,omitempty" validate:"min=1"` // 关联会议ID(可选,不填则不更新) + Name string `json:"name,omitempty" validate:"min=1,max=100"` // 嘉宾姓名(可选,更新时需非空) + Title string `json:"title,omitempty" validate:"max=200"` // 嘉宾头衔(可选) + Avatar string `json:"avatar,omitempty" validate:"max=512"` // 头像URL(可选) + Intro string `json:"intro,omitempty"` // 嘉宾简介(可选) + Sort int `json:"sort,omitempty" validate:"min=0"` // 排序(可选) +} + +type UpdateSpeakerResp struct { + Msg string `json:"message"` // 操作提示(如:"嘉宾信息更新成功") +}