作者 yangfu
正在显示 28 个修改的文件 包含 939 行增加8 行删除
  1 +FROM golang:1.19-alpine as builder
  2 +
  3 +# Define the project name | 定义项目名称
  4 +ARG PROJECT=core
  5 +
  6 +WORKDIR /build
  7 +COPY . .
  8 +
  9 +RUN go env -w GO111MODULE=on \
  10 + && go env -w GOPROXY=https://goproxy.cn,direct \
  11 + && go env -w CGO_ENABLED=0 \
  12 + && go env \
  13 + && go mod tidy \
  14 + && cd cmd/discuss/api \
  15 + && go build -ldflags="-s -w" -o /build/api/${PROJECT} ${PROJECT}.go
  16 +
  17 +FROM alpine:latest
  18 +
  19 +# Define the project name | 定义项目名称
  20 +ARG PROJECT=core
  21 +# Define the config file name | 定义配置文件名
  22 +ARG CONFIG_FILE=core.yaml
  23 +# Define the author | 定义作者
  24 +ARG AUTHOR=785409885@qq.com
  25 +
  26 +LABEL org.opencontainers.image.authors=${AUTHOR}
  27 +
  28 +WORKDIR /app
  29 +ENV PROJECT=${PROJECT}
  30 +ENV CONFIG_FILE=${CONFIG_FILE}
  31 +
  32 +COPY --from=builder /build/api/${PROJECT} ./
  33 +COPY --from=builder /build/cmd/discuss/api/etc/${CONFIG_FILE} ./etc/
  34 +
  35 +EXPOSE 8080
  36 +ENTRYPOINT ./${PROJECT} -f etc/${CONFIG_FILE}
@@ -56,6 +56,21 @@ service Core { @@ -56,6 +56,21 @@ service Core {
56 @handler SystemArticleCommentSearch 56 @handler SystemArticleCommentSearch
57 post /article_comment/search (SystemArticleCommentSearchRequest) returns (SystemArticleCommentSearchResponse) 57 post /article_comment/search (SystemArticleCommentSearchRequest) returns (SystemArticleCommentSearchResponse)
58 58
  59 + @doc "管理后台查看所有的评论"
  60 + @handler SystemListAticleComment
  61 + post /article_comment/list (SystemListCommentRequest)returns (SystemListCommentResponse)
  62 +
  63 + @doc "管理后台评论的详情"
  64 + @handler SystemGetAticleComment
  65 + get /article_comment/:id (SystemGetCommentRequest)returns (SystemGetCommentResponse)
  66 +
  67 + @doc "管理后台变更评论的显示状态"
  68 + @handler SystemEditAticleCommentShow
  69 + post /article_comment/edit_show (SystemEditCommentShowRequest)returns (SystemEditCommentShowResponse)
  70 +
  71 + @doc "管理后台变更评论"
  72 + @handler SystemEditAticleComment
  73 + post /article_comment/edit (SystemEditCommentRequest)returns (SystemEditCommentResponse)
59 } 74 }
60 75
61 //评论的填写人 76 //评论的填写人
@@ -240,3 +255,90 @@ type ( @@ -240,3 +255,90 @@ type (
240 Show int `json:"show"` // 显示状态 255 Show int `json:"show"` // 显示状态
241 } 256 }
242 ) 257 )
  258 +
  259 +// 管理后台 评论管理列表
  260 +type (
  261 + SystemListCommentRequest {
  262 + Page int `json:"page"`
  263 + Size int `json:"size"`
  264 + CompanyId int64 `json:",optional"` //
  265 + TopId int64 `json:"topId"` // 评论的顶层ID
  266 + FromUser string `json:"fromUser,optional"` // 用户
  267 + Show int `json:"show,optional"` // 显示状态
  268 + BeginTime int64 `json:"beginTime,optional"` // 填写评论的开始时间
  269 + EndTime int64 `json:"endTime,optional"` // 填写评论的结束时间
  270 + ArticleTitle string `json:"articleTitle,optional"` //
  271 + Content string `json:"content,optional"` //
  272 + }
  273 + SystemListCommentResponse {
  274 + Total int `json:"total"`
  275 + List []SystemCommentItem `json:"list"`
  276 + }
  277 + SystemCommentItem {
  278 + Id int64 `json:"id"` //评论id
  279 + Pid int64 `json:"pid"` //
  280 + TopId int64 `json:"topId"` //
  281 + ArticleId int64 `json:"articleId"` //对应的文章id
  282 + ArticleTitle string `json:"articleTitle"` //文章标题
  283 + FromUserId int64 `json:"fromUserId"` //填写评论的人
  284 + FromUser CommentAuthor `json:"fromUser"` //填写评论的人
  285 + CreatedAt int64 `json:"createdAt"` //评论的填写时间
  286 + Content string `json:"content"` //评论的内容
  287 + Show int `json:"show"` //是否展示 [1显示] [2不显示]
  288 + CountReply int `json:"countReplay"` //回复数量
  289 + CountUserLove int `json:"countUserLove"` //用户点赞数量
  290 + CountAdminLove int `json:"countAdminLove"` //运营点赞数量
  291 + }
  292 +)
  293 +
  294 +// 管理后台获取评论详情
  295 +type (
  296 + SystemGetCommentRequest {
  297 + CompanyId int64 `path:",optional"`
  298 + Id int64 `path:"id"`
  299 + }
  300 +
  301 + SystemGetCommentResponse {
  302 + Id int64 `json:"id"` //评论id
  303 + Pid int64 `json:"pid"` //
  304 + TopId int64 `json:"topId"` //
  305 + ArticleId int64 `json:"articleId"` //对应的文章id
  306 + ArticleTitle string `json:"articleTitle"` //文章标题
  307 + FromUserId int64 `json:"fromUserId"` //填写评论的人
  308 + FromUser CommentAuthor `json:"fromUser"` //填写评论的人
  309 + CreatedAt int64 `json:"createdAt"` //评论的填写时间
  310 + SectionContent string `json:"sectionContent"` //引用的段落内容
  311 + Content string `json:"content"` // 评论的内容
  312 + Show int `json:"show"` //是否展示 [1显示] [2不显示]
  313 + CountReply int `json:"countReplay"` //回复数量
  314 + CountUserLove int `json:"countUserLove"` //用户点赞数量
  315 + CountAdminLove int `json:"countAdminLove"` //运营点赞数量
  316 + }
  317 +)
  318 +
  319 +// 管理后台单独设置评论显示隐藏状态
  320 +type (
  321 + SystemEditCommentShowRequest {
  322 + CompanyId int64 `json:",optional"`
  323 + Id []int64 `json:"id"`
  324 + Show int `json:"show"` //[1 显示评论] [2: 隐藏评论]
  325 + }
  326 +
  327 + SystemEditCommentShowResponse {
  328 + Id []int64 `json:"id"`
  329 + }
  330 +)
  331 +
  332 +// 管理后台变更评论
  333 +type (
  334 + SystemEditCommentRequest {
  335 + CompanyId int64 `json:",optional"`
  336 + Id int64 `json:"id"`
  337 + Show int `json:"show"` //[1 显示评论] [2: 隐藏评论]
  338 + CountAdminLove int `json:"countAdminLove,optional"`
  339 + }
  340 +
  341 + SystemEditCommentResponse {
  342 + Id int64 `json:"id"`
  343 + }
  344 +)
