完成教学案例的实现逻辑

This commit is contained in:
2025-10-31 14:18:08 +08:00
parent 55b2e201f8
commit 5995563bc6
17 changed files with 159 additions and 143 deletions

View File

@@ -4,15 +4,18 @@
package teaching_case
import (
"fmt"
"net/http"
"github.com/JACKYMYPERSON/hldrCenter/config"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/logic/teaching_case"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/svc"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/model"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/types"
"github.com/zeromicro/go-zero/core/stores/sqlx"
"github.com/zeromicro/go-zero/rest/httpx"
)
func CreateTeachingCaseHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
func CreateTeachingCaseHandler(cfg *config.Config) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
var req types.CreateTeachingCaseReq
if err := httpx.Parse(r, &req); err != nil {
@@ -20,7 +23,23 @@ func CreateTeachingCaseHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
return
}
l := teaching_case.NewCreateTeachingCaseLogic(r.Context(), svcCtx)
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)
teaching_caseModel := model.NewTeachingCaseModel(conn)
l := teaching_case.NewCreateTeachingCaseLogic(r.Context(), cfg, teaching_caseModel)
resp, err := l.CreateTeachingCase(&req)
if err != nil {
httpx.ErrorCtx(r.Context(), w, err)

View File

@@ -4,15 +4,18 @@
package teaching_case
import (
"fmt"
"net/http"
"github.com/JACKYMYPERSON/hldrCenter/config"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/logic/teaching_case"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/svc"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/model"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/types"
"github.com/zeromicro/go-zero/core/stores/sqlx"
"github.com/zeromicro/go-zero/rest/httpx"
)
func DeleteTeachingCaseHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
func DeleteTeachingCaseHandler(cfg *config.Config) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
var req types.DeleteTeachingCaseReq
if err := httpx.Parse(r, &req); err != nil {
@@ -20,7 +23,23 @@ func DeleteTeachingCaseHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
return
}
l := teaching_case.NewDeleteTeachingCaseLogic(r.Context(), svcCtx)
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)
teaching_caseModel := model.NewTeachingCaseModel(conn)
l := teaching_case.NewDeleteTeachingCaseLogic(r.Context(), cfg, teaching_caseModel)
resp, err := l.DeleteTeachingCase(&req)
if err != nil {
httpx.ErrorCtx(r.Context(), w, err)

View File

@@ -4,15 +4,18 @@
package teaching_case
import (
"fmt"
"net/http"
"github.com/JACKYMYPERSON/hldrCenter/config"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/logic/teaching_case"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/svc"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/model"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/types"
"github.com/zeromicro/go-zero/core/stores/sqlx"
"github.com/zeromicro/go-zero/rest/httpx"
)
func GetTeachingCaseHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
func GetTeachingCaseHandler(cfg *config.Config) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
var req types.GetTeachingCaseReq
if err := httpx.Parse(r, &req); err != nil {
@@ -20,7 +23,23 @@ func GetTeachingCaseHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
return
}
l := teaching_case.NewGetTeachingCaseLogic(r.Context(), svcCtx)
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)
teaching_caseModel := model.NewTeachingCaseModel(conn)
l := teaching_case.NewGetTeachingCaseLogic(r.Context(), cfg, teaching_caseModel)
resp, err := l.GetTeachingCase(&req)
if err != nil {
httpx.ErrorCtx(r.Context(), w, err)

View File

@@ -4,15 +4,18 @@
package teaching_case
import (
"fmt"
"net/http"
"github.com/JACKYMYPERSON/hldrCenter/config"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/logic/teaching_case"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/svc"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/model"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/types"
"github.com/zeromicro/go-zero/core/stores/sqlx"
"github.com/zeromicro/go-zero/rest/httpx"
)
func ListTeachingCaseHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
func ListTeachingCaseHandler(cfg *config.Config) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
var req types.ListTeachingCaseReq
if err := httpx.Parse(r, &req); err != nil {
@@ -20,7 +23,23 @@ func ListTeachingCaseHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
return
}
l := teaching_case.NewListTeachingCaseLogic(r.Context(), svcCtx)
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)
teaching_caseModel := model.NewTeachingCaseModel(conn)
l := teaching_case.NewListTeachingCaseLogic(r.Context(), cfg, teaching_caseModel)
resp, err := l.ListTeachingCase(&req)
if err != nil {
httpx.ErrorCtx(r.Context(), w, err)

View File

@@ -4,23 +4,41 @@
package teaching_case
import (
"fmt"
"net/http"
"github.com/JACKYMYPERSON/hldrCenter/config"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/logic/teaching_case"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/svc"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/model"
"github.com/JACKYMYPERSON/hldrCenter/internal/teaching_case/internal/types"
"github.com/zeromicro/go-zero/core/stores/sqlx"
"github.com/zeromicro/go-zero/rest/httpx"
)
func UpdateTeachingCaseHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
func UpdateTeachingCaseHandler(cfg *config.Config) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
var req types.UpdateTeachingCaseReq
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请求")
l := teaching_case.NewUpdateTeachingCaseLogic(r.Context(), svcCtx)
conn := sqlx.NewSqlConn("mysql", dsn)
teaching_caseModel := model.NewTeachingCaseModel(conn)
l := teaching_case.NewUpdateTeachingCaseLogic(r.Context(), cfg, teaching_caseModel)
resp, err := l.UpdateTeachingCase(&req)
if err != nil {
httpx.ErrorCtx(r.Context(), w, err)