新增科普文章管理
This commit is contained in:
parent
74b7003620
commit
aab466b4ea
@ -4,10 +4,12 @@ import (
|
||||
"github.com/gin-gonic/gin"
|
||||
"hospital-admin-api/api/dao"
|
||||
"hospital-admin-api/api/dto"
|
||||
"hospital-admin-api/api/model"
|
||||
"hospital-admin-api/api/requests"
|
||||
"hospital-admin-api/api/responses"
|
||||
"hospital-admin-api/global"
|
||||
"hospital-admin-api/utils"
|
||||
"strconv"
|
||||
)
|
||||
|
||||
type ArticleScience struct{}
|
||||
@ -53,3 +55,405 @@ func (b *ArticleScience) GetArticleSciencePage(c *gin.Context) {
|
||||
result["data"] = g
|
||||
responses.OkWithData(result, c)
|
||||
}
|
||||
|
||||
// GetArticleScience 获取科普文章详情
|
||||
func (b *ArticleScience) GetArticleScience(c *gin.Context) {
|
||||
id := c.Param("article_id")
|
||||
if id == "" {
|
||||
responses.FailWithMessage("缺少参数", c)
|
||||
return
|
||||
}
|
||||
|
||||
// 将 id 转换为 int64 类型
|
||||
articleId, err := strconv.ParseInt(id, 10, 64)
|
||||
if err != nil {
|
||||
responses.Fail(c)
|
||||
return
|
||||
}
|
||||
|
||||
// 获取科普文章数据
|
||||
articleScienceDao := dao.ArticleScienceDao{}
|
||||
articleScience, err := articleScienceDao.GetArticleScienceById(articleId)
|
||||
if err != nil {
|
||||
responses.FailWithMessage("异常", c)
|
||||
return
|
||||
}
|
||||
|
||||
// 处理返回值
|
||||
g := dto.GetArticleScienceDto(articleScience)
|
||||
|
||||
// 加载文章来源
|
||||
articleScienceSourceDao := dao.ArticleScienceSourceDao{}
|
||||
articleScienceSource, err := articleScienceSourceDao.GetArticleScienceSourceById(articleScience.SourceId)
|
||||
if err != nil {
|
||||
responses.FailWithMessage("异常", c)
|
||||
return
|
||||
}
|
||||
g.LoadArticleScienceSource(articleScienceSource)
|
||||
|
||||
// 加载文章分类
|
||||
articleScienceClassDao := dao.ArticleScienceClassDao{}
|
||||
maps := make(map[string]interface{})
|
||||
maps["article_id"] = articleScience.ArticleId
|
||||
articleScienceClass, err := articleScienceClassDao.GetArticleScienceClassList(maps)
|
||||
if len(articleScienceClass) > 0 {
|
||||
basicArticleClassDao := dao.BasicArticleClassDao{}
|
||||
for _, class := range articleScienceClass {
|
||||
basicArticleClass, err := basicArticleClassDao.GetBasicArticleClassById(class.BasicClassId)
|
||||
if err != nil {
|
||||
responses.FailWithMessage("异常", c)
|
||||
return
|
||||
}
|
||||
|
||||
// 加载文章分类
|
||||
g.LoadArticleScienceClass(basicArticleClass)
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
responses.OkWithData(g, c)
|
||||
}
|
||||
|
||||
// AddArticleScience 新增科普文章
|
||||
func (b *ArticleScience) AddArticleScience(c *gin.Context) {
|
||||
articleScienceRequest := requests.ArticleScienceRequest{}
|
||||
req := articleScienceRequest.AddArticleScience
|
||||
if err := c.ShouldBindJSON(&req); err != nil {
|
||||
responses.FailWithMessage(err.Error(), c)
|
||||
return
|
||||
}
|
||||
|
||||
// 参数验证
|
||||
if err := global.Validate.Struct(req); err != nil {
|
||||
responses.FailWithMessage(utils.Translate(err), c)
|
||||
return
|
||||
}
|
||||
|
||||
// 参数验证
|
||||
for _, item := range req.ArticleScienceClass {
|
||||
if err := global.Validate.Struct(item); err != nil {
|
||||
responses.FailWithMessage(utils.Translate(err), c)
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
// 检测来源是否正确
|
||||
sourceId, err := strconv.ParseInt(req.SourceId, 10, 64)
|
||||
if err != nil {
|
||||
responses.FailWithMessage("来源错误", c)
|
||||
return
|
||||
}
|
||||
|
||||
articleScienceSourceDao := dao.ArticleScienceSourceDao{}
|
||||
articleScienceSource, err := articleScienceSourceDao.GetArticleScienceSourceById(sourceId)
|
||||
if err != nil {
|
||||
responses.FailWithMessage("来源错误", c)
|
||||
return
|
||||
}
|
||||
|
||||
// 开始事务
|
||||
tx := global.Db.Begin()
|
||||
defer func() {
|
||||
if r := recover(); r != nil {
|
||||
tx.Rollback()
|
||||
}
|
||||
}()
|
||||
|
||||
articleScience := &model.ArticleScience{
|
||||
ArticleTitle: req.ArticleTitle,
|
||||
ArticleStatus: req.ArticleStatus,
|
||||
IsTop: req.IsTop,
|
||||
ArticleImage: utils.RemoveOssDomain(req.ArticleImage),
|
||||
SourceId: articleScienceSource.SourceId,
|
||||
ArticleUrl: req.ArticleUrl,
|
||||
}
|
||||
|
||||
articleScienceDao := dao.ArticleScienceDao{}
|
||||
articleScience, err = articleScienceDao.AddArticleScience(tx, articleScience)
|
||||
if err != nil {
|
||||
tx.Rollback()
|
||||
responses.FailWithMessage(err.Error(), c)
|
||||
return
|
||||
}
|
||||
|
||||
// 新增文章分类
|
||||
articleScienceClassDao := dao.ArticleScienceClassDao{}
|
||||
for _, i2 := range req.ArticleScienceClass {
|
||||
basicClassId, err := strconv.ParseInt(i2.BasicClassId, 10, 64)
|
||||
if err != nil {
|
||||
responses.FailWithMessage("分类错误", c)
|
||||
return
|
||||
}
|
||||
|
||||
articleScienceClass := &model.ArticleScienceClass{
|
||||
ArticleId: articleScience.ArticleId,
|
||||
BasicClassId: basicClassId,
|
||||
}
|
||||
articleScienceClass, err = articleScienceClassDao.AddArticleScienceClass(tx, articleScienceClass)
|
||||
if err != nil {
|
||||
tx.Rollback()
|
||||
responses.FailWithMessage(err.Error(), c)
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
tx.Commit()
|
||||
responses.Ok(c)
|
||||
}
|
||||
|
||||
// PutArticleScience 修改科普文章
|
||||
func (b *ArticleScience) PutArticleScience(c *gin.Context) {
|
||||
articleScienceRequest := requests.ArticleScienceRequest{}
|
||||
req := articleScienceRequest.PutArticleScience
|
||||
if err := c.ShouldBindJSON(&req); err != nil {
|
||||
responses.FailWithMessage(err.Error(), c)
|
||||
return
|
||||
}
|
||||
|
||||
// 参数验证
|
||||
if err := global.Validate.Struct(req); err != nil {
|
||||
responses.FailWithMessage(utils.Translate(err), c)
|
||||
return
|
||||
}
|
||||
|
||||
id := c.Param("article_id")
|
||||
if id == "" {
|
||||
responses.FailWithMessage("缺少参数", c)
|
||||
return
|
||||
}
|
||||
|
||||
// 将 id 转换为 int64 类型
|
||||
articleId, err := strconv.ParseInt(id, 10, 64)
|
||||
if err != nil {
|
||||
responses.Fail(c)
|
||||
return
|
||||
}
|
||||
|
||||
// 获取科普分类数据
|
||||
articleScienceDao := dao.ArticleScienceDao{}
|
||||
articleScience, err := articleScienceDao.GetArticleScienceById(articleId)
|
||||
if err != nil {
|
||||
responses.FailWithMessage("分类异常", c)
|
||||
return
|
||||
}
|
||||
|
||||
// 修改值
|
||||
articleScienceData := make(map[string]interface{})
|
||||
|
||||
// 文章标题
|
||||
if req.ArticleTitle != articleScience.ArticleTitle {
|
||||
articleScienceData["article_title"] = req.ArticleTitle
|
||||
}
|
||||
|
||||
// 文章状态
|
||||
if req.ArticleStatus != articleScience.ArticleStatus {
|
||||
articleScienceData["article_status"] = req.ArticleStatus
|
||||
}
|
||||
|
||||
// 是否置顶
|
||||
if req.IsTop != articleScience.IsTop {
|
||||
articleScienceData["is_top"] = req.IsTop
|
||||
}
|
||||
|
||||
// 文章图片
|
||||
articleImage := utils.RemoveOssDomain(req.ArticleImage)
|
||||
if articleImage != articleScience.ArticleImage {
|
||||
articleScienceData["article_image"] = req.ArticleImage
|
||||
}
|
||||
|
||||
// 文章来源
|
||||
sourceId, err := strconv.ParseInt(req.SourceId, 10, 64)
|
||||
if err != nil {
|
||||
responses.Fail(c)
|
||||
return
|
||||
}
|
||||
|
||||
if sourceId != articleScience.SourceId {
|
||||
articleScienceData["source_id"] = req.SourceId
|
||||
}
|
||||
|
||||
// 文章地址
|
||||
if req.ArticleUrl != articleScience.ArticleUrl {
|
||||
articleScienceData["article_url"] = req.ArticleUrl
|
||||
}
|
||||
|
||||
// 开始事务
|
||||
tx := global.Db.Begin()
|
||||
defer func() {
|
||||
if r := recover(); r != nil {
|
||||
tx.Rollback()
|
||||
}
|
||||
}()
|
||||
|
||||
if len(articleScienceData) > 0 {
|
||||
err = articleScienceDao.EditArticleScienceById(tx, articleId, articleScienceData)
|
||||
if err != nil {
|
||||
tx.Rollback()
|
||||
responses.FailWithMessage("操作失败", c)
|
||||
return
|
||||
}
|
||||
|
||||
tx.Commit()
|
||||
}
|
||||
|
||||
// 删除文章分类
|
||||
articleScienceClassDao := dao.ArticleScienceClassDao{}
|
||||
maps := make(map[string]interface{})
|
||||
maps["article_id"] = articleScience.ArticleId
|
||||
err = articleScienceClassDao.DeleteArticleScienceClass(tx, maps)
|
||||
if err != nil {
|
||||
tx.Rollback()
|
||||
responses.FailWithMessage("操作失败", c)
|
||||
return
|
||||
}
|
||||
|
||||
// 新增文章分类
|
||||
for _, i2 := range req.ArticleScienceClass {
|
||||
basicClassId, err := strconv.ParseInt(i2.BasicClassId, 10, 64)
|
||||
if err != nil {
|
||||
tx.Rollback()
|
||||
responses.FailWithMessage("分类错误", c)
|
||||
return
|
||||
}
|
||||
|
||||
articleScienceClass := &model.ArticleScienceClass{
|
||||
ArticleId: articleScience.ArticleId,
|
||||
BasicClassId: basicClassId,
|
||||
}
|
||||
articleScienceClass, err = articleScienceClassDao.AddArticleScienceClass(tx, articleScienceClass)
|
||||
if err != nil {
|
||||
tx.Rollback()
|
||||
responses.FailWithMessage(err.Error(), c)
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
tx.Commit()
|
||||
responses.Ok(c)
|
||||
}
|
||||
|
||||
// PutArticleScienceStatus 操作科普文章状态
|
||||
func (b *ArticleScience) PutArticleScienceStatus(c *gin.Context) {
|
||||
articleScienceRequest := requests.ArticleScienceRequest{}
|
||||
req := articleScienceRequest.PutArticleScienceStatus
|
||||
if err := c.ShouldBind(&req); err != nil {
|
||||
responses.FailWithMessage(err.Error(), c)
|
||||
return
|
||||
}
|
||||
|
||||
// 参数验证
|
||||
if err := global.Validate.Struct(req); err != nil {
|
||||
responses.FailWithMessage(utils.Translate(err), c)
|
||||
return
|
||||
}
|
||||
|
||||
id := c.Param("article_id")
|
||||
if id == "" {
|
||||
responses.FailWithMessage("缺少参数", c)
|
||||
return
|
||||
}
|
||||
|
||||
// 将 id 转换为 int64 类型
|
||||
articleId, err := strconv.ParseInt(id, 10, 64)
|
||||
if err != nil {
|
||||
responses.Fail(c)
|
||||
return
|
||||
}
|
||||
|
||||
// 获取科普分类数据
|
||||
articleScienceDao := dao.ArticleScienceDao{}
|
||||
articleScience, err := articleScienceDao.GetArticleScienceById(articleId)
|
||||
if err != nil {
|
||||
responses.FailWithMessage("分类异常", c)
|
||||
return
|
||||
}
|
||||
|
||||
// 检测状态
|
||||
if articleScience.ArticleStatus == req.ArticleStatus {
|
||||
responses.Ok(c)
|
||||
return
|
||||
}
|
||||
|
||||
// 开始事务
|
||||
tx := global.Db.Begin()
|
||||
defer func() {
|
||||
if r := recover(); r != nil {
|
||||
tx.Rollback()
|
||||
}
|
||||
}()
|
||||
|
||||
articleScienceData := make(map[string]interface{})
|
||||
articleScienceData["article_status"] = req.ArticleStatus
|
||||
err = articleScienceDao.EditArticleScienceById(tx, articleId, articleScienceData)
|
||||
if err != nil {
|
||||
tx.Rollback()
|
||||
responses.FailWithMessage("操作失败", c)
|
||||
return
|
||||
}
|
||||
|
||||
tx.Commit()
|
||||
responses.Ok(c)
|
||||
}
|
||||
|
||||
// PutArticleScienceTop 操作科普文章置顶状态
|
||||
func (b *ArticleScience) PutArticleScienceTop(c *gin.Context) {
|
||||
articleScienceRequest := requests.ArticleScienceRequest{}
|
||||
req := articleScienceRequest.PutArticleScienceTop
|
||||
if err := c.ShouldBind(&req); err != nil {
|
||||
responses.FailWithMessage(err.Error(), c)
|
||||
return
|
||||
}
|
||||
|
||||
// 参数验证
|
||||
if err := global.Validate.Struct(req); err != nil {
|
||||
responses.FailWithMessage(utils.Translate(err), c)
|
||||
return
|
||||
}
|
||||
|
||||
id := c.Param("article_id")
|
||||
if id == "" {
|
||||
responses.FailWithMessage("缺少参数", c)
|
||||
return
|
||||
}
|
||||
|
||||
// 将 id 转换为 int64 类型
|
||||
articleId, err := strconv.ParseInt(id, 10, 64)
|
||||
if err != nil {
|
||||
responses.Fail(c)
|
||||
return
|
||||
}
|
||||
|
||||
// 获取科普分类数据
|
||||
articleScienceDao := dao.ArticleScienceDao{}
|
||||
articleScience, err := articleScienceDao.GetArticleScienceById(articleId)
|
||||
if err != nil {
|
||||
responses.FailWithMessage("分类异常", c)
|
||||
return
|
||||
}
|
||||
|
||||
// 检测置顶状态
|
||||
if articleScience.IsTop == req.IsTop {
|
||||
responses.Ok(c)
|
||||
return
|
||||
}
|
||||
|
||||
// 开始事务
|
||||
tx := global.Db.Begin()
|
||||
defer func() {
|
||||
if r := recover(); r != nil {
|
||||
tx.Rollback()
|
||||
}
|
||||
}()
|
||||
|
||||
articleScienceData := make(map[string]interface{})
|
||||
articleScienceData["is_top"] = req.IsTop
|
||||
err = articleScienceDao.EditArticleScienceById(tx, articleId, articleScienceData)
|
||||
if err != nil {
|
||||
tx.Rollback()
|
||||
responses.FailWithMessage("操作失败", c)
|
||||
return
|
||||
}
|
||||
|
||||
tx.Commit()
|
||||
responses.Ok(c)
|
||||
}
|
||||
|
||||
@ -194,7 +194,7 @@ func (b *BasicArticleClass) PutBasicArticleClass(c *gin.Context) {
|
||||
// AddBasicArticleClass 新增科普分类
|
||||
func (b *BasicArticleClass) AddBasicArticleClass(c *gin.Context) {
|
||||
basicArticleClassRequest := requests.BasicArticleClassRequest{}
|
||||
req := basicArticleClassRequest.PutBasicArticleClass
|
||||
req := basicArticleClassRequest.AddBasicArticleClass
|
||||
if err := c.ShouldBind(&req); err != nil {
|
||||
responses.FailWithMessage(err.Error(), c)
|
||||
return
|
||||
|
||||
@ -38,8 +38,8 @@ func (r *ArticleScienceClassDao) DeleteArticleScienceClass(tx *gorm.DB, maps int
|
||||
}
|
||||
|
||||
// DeleteArticleScienceClassById 删除-id
|
||||
func (r *ArticleScienceClassDao) DeleteArticleScienceClassById(tx *gorm.DB, articleId int64) error {
|
||||
if err := tx.Delete(&model.ArticleScienceClass{}, articleId).Error; err != nil {
|
||||
func (r *ArticleScienceClassDao) DeleteArticleScienceClassById(tx *gorm.DB, classId int64) error {
|
||||
if err := tx.Delete(&model.ArticleScienceClass{}, classId).Error; err != nil {
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
|
||||
@ -77,15 +77,11 @@ func (r *ArticleScienceDto) LoadArticleScienceSource(m *model.ArticleScienceSour
|
||||
}
|
||||
|
||||
// LoadArticleScienceClass 加载文章分类
|
||||
func (r *ArticleScienceDto) LoadArticleScienceClass(m []*model.ArticleScienceClass) *ArticleScienceDto {
|
||||
if len(m) > 0 {
|
||||
for _, v := range m {
|
||||
if v.BasicArticleClass != nil {
|
||||
basicArticleClass := GetBasicArticleClassDto(v.BasicArticleClass)
|
||||
func (r *ArticleScienceDto) LoadArticleScienceClass(m *model.BasicArticleClass) *ArticleScienceDto {
|
||||
if m != nil {
|
||||
basicArticleClass := GetBasicArticleClassDto(m)
|
||||
|
||||
r.ArticleScienceClass = append(r.ArticleScienceClass, basicArticleClass)
|
||||
}
|
||||
}
|
||||
r.ArticleScienceClass = append(r.ArticleScienceClass, basicArticleClass)
|
||||
}
|
||||
return r
|
||||
}
|
||||
|
||||
@ -1,10 +1,11 @@
|
||||
package requests
|
||||
|
||||
type ArticleScienceRequest struct {
|
||||
GetArticleSciencePage // 获取科普文章列表-分页
|
||||
GetArticleScienceList // 获取科普文章列表
|
||||
PutArticleScience // 修改科普文章
|
||||
AddArticleScience // 新增科普文章
|
||||
GetArticleSciencePage // 获取科普文章列表-分页
|
||||
PutArticleScience // 修改科普文章
|
||||
AddArticleScience // 新增科普文章
|
||||
PutArticleScienceStatus // 操作科普文章状态
|
||||
PutArticleScienceTop // 操作科普文章置顶状态
|
||||
}
|
||||
|
||||
// GetArticleSciencePage 获取科普文章列表-分页
|
||||
@ -23,28 +24,44 @@ type GetArticleSciencePageOrder struct {
|
||||
UpdatedAt string `json:"updated_at" form:"updated_at" label:"排序"` // 修改时间
|
||||
}
|
||||
|
||||
// GetArticleScienceList 获取科普文章列表
|
||||
type GetArticleScienceList struct {
|
||||
ArticleTitle string `json:"article_title" form:"article_title" label:"文章标题"` // 文章标题
|
||||
ArticleStatus *int `json:"article_status" form:"article_status" label:"文章状态" validate:"omitempty,numeric,oneof=1 2"` // 文章状态(1:正常 2:禁用)
|
||||
IsTop *int `json:"is_top" form:"is_top" label:"是否置顶" validate:"omitempty,numeric,oneof=0 1"` // 是否置顶(0:否 1:是)
|
||||
SourceId string `json:"source_id" form:"source_id" label:"文章来源"` // 文章来源id
|
||||
Order *GetArticleSciencePageOrder `json:"order" form:"order" label:"排序"`
|
||||
}
|
||||
|
||||
// GetArticleScienceListOrder 获取科普文章列表-排序条件
|
||||
type GetArticleScienceListOrder struct {
|
||||
BasicClassSort string `json:"basic_class_sort" form:"basic_class_sort" label:"排序"` // 排序(越大排序越靠前)
|
||||
}
|
||||
|
||||
// PutArticleScience 修改科普文章
|
||||
type PutArticleScience struct {
|
||||
BasicClassName string `json:"basic_class_name" form:"basic_class_name" label:"分类名称" validate:"required"`
|
||||
BasicClassSort uint `json:"basic_class_sort" form:"basic_class_sort" label:"排序值" validate:"required,number,min=1"`
|
||||
ArticleTitle string `json:"article_title" form:"article_title" label:"文章标题" validate:"required"` // 文章标题
|
||||
ArticleStatus int `json:"article_status" form:"article_status" label:"文章状态" validate:"omitempty,numeric,oneof=1 2"` // 文章状态(1:正常 2:禁用)
|
||||
IsTop int `json:"is_top" form:"is_top" label:"是否置顶" validate:"omitempty,numeric,oneof=0 1"` // 是否置顶(0:否 1:是)
|
||||
ArticleImage string `json:"article_image" form:"is_top" label:"文章图片" validate:"required"`
|
||||
SourceId string `json:"source_id" form:"source_id" label:"文章来源" validate:"required"`
|
||||
ArticleUrl string `json:"article_url" form:"article_url" label:"文章地址" validate:"required"`
|
||||
ArticleScienceClass []*PutArticleScienceClass `json:"article_science_class" form:"article_science_class" label:"文章分类" validate:"required"`
|
||||
}
|
||||
|
||||
// PutArticleScienceClass 修改科普文章-文章分类
|
||||
type PutArticleScienceClass struct {
|
||||
BasicClassId string `json:"basic_class_id" form:"basic_class_id" label:"分类" validate:"required"`
|
||||
}
|
||||
|
||||
// AddArticleScience 新增科普文章
|
||||
type AddArticleScience struct {
|
||||
BasicClassName string `json:"basic_class_name" form:"basic_class_name" label:"分类名称" validate:"required"`
|
||||
BasicClassSort uint `json:"basic_class_sort" form:"basic_class_sort" label:"排序值" validate:"required,number,min=1"`
|
||||
ArticleTitle string `json:"article_title" form:"article_title" label:"文章标题" validate:"required"` // 文章标题
|
||||
ArticleStatus int `json:"article_status" form:"article_status" label:"文章状态" validate:"omitempty,numeric,oneof=1 2"` // 文章状态(1:正常 2:禁用)
|
||||
IsTop int `json:"is_top" form:"is_top" label:"是否置顶" validate:"omitempty,numeric,oneof=0 1"` // 是否置顶(0:否 1:是)
|
||||
ArticleImage string `json:"article_image" form:"is_top" label:"文章图片" validate:"required"`
|
||||
SourceId string `json:"source_id" form:"source_id" label:"文章来源" validate:"required"`
|
||||
ArticleUrl string `json:"article_url" form:"article_url" label:"文章地址" validate:"required"`
|
||||
ArticleScienceClass []*AddArticleScienceClass `json:"article_science_class" form:"article_science_class" label:"文章分类" validate:"required"`
|
||||
}
|
||||
|
||||
// AddArticleScienceClass 新增科普文章-文章分类
|
||||
type AddArticleScienceClass struct {
|
||||
BasicClassId string `json:"basic_class_id" form:"basic_class_id" label:"分类" validate:"required"`
|
||||
}
|
||||
|
||||
// PutArticleScienceStatus 操作科普文章状态
|
||||
type PutArticleScienceStatus struct {
|
||||
ArticleStatus int `json:"article_status" form:"article_status" label:"状态" validate:"required,oneof=1 2"` // 文章状态(1:正常 2:禁用)
|
||||
}
|
||||
|
||||
// PutArticleScienceTop 操作科普文章置顶状态
|
||||
type PutArticleScienceTop struct {
|
||||
IsTop int `json:"is_top" form:"is_top" label:"状态" validate:"omitempty,numeric,oneof=0 1"` // 是否置顶(0:否 1:是)
|
||||
}
|
||||
|
||||
@ -887,10 +887,19 @@ func privateRouter(r *gin.Engine, api controller.Api) {
|
||||
scienceGroup.POST("/page", api.ArticleScience.GetArticleSciencePage)
|
||||
|
||||
// 获取科普文章详情
|
||||
scienceGroup.GET("/:article_id", api.ArticleScience.GetArticleScience)
|
||||
|
||||
// 修改科普文章
|
||||
scienceGroup.PUT("/:article_id", api.ArticleScience.PutArticleScience)
|
||||
|
||||
// 新增科普文章
|
||||
scienceGroup.POST("", api.ArticleScience.AddArticleScience)
|
||||
|
||||
// 操作科普文章状态
|
||||
scienceGroup.PUT("/status/:article_id", api.ArticleScience.PutArticleScienceStatus)
|
||||
|
||||
// 操作科普文章置顶状态
|
||||
scienceGroup.PUT("/top/:article_id", api.ArticleScience.PutArticleScienceTop)
|
||||
|
||||
// 科普文章来源
|
||||
sourceGroup := scienceGroup.Group("source")
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user