@@ -4,6 +4,8 @@ Port: 8081 @@ -4,6 +4,8 @@ Port: 8081
4 Verbose: true 4 Verbose: true
5 Migrate: false 5 Migrate: false
6 Timeout: 30000 6 Timeout: 30000
  7 +# CertFile: ./key/fjmaimaimai.com_bundle.crt
  8 +# KeyFile: ./key/fjmaimaimai.com.key
7 Log: 9 Log:
8 #Mode: file 10 #Mode: file
9 Encoding: plain 11 Encoding: plain
@@ -16,7 +16,7 @@ func MiniSearchArticlePageHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { @@ -16,7 +16,7 @@ func MiniSearchArticlePageHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
16 return func(w http.ResponseWriter, r *http.Request) { 16 return func(w http.ResponseWriter, r *http.Request) {
17 var req types.MiniSearchArticleRequest 17 var req types.MiniSearchArticleRequest
18 if err := httpx.Parse(r, &req); err != nil { 18 if err := httpx.Parse(r, &req); err != nil {
19 - httpx.ErrorCtx(r.Context(), w, err) 19 + result.HttpResult(r, w, nil, err)
20 return 20 return
21 } 21 }
22 22
1 package comment 1 package comment
2 2
3 import ( 3 import (
4 - "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result"  
5 "net/http" 4 "net/http"
6 5
  6 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result"
  7 +
7 "github.com/zeromicro/go-zero/rest/httpx" 8 "github.com/zeromicro/go-zero/rest/httpx"
8 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/comment" 9 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/comment"
9 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc" 10 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc"
@@ -14,7 +15,7 @@ func SystemArticleCommentSearchHandler(svcCtx *svc.ServiceContext) http.HandlerF @@ -14,7 +15,7 @@ func SystemArticleCommentSearchHandler(svcCtx *svc.ServiceContext) http.HandlerF
14 return func(w http.ResponseWriter, r *http.Request) { 15 return func(w http.ResponseWriter, r *http.Request) {
15 var req types.SystemArticleCommentSearchRequest 16 var req types.SystemArticleCommentSearchRequest
16 if err := httpx.Parse(r, &req); err != nil { 17 if err := httpx.Parse(r, &req); err != nil {
17 - httpx.ErrorCtx(r.Context(), w, err) 18 + result.HttpResult(r, w, nil, err)
18 return 19 return
19 } 20 }
20 21
1 package comment 1 package comment
2 2
3 import ( 3 import (
4 - "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result"  
5 "net/http" 4 "net/http"
6 5
  6 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result"
  7 +
7 "github.com/zeromicro/go-zero/rest/httpx" 8 "github.com/zeromicro/go-zero/rest/httpx"
8 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/comment" 9 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/comment"
9 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc" 10 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc"
@@ -14,7 +15,7 @@ func SystemArticleCommentSearchMeHandler(svcCtx *svc.ServiceContext) http.Handle @@ -14,7 +15,7 @@ func SystemArticleCommentSearchMeHandler(svcCtx *svc.ServiceContext) http.Handle
14 return func(w http.ResponseWriter, r *http.Request) { 15 return func(w http.ResponseWriter, r *http.Request) {
15 var req types.SystemArticleCommentSearchMeRequest 16 var req types.SystemArticleCommentSearchMeRequest
16 if err := httpx.Parse(r, &req); err != nil { 17 if err := httpx.Parse(r, &req); err != nil {
17 - httpx.ErrorCtx(r.Context(), w, err) 18 + result.HttpResult(r, w, nil, err)
18 return 19 return
19 } 20 }
20 21
  1 +package comment
  2 +
  3 +import (
  4 + "net/http"
  5 +
  6 + "github.com/zeromicro/go-zero/rest/httpx"
  7 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/comment"
  8 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc"
  9 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types"
  10 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata"
  11 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result"
  12 +)
  13 +
  14 +func SystemEditAticleCommentHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
  15 + return func(w http.ResponseWriter, r *http.Request) {
  16 + var req types.SystemEditCommentRequest
  17 + if err := httpx.Parse(r, &req); err != nil {
  18 + httpx.ErrorCtx(r.Context(), w, err)
  19 + return
  20 + }
  21 +
  22 + l := comment.NewSystemEditAticleCommentLogic(r.Context(), svcCtx)
  23 + token := contextdata.GetUserTokenFromCtx(r.Context())
  24 + req.CompanyId = token.CompanyId
  25 + resp, err := l.SystemEditAticleComment(&req)
  26 + result.HttpResult(r, w, resp, err)
  27 + }
  28 +}
  1 +package comment
  2 +
  3 +import (
  4 + "net/http"
  5 +
  6 + "github.com/zeromicro/go-zero/rest/httpx"
  7 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/comment"
  8 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc"
  9 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types"
  10 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata"
  11 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result"
  12 +)
  13 +
  14 +func SystemEditAticleCommentShowHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
  15 + return func(w http.ResponseWriter, r *http.Request) {
  16 + var req types.SystemEditCommentShowRequest
  17 + if err := httpx.Parse(r, &req); err != nil {
  18 + result.HttpResult(r, w, nil, err)
  19 + return
  20 + }
  21 +
  22 + l := comment.NewSystemEditAticleCommentShowLogic(r.Context(), svcCtx)
  23 + token := contextdata.GetUserTokenFromCtx(r.Context())
  24 + req.CompanyId = token.CompanyId
  25 + resp, err := l.SystemEditAticleCommentShow(&req)
  26 + result.HttpResult(r, w, resp, err)
  27 + }
  28 +}
  1 +package comment
  2 +
  3 +import (
  4 + "net/http"
  5 +
  6 + "github.com/zeromicro/go-zero/rest/httpx"
  7 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/comment"
  8 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc"
  9 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types"
  10 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata"
  11 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result"
  12 +)
  13 +
  14 +func SystemGetAticleCommentHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
  15 + return func(w http.ResponseWriter, r *http.Request) {
  16 + var req types.SystemGetCommentRequest
  17 + if err := httpx.Parse(r, &req); err != nil {
  18 + result.HttpResult(r, w, nil, err)
  19 + return
  20 + }
  21 +
  22 + l := comment.NewSystemGetAticleCommentLogic(r.Context(), svcCtx)
  23 + token := contextdata.GetUserTokenFromCtx(r.Context())
  24 + req.CompanyId = token.CompanyId
  25 + resp, err := l.SystemGetAticleComment(&req)
  26 + result.HttpResult(r, w, resp, err)
  27 + }
  28 +}
  1 +package comment
  2 +
  3 +import (
  4 + "net/http"
  5 +
  6 + "github.com/zeromicro/go-zero/rest/httpx"
  7 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/comment"
  8 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc"
  9 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types"
  10 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata"
  11 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result"
  12 +)
  13 +
  14 +func SystemListAticleCommentHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
  15 + return func(w http.ResponseWriter, r *http.Request) {
  16 + var req types.SystemListCommentRequest
  17 + if err := httpx.Parse(r, &req); err != nil {
  18 + result.HttpResult(r, w, nil, err)
  19 + return
  20 + }
  21 +
  22 + l := comment.NewSystemListAticleCommentLogic(r.Context(), svcCtx)
  23 + token := contextdata.GetUserTokenFromCtx(r.Context())
  24 + req.CompanyId = token.CompanyId
  25 + resp, err := l.SystemListAticleComment(&req)
  26 + result.HttpResult(r, w, resp, err)
  27 + }
  28 +}
@@ -69,6 +69,26 @@ func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) { @@ -69,6 +69,26 @@ func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) {
69 Path: "/article_comment/search", 69 Path: "/article_comment/search",
70 Handler: comment.SystemArticleCommentSearchHandler(serverCtx), 70 Handler: comment.SystemArticleCommentSearchHandler(serverCtx),
71 }, 71 },
  72 + {
  73 + Method: http.MethodPost,
  74 + Path: "/article_comment/list",
  75 + Handler: comment.SystemListAticleCommentHandler(serverCtx),
  76 + },
  77 + {
  78 + Method: http.MethodGet,
  79 + Path: "/article_comment/:id",
  80 + Handler: comment.SystemGetAticleCommentHandler(serverCtx),
  81 + },
  82 + {
  83 + Method: http.MethodPost,
  84 + Path: "/article_comment/edit_show",
  85 + Handler: comment.SystemEditAticleCommentShowHandler(serverCtx),
  86 + },
  87 + {
  88 + Method: http.MethodPost,
  89 + Path: "/article_comment/edit",
  90 + Handler: comment.SystemEditAticleCommentHandler(serverCtx),
  91 + },
72 }..., 92 }...,
73 ), 93 ),
74 rest.WithJwt(serverCtx.Config.SystemAuth.AccessSecret), 94 rest.WithJwt(serverCtx.Config.SystemAuth.AccessSecret),
@@ -38,6 +38,12 @@ func (l *MiniDeleteArticleCommentLogic) MiniDeleteArticleComment(req *types.Mini @@ -38,6 +38,12 @@ func (l *MiniDeleteArticleCommentLogic) MiniDeleteArticleComment(req *types.Mini
38 return nil, xerr.NewErrMsg("没有操作权限") 38 return nil, xerr.NewErrMsg("没有操作权限")
39 } 39 }
40 40
  41 + if commetInfo.Show == domain.CommentShowDisable {
  42 + resp = &types.MiniDeleteArticleCommentResponse{
  43 + Id: commetInfo.Id,
  44 + }
  45 + return resp, nil
  46 + }
41 commetInfo.Show = domain.CommentShowDisable 47 commetInfo.Show = domain.CommentShowDisable
42 48
43 // 变更回复数量 49 // 变更回复数量
@@ -25,6 +25,7 @@ func NewMiniListArticleCommentLogic(ctx context.Context, svcCtx *svc.ServiceCont @@ -25,6 +25,7 @@ func NewMiniListArticleCommentLogic(ctx context.Context, svcCtx *svc.ServiceCont
25 } 25 }
26 } 26 }
27 27
  28 +// 小程序端获取 根据文章id 获取评论列表
28 func (l *MiniListArticleCommentLogic) MiniListArticleComment(req *types.MiniListArticleCommentRequest) (resp *types.MiniListArticleCommentResponse, err error) { 29 func (l *MiniListArticleCommentLogic) MiniListArticleComment(req *types.MiniListArticleCommentRequest) (resp *types.MiniListArticleCommentResponse, err error) {
29 // 先获取最顶层的评论 30 // 先获取最顶层的评论
30 var conn = l.svcCtx.DefaultDBConn() 31 var conn = l.svcCtx.DefaultDBConn()
  1 +package comment
  2 +
  3 +import (
  4 + "context"
  5 +
  6 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc"
  7 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types"
  8 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/db/transaction"
  9 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain"
  10 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr"
  11 +
  12 + "github.com/zeromicro/go-zero/core/logx"
  13 +)
  14 +
  15 +type SystemEditAticleCommentLogic struct {
  16 + logx.Logger
  17 + ctx context.Context
  18 + svcCtx *svc.ServiceContext
  19 +}
  20 +
  21 +func NewSystemEditAticleCommentLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SystemEditAticleCommentLogic {
  22 + return &SystemEditAticleCommentLogic{
  23 + Logger: logx.WithContext(ctx),
  24 + ctx: ctx,
  25 + svcCtx: svcCtx,
  26 + }
  27 +}
  28 +
  29 +// 管理后台变更评论的设置
  30 +func (l *SystemEditAticleCommentLogic) SystemEditAticleComment(req *types.SystemEditCommentRequest) (resp *types.SystemEditCommentResponse, err error) {
  31 + var conn = l.svcCtx.DefaultDBConn()
  32 + commetInfo, err := l.svcCtx.ArticleCommentRepository.FindOne(l.ctx, conn, req.Id)
  33 + if err != nil {
  34 + return nil, xerr.NewErrMsgErr("编辑评论信息失败", err)
  35 + }
  36 + if commetInfo.CompanyId != req.CompanyId {
  37 + return nil, xerr.NewErrMsg("没有操作权限")
  38 + }
  39 + commetInfo.CountAdminLove = req.CountAdminLove
  40 + var increaseCount int
  41 + switch req.Show {
  42 + case 1:
  43 + // 设置为显示评论
  44 + if commetInfo.Show != domain.CommentShowEnable {
  45 + commetInfo.Show = domain.CommentShowEnable
  46 + increaseCount = 1
  47 + }
  48 + case 2:
  49 + // 设置为隐藏评论
  50 + if commetInfo.Show != domain.CommentShowDisable {
  51 + commetInfo.Show = domain.CommentShowDisable
  52 + increaseCount = -1
  53 + }
  54 + }
  55 + commetInfo.Show = domain.CommentShowEnable
  56 + // 变更回复数量
  57 + err = transaction.UseTrans(l.ctx, conn.DB(), func(ctx context.Context, c transaction.Conn) error {
  58 + _, err = l.svcCtx.ArticleCommentRepository.Update(ctx, c, commetInfo)
  59 + if err != nil {
  60 + return err
  61 + }
  62 + if increaseCount != 0 {
  63 + // 增加上级评论的回复数量
  64 + if commetInfo.Pid != 0 {
  65 + err = l.svcCtx.ArticleCommentRepository.IncreaseCountReply(l.ctx, c, increaseCount, commetInfo.Pid)
  66 + if err != nil {
  67 + return err
  68 + }
  69 + }
  70 + // 增加最顶层的评论回复计数
  71 + if commetInfo.TopId != 0 && commetInfo.Pid != commetInfo.TopId {
  72 + err = l.svcCtx.ArticleCommentRepository.IncreaseCountReply(l.ctx, c, increaseCount, commetInfo.TopId)
  73 + if err != nil {
  74 + return err
  75 + }
  76 + }
  77 + // 增加加段落评论计数
  78 + if commetInfo.SectionId > 0 {
  79 + err = l.svcCtx.ArticleSectionRepository.IncreaseCountComment(ctx, c, increaseCount, commetInfo.SectionId)
  80 + if err != nil {
  81 + return err
  82 + }
  83 + }
  84 + // 增加文章的评论数
  85 + err = l.svcCtx.ArticleRepository.IncreaseCountComment(ctx, c, increaseCount, commetInfo.ArticleId)
  86 + if err != nil {
  87 + return err
  88 + }
  89 + }
  90 + return nil
  91 + }, true)
  92 +
  93 + if err != nil {
  94 + return nil, xerr.NewErrMsgErr("编辑评论信息失败", err)
  95 + }
  96 + resp = &types.SystemEditCommentResponse{
  97 + Id: commetInfo.Id,
  98 + }
  99 + return resp, nil
  100 +
  101 +}
  1 +package comment
  2 +
  3 +import (
  4 + "context"
  5 +
  6 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc"
  7 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types"
  8 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/db/transaction"
  9 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain"
  10 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr"
  11 +
  12 + "github.com/zeromicro/go-zero/core/logx"
  13 +)
  14 +
  15 +type SystemEditAticleCommentShowLogic struct {
  16 + logx.Logger
  17 + ctx context.Context
  18 + svcCtx *svc.ServiceContext
  19 +}
  20 +
  21 +func NewSystemEditAticleCommentShowLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SystemEditAticleCommentShowLogic {
  22 + return &SystemEditAticleCommentShowLogic{
  23 + Logger: logx.WithContext(ctx),
  24 + ctx: ctx,
  25 + svcCtx: svcCtx,
  26 + }
  27 +}
  28 +
  29 +// 管理后台,单独设置评论的隐藏显示
  30 +func (l *SystemEditAticleCommentShowLogic) SystemEditAticleCommentShow(req *types.SystemEditCommentShowRequest) (resp *types.SystemEditCommentShowResponse, err error) {
  31 +
  32 + resp = &types.SystemEditCommentShowResponse{
  33 + Id: []int64{},
  34 + }
  35 + if req.Show == 1 {
  36 + for _, val := range req.Id {
  37 + err = l.enableShow(val, req.CompanyId)
  38 + if err != nil {
  39 + err = xerr.NewErrMsgErr("操作失败,刷新重试", err)
  40 + } else {
  41 + resp.Id = append(resp.Id, val)
  42 + }
  43 + }
  44 + }
  45 + if req.Show == 2 {
  46 + for _, val := range req.Id {
  47 + err = l.disableShow(val, req.CompanyId)
  48 + if err != nil {
  49 + err = xerr.NewErrMsgErr("操作失败,刷新重试", err)
  50 + } else {
  51 + resp.Id = append(resp.Id, val)
  52 + }
  53 + }
  54 + }
  55 + if err != nil {
  56 + return resp, err
  57 + }
  58 + return
  59 +}
  60 +
  61 +func (l *SystemEditAticleCommentShowLogic) disableShow(commentId int64, companyId int64) error {
  62 + var conn = l.svcCtx.DefaultDBConn()
  63 + commetInfo, err := l.svcCtx.ArticleCommentRepository.FindOne(l.ctx, conn, commentId)
  64 + if err != nil {
  65 + return xerr.NewErrMsgErr("删除评论信息失败", err)
  66 + }
  67 + if commetInfo.CompanyId != companyId {
  68 + return xerr.NewErrMsg("没有操作权限")
  69 + }
  70 + if commetInfo.Show == domain.CommentShowDisable {
  71 + return nil
  72 + }
  73 + commetInfo.Show = domain.CommentShowDisable
  74 + // 变更回复数量
  75 + err = transaction.UseTrans(l.ctx, conn.DB(), func(ctx context.Context, c transaction.Conn) error {
  76 + _, err = l.svcCtx.ArticleCommentRepository.Update(ctx, c, commetInfo)
  77 + if err != nil {
  78 + return err
  79 + }
  80 + // 减少上级评论的回复数量
  81 + if commetInfo.Pid != 0 {
  82 + err = l.svcCtx.ArticleCommentRepository.IncreaseCountReply(l.ctx, c, -1, commetInfo.Pid)
  83 + if err != nil {
  84 + return err
  85 + }
  86 + }
  87 + // 减少最顶层的评论回复计数
  88 + if commetInfo.TopId != 0 && commetInfo.Pid != commetInfo.TopId {
  89 + err = l.svcCtx.ArticleCommentRepository.IncreaseCountReply(l.ctx, c, -1, commetInfo.TopId)
  90 + if err != nil {
  91 + return err
  92 + }
  93 + }
  94 + //减少加段落评论计数
  95 + if commetInfo.SectionId > 0 {
  96 + err = l.svcCtx.ArticleSectionRepository.IncreaseCountComment(ctx, c, -1, commetInfo.SectionId)
  97 + if err != nil {
  98 + return err
  99 + }
  100 + }
  101 + // 减少文章的评论数
  102 + err = l.svcCtx.ArticleRepository.IncreaseCountComment(ctx, c, -1, commetInfo.ArticleId)
  103 + if err != nil {
  104 + return err
  105 + }
  106 + return nil
  107 + }, true)
  108 +
  109 + if err != nil {
  110 + return xerr.NewErrMsgErr("删除评论信息失败", err)
  111 + }
  112 + return nil
  113 +}
  114 +
  115 +func (l *SystemEditAticleCommentShowLogic) enableShow(commentId int64, companyId int64) error {
  116 + var conn = l.svcCtx.DefaultDBConn()
  117 + commetInfo, err := l.svcCtx.ArticleCommentRepository.FindOne(l.ctx, conn, commentId)
  118 + if err != nil {
  119 + return xerr.NewErrMsgErr("删除评论信息失败", err)
  120 + }
  121 + if commetInfo.CompanyId != companyId {
  122 + return xerr.NewErrMsg("没有操作权限")
  123 + }
  124 + if commetInfo.Show == domain.CommentShowEnable {
  125 + return nil
  126 + }
  127 + commetInfo.Show = domain.CommentShowEnable
  128 + // 变更回复数量
  129 + err = transaction.UseTrans(l.ctx, conn.DB(), func(ctx context.Context, c transaction.Conn) error {
  130 + _, err = l.svcCtx.ArticleCommentRepository.Update(ctx, c, commetInfo)
  131 + if err != nil {
  132 + return err
  133 + }
  134 + // 增加上级评论的回复数量
  135 + if commetInfo.Pid != 0 {
  136 + err = l.svcCtx.ArticleCommentRepository.IncreaseCountReply(l.ctx, c, 1, commetInfo.Pid)
  137 + if err != nil {
  138 + return err
  139 + }
  140 + }
  141 + // 增加最顶层的评论回复计数
  142 + if commetInfo.TopId != 0 && commetInfo.Pid != commetInfo.TopId {
  143 + err = l.svcCtx.ArticleCommentRepository.IncreaseCountReply(l.ctx, c, 1, commetInfo.TopId)
  144 + if err != nil {
  145 + return err
  146 + }
  147 + }
  148 + //增加加段落评论计数
  149 + if commetInfo.SectionId > 0 {
  150 + err = l.svcCtx.ArticleSectionRepository.IncreaseCountComment(ctx, c, 1, commetInfo.SectionId)
  151 + if err != nil {
  152 + return err
  153 + }
  154 + }
  155 + // 增加文章的评论数
  156 + err = l.svcCtx.ArticleRepository.IncreaseCountComment(ctx, c, 1, commetInfo.ArticleId)
  157 + if err != nil {
  158 + return err
  159 + }
  160 + return nil
  161 + }, true)
  162 +
  163 + if err != nil {
  164 + return xerr.NewErrMsgErr("删除评论信息失败", err)
  165 + }
  166 + return nil
  167 +}
  1 +package comment
  2 +
  3 +import (
  4 + "context"
  5 +
  6 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc"
  7 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types"
  8 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr"
  9 +
  10 + "github.com/zeromicro/go-zero/core/logx"
  11 +)
  12 +
  13 +type SystemGetAticleCommentLogic struct {
  14 + logx.Logger
  15 + ctx context.Context
  16 + svcCtx *svc.ServiceContext
  17 +}
  18 +
  19 +func NewSystemGetAticleCommentLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SystemGetAticleCommentLogic {
  20 + return &SystemGetAticleCommentLogic{
  21 + Logger: logx.WithContext(ctx),
  22 + ctx: ctx,
  23 + svcCtx: svcCtx,
  24 + }
  25 +}
  26 +
  27 +func (l *SystemGetAticleCommentLogic) SystemGetAticleComment(req *types.SystemGetCommentRequest) (resp *types.SystemGetCommentResponse, err error) {
  28 + var conn = l.svcCtx.DefaultDBConn()
  29 +
  30 + commentInfo, err := l.svcCtx.ArticleCommentRepository.FindOne(l.ctx, conn, req.Id)
  31 + if err != nil {
  32 + return nil, xerr.NewErrMsgErr("获取评论详情失败", err)
  33 + }
  34 + if commentInfo.CompanyId != req.CompanyId {
  35 + return nil, xerr.NewErrMsg("没有查看权限")
  36 + }
  37 + resp = &types.SystemGetCommentResponse{
  38 + Id: commentInfo.Id,
  39 + Pid: commentInfo.Pid,
  40 + TopId: commentInfo.TopId,
  41 + ArticleId: commentInfo.ArticleId,
  42 + ArticleTitle: "",
  43 + FromUserId: commentInfo.FromUserId,
  44 + FromUser: types.CommentAuthor{
  45 + Id: commentInfo.FromUserId,
  46 + Name: commentInfo.FromUser.Name,
  47 + Avatar: commentInfo.FromUser.Avatar,
  48 + Position: commentInfo.FromUser.Position,
  49 + Company: commentInfo.FromUser.Company,
  50 + },
  51 + CreatedAt: commentInfo.CreatedAt,
  52 + SectionContent: commentInfo.SectionContent,
  53 + Content: commentInfo.Content,
  54 + Show: int(commentInfo.Show),
  55 + CountReply: commentInfo.CountReply,
  56 + CountUserLove: commentInfo.CountUserLove,
  57 + CountAdminLove: commentInfo.CountAdminLove,
  58 + }
  59 + return resp, nil
  60 +}
  1 +package comment
  2 +
  3 +import (
  4 + "context"
  5 +
  6 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc"
  7 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types"
  8 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr"
  9 +
  10 + "github.com/zeromicro/go-zero/core/logx"
  11 +)
  12 +
  13 +type SystemListAticleCommentLogic struct {
  14 + logx.Logger
  15 + ctx context.Context
  16 + svcCtx *svc.ServiceContext
  17 +}
  18 +
  19 +func NewSystemListAticleCommentLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SystemListAticleCommentLogic {
  20 + return &SystemListAticleCommentLogic{
  21 + Logger: logx.WithContext(ctx),
  22 + ctx: ctx,
  23 + svcCtx: svcCtx,
  24 + }
  25 +}
  26 +
  27 +// 管理后台评论列表
  28 +func (l *SystemListAticleCommentLogic) SystemListAticleComment(req *types.SystemListCommentRequest) (resp *types.SystemListCommentResponse, err error) {
  29 + var conn = l.svcCtx.DefaultDBConn()
  30 +
  31 + cnt, commentList, err := l.svcCtx.ArticleCommentRepository.CustomSearchBy(l.ctx, conn, req.CompanyId, req.Page, req.Size,
  32 + req.TopId, req.ArticleTitle, req.Content, req.FromUser, req.Show,
  33 + )
  34 + if err != nil {
  35 + return nil, xerr.NewErrMsgErr("获取评论列表失败", err)
  36 + }
  37 +
  38 + resp = &types.SystemListCommentResponse{
  39 + Total: cnt,
  40 + List: make([]types.SystemCommentItem, len(commentList)),
  41 + }
  42 +
  43 + for i, val := range commentList {
  44 + resp.List[i] = types.SystemCommentItem{
  45 + Id: val.Id,
  46 + Pid: val.Pid,
  47 + TopId: val.TopId,
  48 + ArticleTitle: val.ArticleTitle,
  49 + FromUserId: val.FromUserId,
  50 + FromUser: types.CommentAuthor{
  51 + Id: val.FromUser.Id,
  52 + Name: val.FromUser.Name,
  53 + Avatar: val.FromUser.Avatar,
  54 + Position: val.FromUser.Position,
  55 + Company: val.FromUser.Company,
  56 + },
  57 + CreatedAt: val.CreatedAt,
  58 + Content: val.Content,
  59 + Show: val.Show,
  60 + CountReply: val.CountReply,
  61 + CountUserLove: val.CountUserLove,
  62 + CountAdminLove: val.CountAdminLove,
  63 + }
  64 + }
  65 +
  66 + return resp, nil
  67 +}
@@ -3,6 +3,8 @@ package user @@ -3,6 +3,8 @@ package user
3 import ( 3 import (
4 "context" 4 "context"
5 "fmt" 5 "fmt"
  6 + "strconv"
  7 +
6 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc" 8 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc"
7 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types" 9 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types"
8 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain" 10 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain"
@@ -10,7 +12,6 @@ import ( @@ -10,7 +12,6 @@ import (
10 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata" 12 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata"
11 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/tool" 13 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/tool"
12 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr" 14 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr"
13 - "strconv"  
14 15
15 "github.com/zeromicro/go-zero/core/logx" 16 "github.com/zeromicro/go-zero/core/logx"
16 ) 17 )
@@ -94,3 +95,10 @@ func (l *SystemUserInfoLogic) SystemUserInfo(req *types.SystemUserInfoRequest) ( @@ -94,3 +95,10 @@ func (l *SystemUserInfoLogic) SystemUserInfo(req *types.SystemUserInfoRequest) (
94 } 95 }
95 return 96 return
96 } 97 }
  98 +
  99 +// 后台登录时 ,检查/设置公司的初始数据
  100 +func (l *SystemUserInfoLogic) initSystemData(companyId int64) error {
  101 + // TODO 初始设置文章标签
  102 +
  103 + return nil
  104 +}
@@ -168,6 +168,83 @@ type SystemArticleCommentSearchItem struct { @@ -168,6 +168,83 @@ type SystemArticleCommentSearchItem struct {
168 Show int `json:"show"` // 显示状态 168 Show int `json:"show"` // 显示状态
169 } 169 }
170 170
  171 +type SystemListCommentRequest struct {
  172 + Page int `json:"page"`
  173 + Size int `json:"size"`
  174 + CompanyId int64 `json:",optional"` //
  175 + TopId int64 `json:"topId"` // 评论的顶层ID
  176 + FromUser string `json:"fromUser,optional"` // 用户
  177 + Show int `json:"show,optional"` // 显示状态
  178 + BeginTime int64 `json:"beginTime,optional"` // 填写评论的开始时间
  179 + EndTime int64 `json:"endTime,optional"` // 填写评论的结束时间
  180 + ArticleTitle string `json:"articleTitle,optional"` //
  181 + Content string `json:"content,optional"` //
  182 +}
  183 +
  184 +type SystemListCommentResponse struct {
  185 + Total int `json:"total"`
  186 + List []SystemCommentItem `json:"list"`
  187 +}
  188 +
  189 +type SystemCommentItem struct {
  190 + Id int64 `json:"id"` //评论id
  191 + Pid int64 `json:"pid"` //
  192 + TopId int64 `json:"topId"` //
  193 + ArticleId int64 `json:"articleId"` //对应的文章id
  194 + ArticleTitle string `json:"articleTitle"` //文章标题
  195 + FromUserId int64 `json:"fromUserId"` //填写评论的人
  196 + FromUser CommentAuthor `json:"fromUser"` //填写评论的人
  197 + CreatedAt int64 `json:"createdAt"` //评论的填写时间
  198 + Content string `json:"content"` //评论的内容
  199 + Show int `json:"show"` //是否展示 [1显示] [2不显示]
  200 + CountReply int `json:"countReplay"` //回复数量
  201 + CountUserLove int `json:"countUserLove"` //用户点赞数量
  202 + CountAdminLove int `json:"countAdminLove"` //运营点赞数量
  203 +}
  204 +
  205 +type SystemGetCommentRequest struct {
  206 + CompanyId int64 `path:",optional"`
  207 + Id int64 `path:"id"`
  208 +}
  209 +
  210 +type SystemGetCommentResponse struct {
  211 + Id int64 `json:"id"` //评论id
  212 + Pid int64 `json:"pid"` //
  213 + TopId int64 `json:"topId"` //
  214 + ArticleId int64 `json:"articleId"` //对应的文章id
  215 + ArticleTitle string `json:"articleTitle"` //文章标题
  216 + FromUserId int64 `json:"fromUserId"` //填写评论的人
  217 + FromUser CommentAuthor `json:"fromUser"` //填写评论的人
  218 + CreatedAt int64 `json:"createdAt"` //评论的填写时间
  219 + SectionContent string `json:"sectionContent"` //引用的段落内容
  220 + Content string `json:"content"` // 评论的内容
  221 + Show int `json:"show"` //是否展示 [1显示] [2不显示]
  222 + CountReply int `json:"countReplay"` //回复数量
  223 + CountUserLove int `json:"countUserLove"` //用户点赞数量
  224 + CountAdminLove int `json:"countAdminLove"` //运营点赞数量
  225 +}
  226 +
  227 +type SystemEditCommentShowRequest struct {
  228 + CompanyId int64 `json:",optional"`
  229 + Id []int64 `json:"id"`
  230 + Show int `json:"show"` //[1 显示评论] [2: 隐藏评论]
  231 +}
  232 +
  233 +type SystemEditCommentShowResponse struct {
  234 + Id []int64 `json:"id"`
  235 +}
  236 +
  237 +type SystemEditCommentRequest struct {
  238 + CompanyId int64 `json:",optional"`
  239 + Id int64 `json:"id"`
  240 + Show int `json:"show"` //[1 显示评论] [2: 隐藏评论]
  241 + CountAdminLove int `json:"countAdminLove,optional"`
  242 +}
  243 +
  244 +type SystemEditCommentResponse struct {
  245 + Id int64 `json:"id"`
  246 +}
  247 +
171 type MessageSystemRequest struct { 248 type MessageSystemRequest struct {
172 Page int `json:"page"` 249 Page int `json:"page"`
173 Size int `json:"size"` 250 Size int `json:"size"`
@@ -70,3 +70,18 @@ func (m *ArticleComment) CachePrimaryKeyFunc() string { @@ -70,3 +70,18 @@ func (m *ArticleComment) CachePrimaryKeyFunc() string {
70 } 70 }
71 return fmt.Sprintf("%v:cache:%v:primarykey:%v", domain.ProjectName, m.TableName(), "key") 71 return fmt.Sprintf("%v:cache:%v:primarykey:%v", domain.ProjectName, m.TableName(), "key")
72 } 72 }
  73 +
  74 +type ArticleCommentShow struct {
  75 + Id int64 //评论id
  76 + Pid int64
  77 + TopId int64
  78 + ArticleTitle string //文章标题
  79 + FromUserId int64 // 评论填写人的id
  80 + FromUser domain.UserSimple `gorm:"type:jsonb;serializer:json"`
  81 + Content string // 评论内容
  82 + CountReply int // 回复数量
  83 + CountUserLove int // 用户点赞数量
  84 + CountAdminLove int // 运营点赞数量
  85 + Show int // 评论的展示状态(0显示、1不显示)
  86 + CreatedAt int64 // 评论的创建时间
  87 +}
@@ -325,6 +325,98 @@ func (repository *ArticleCommentRepository) Top5Comment(ctx context.Context, con @@ -325,6 +325,98 @@ func (repository *ArticleCommentRepository) Top5Comment(ctx context.Context, con
325 } 325 }
326 return dms, nil 326 return dms, nil
327 } 327 }
  328 +
  329 +func (repository *ArticleCommentRepository) CustomSearchBy(ctx context.Context, conn transaction.Conn, companyId int64, page int, size int,
  330 + topId int64, articleTitle string, contentLike string, fromUserName string, show int) (int, []*domain.ArticleCommentShow, error) {
  331 +
  332 + if size <= 0 {
  333 + size = 20
  334 + }
  335 + if page <= 0 {
  336 + page = 1
  337 + }
  338 +
  339 + where := " and article_comment.company_id=? "
  340 + condition := []interface{}{companyId}
  341 +
  342 + if len(articleTitle) > 0 {
  343 + where += ` and article.title like ? `
  344 + condition = append(condition, "%"+articleTitle+"%")
  345 + }
  346 + if len(contentLike) > 0 {
  347 + where += ` and article_comment."content" like ? `
  348 + condition = append(condition, "%"+contentLike+"%")
  349 + }
  350 +
  351 + if len(fromUserName) > 0 {
  352 + where += ` and article_comment.from_user ->>'name' like ? `
  353 + condition = append(condition, "%"+fromUserName+"%")
  354 + }
  355 + if show > 0 {
  356 + where += ` and article_comment."show" =? `
  357 + condition = append(condition, show)
  358 + }
  359 +
  360 + if topId >= 0 {
  361 + where += ` and article_comment."top_id"= ? `
  362 + condition = append(condition, topId)
  363 + }
  364 + countSql := `select
  365 + count(*)
  366 + from article_comment
  367 + join article on article.id = article_comment.article_id
  368 + where 1=1 ` + where
  369 +
  370 + var cnt int
  371 + db := conn.DB()
  372 + result := db.Raw(countSql, condition...).Scan(&cnt)
  373 + if result.Error != nil {
  374 + return 0, nil, result.Error
  375 + }
  376 +
  377 + dataSql := `select
  378 + article.title as article_title ,
  379 + article_comment.id ,
  380 + article_comment.pid,
  381 + article_comment.top_id,
  382 + article_comment.from_user_id ,
  383 + article_comment.from_user,
  384 + article_comment."content" ,
  385 + article_comment.created_at ,
  386 + article_comment.count_reply ,
  387 + article_comment.count_user_love ,
  388 + article_comment.count_admin_love ,
  389 + article_comment."show"
  390 + from article_comment
  391 + join article on article.id = article_comment.article_id
  392 + where 1=1` + where + ` order by article_comment.id desc limit ? offset ? `
  393 +
  394 + condition = append(condition, size, (page-1)*size)
  395 +
  396 + ms := []models.ArticleCommentShow{}
  397 + result = db.Raw(dataSql, condition...).Scan(&ms)
  398 + if result.Error != nil {
  399 + return 0, nil, result.Error
  400 + }
  401 + d := []*domain.ArticleCommentShow{}
  402 + for _, val := range ms {
  403 + d = append(d, &domain.ArticleCommentShow{
  404 + ArticleTitle: val.ArticleTitle,
  405 + Id: val.Id,
  406 + FromUserId: val.FromUserId,
  407 + FromUser: val.FromUser,
  408 + Content: val.Content,
  409 + CountReply: val.CountReply,
  410 + CountUserLove: val.CountUserLove,
  411 + CountAdminLove: val.CountAdminLove,
  412 + Show: val.Show,
  413 + CreatedAt: val.CreatedAt,
  414 + })
  415 + }
  416 + return cnt, d, nil
  417 +
  418 +}
  419 +
328 func NewArticleCommentRepository(cache *cache.CachedRepository) domain.ArticleCommentRepository { 420 func NewArticleCommentRepository(cache *cache.CachedRepository) domain.ArticleCommentRepository {
329 return &ArticleCommentRepository{CachedRepository: cache} 421 return &ArticleCommentRepository{CachedRepository: cache}
330 } 422 }
@@ -435,7 +435,7 @@ func (repository *ArticleRepository) CustomSearchBy(ctx context.Context, conn tr @@ -435,7 +435,7 @@ func (repository *ArticleRepository) CustomSearchBy(ctx context.Context, conn tr
435 tx = tx.Where("article_and_tag.tag_id=?", tagId) 435 tx = tx.Where("article_and_tag.tag_id=?", tagId)
436 } else if len(tagCategory) > 0 { 436 } else if len(tagCategory) > 0 {
437 tx = tx.Joins(`join article_and_tag on article.id = article_and_tag.article_id`) 437 tx = tx.Joins(`join article_and_tag on article.id = article_and_tag.article_id`)
438 - tx = tx.Where(`article_and_tag.tag_id =any(select article_tag.id from article_tag where category =%s )`, tagCategory) 438 + tx = tx.Where(`article_and_tag.tag_id =any(select article_tag.id from article_tag where category =? )`, tagCategory)
439 } 439 }
440 if len(titleLike) > 0 { 440 if len(titleLike) > 0 {
441 tx = tx.Where("article.title like ?", "%"+titleLike+"%") 441 tx = tx.Where("article.title like ?", "%"+titleLike+"%")
@@ -33,6 +33,8 @@ func (repository *ArticleTagRepository) Insert(ctx context.Context, conn transac @@ -33,6 +33,8 @@ func (repository *ArticleTagRepository) Insert(ctx context.Context, conn transac
33 33
34 } 34 }
35 35
  36 +// func (repository *ArticleTagRepository) CreateInBatches
  37 +
36 func (repository *ArticleTagRepository) Update(ctx context.Context, conn transaction.Conn, dm *domain.ArticleTag) (*domain.ArticleTag, error) { 38 func (repository *ArticleTagRepository) Update(ctx context.Context, conn transaction.Conn, dm *domain.ArticleTag) (*domain.ArticleTag, error) {
37 var ( 39 var (
38 err error 40 err error
@@ -50,6 +50,21 @@ func (show CommentShow) Named() string { @@ -50,6 +50,21 @@ func (show CommentShow) Named() string {
50 return "" 50 return ""
51 } 51 }
52 52
  53 +type ArticleCommentShow struct {
  54 + Id int64 // 评论id
  55 + Pid int64
  56 + TopId int64
  57 + ArticleTitle string // 文章标题
  58 + FromUserId int64 // 评论填写人的id
  59 + FromUser UserSimple // 评论填写人
  60 + Content string // 评论内容
  61 + CountReply int // 回复数量
  62 + CountUserLove int // 用户点赞数量
  63 + CountAdminLove int // 运营点赞数量
  64 + Show int // 评论的展示状态(0显示、1不显示)
  65 + CreatedAt int64 // 评论的创建时间
  66 +}
  67 +
53 type ArticleCommentRepository interface { 68 type ArticleCommentRepository interface {
54 Insert(ctx context.Context, conn transaction.Conn, dm *ArticleComment) (*ArticleComment, error) 69 Insert(ctx context.Context, conn transaction.Conn, dm *ArticleComment) (*ArticleComment, error)
55 Update(ctx context.Context, conn transaction.Conn, dm *ArticleComment) (*ArticleComment, error) 70 Update(ctx context.Context, conn transaction.Conn, dm *ArticleComment) (*ArticleComment, error)
@@ -60,4 +75,7 @@ type ArticleCommentRepository interface { @@ -60,4 +75,7 @@ type ArticleCommentRepository interface {
60 IncreaseCountUserLove(ctx context.Context, conn transaction.Conn, incr int, commentId int64) error //点赞数量变动 75 IncreaseCountUserLove(ctx context.Context, conn transaction.Conn, incr int, commentId int64) error //点赞数量变动
61 IncreaseCountReply(ctx context.Context, conn transaction.Conn, incr int, commentId int64) error // 评论回复数量变动 76 IncreaseCountReply(ctx context.Context, conn transaction.Conn, incr int, commentId int64) error // 评论回复数量变动
62 Top5Comment(ctx context.Context, conn transaction.Conn, companyId int64, articleId int64) ([]*ArticleComment, error) 77 Top5Comment(ctx context.Context, conn transaction.Conn, companyId int64, articleId int64) ([]*ArticleComment, error)
  78 + // 特定的查询
  79 + CustomSearchBy(ctx context.Context, conn transaction.Conn, companyId int64, page int, size int,
  80 + topId int64, articleTitle string, contentLike string, fromUserName string, show int) (int, []*ArticleCommentShow, error)
63 } 81 }
  1 +#!/bin/bash
  2 +export PATH=/root/local/bin:$PATH
  3 +kubectl -n mmm-suplus-test get pods | grep -q sumifcc-discuss
  4 +if [ "$?" == "1" ];then
  5 + kubectl create -f /tmp/test/sumifcc-discuss/sumifcc-discuss.yaml --record
  6 + kubectl -n mmm-suplus-test get svc | grep -q sumifcc-discuss
  7 + if [ "$?" == "0" ];then
  8 + echo "sumifcc-discuss service install success!"
  9 + else
  10 + echo "sumifcc-discuss service install fail!"
  11 + fi
  12 + kubectl -n mmm-suplus-test get pods | grep -q sumifcc-discuss
  13 + if [ "$?" == "0" ];then
  14 + echo "sumifcc-discuss deployment install success!"
  15 + else
  16 + echo "sumifcc-discuss deployment install fail!"
  17 + fi
  18 +else
  19 + kubectl delete -f /tmp/test/sumifcc-discuss/sumifcc-discuss.yaml
  20 + kubectl -n mmm-suplus-test get svc | grep -q sumifcc-discuss
  21 + while [ "$?" == "0" ]
  22 + do
  23 + kubectl -n mmm-suplus-test get svc | grep -q sumifcc-discuss
  24 + done
  25 + kubectl -n mmm-suplus-test get pods | grep -q sumifcc-discuss
  26 + while [ "$?" == "0" ]
  27 + do
  28 + kubectl -n mmm-suplus-test get pods | grep -q sumifcc-discuss
  29 + done
  30 + kubectl create -f /tmp/test/sumifcc-discuss/sumifcc-discuss.yaml --record
  31 + kubectl -n mmm-suplus-test get svc | grep -q sumifcc-discuss
  32 + if [ "$?" == "0" ];then
  33 + echo "sumifcc-discuss service update success!"
  34 + else
  35 + echo "sumifcc-discuss service update fail!"
  36 + fi
  37 + kubectl -n mmm-suplus-test get pods | grep -q sumifcc-discuss
  38 + if [ "$?" == "0" ];then
  39 + echo "sumifcc-discuss deployment update success!"
  40 + else
  41 + echo "sumifcc-discuss deployment update fail!"
  42 + fi
  43 +fi
@@ -10,7 +10,7 @@ type Auth struct { @@ -10,7 +10,7 @@ type Auth struct {
10 } 10 }
11 type Config struct { 11 type Config struct {
12 DB struct { 12 DB struct {
13 - DataSource string 13 + DataSource string `json:",env=DataSource"`
14 } `json:",optional"` 14 } `json:",optional"`
15 Cache cache.CacheConf `json:",optional"` 15 Cache cache.CacheConf `json:",optional"`
16 DTM DTM `json:",optional"` 16 DTM DTM `json:",optional"`