Merge branch 'dev' of http://gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss into dev
正在显示
61 个修改的文件
包含
1368 行增加
和
342 行删除
@@ -293,34 +293,6 @@ | @@ -293,34 +293,6 @@ | ||
293 | ] | 293 | ] |
294 | } | 294 | } |
295 | }, | 295 | }, |
296 | - "v1/mini/article_comment/at_user/select": { | ||
297 | - "post": { | ||
298 | - "summary": "小程序获取回复@人可选列表", | ||
299 | - "operationId": "MiniArticleCommentAtUser", | ||
300 | - "responses": { | ||
301 | - "200": { | ||
302 | - "description": "A successful response.", | ||
303 | - "schema": { | ||
304 | - "$ref": "#/definitions/MiniArticleCommentAtUserResponse" | ||
305 | - } | ||
306 | - } | ||
307 | - }, | ||
308 | - "parameters": [ | ||
309 | - { | ||
310 | - "name": "body", | ||
311 | - "in": "body", | ||
312 | - "required": true, | ||
313 | - "schema": { | ||
314 | - "$ref": "#/definitions/MiniArticleCommentAtUserRequest" | ||
315 | - } | ||
316 | - } | ||
317 | - ], | ||
318 | - "requestBody": {}, | ||
319 | - "tags": [ | ||
320 | - "comment" | ||
321 | - ] | ||
322 | - } | ||
323 | - }, | ||
324 | "v1/mini/article_comment/at_who/list": { | 296 | "v1/mini/article_comment/at_who/list": { |
325 | "post": { | 297 | "post": { |
326 | "summary": "小程序展示评论时@人可选列表", | 298 | "summary": "小程序展示评论时@人可选列表", |
@@ -631,22 +603,6 @@ | @@ -631,22 +603,6 @@ | ||
631 | "required": false, | 603 | "required": false, |
632 | "type": "integer", | 604 | "type": "integer", |
633 | "format": "int64" | 605 | "format": "int64" |
634 | - }, | ||
635 | - { | ||
636 | - "name": "articleId", | ||
637 | - "description": " 文章id", | ||
638 | - "in": "query", | ||
639 | - "required": true, | ||
640 | - "type": "integer", | ||
641 | - "format": "int64" | ||
642 | - }, | ||
643 | - { | ||
644 | - "name": "tagId", | ||
645 | - "description": " 标签id", | ||
646 | - "in": "query", | ||
647 | - "required": true, | ||
648 | - "type": "integer", | ||
649 | - "format": "int64" | ||
650 | } | 606 | } |
651 | ], | 607 | ], |
652 | "requestBody": {}, | 608 | "requestBody": {}, |
@@ -1211,6 +1167,64 @@ | @@ -1211,6 +1167,64 @@ | ||
1211 | ] | 1167 | ] |
1212 | } | 1168 | } |
1213 | }, | 1169 | }, |
1170 | + "v1/system/article": { | ||
1171 | + "put": { | ||
1172 | + "summary": "管理后台编辑帖子", | ||
1173 | + "operationId": "SystemUpdateArticle", | ||
1174 | + "responses": { | ||
1175 | + "200": { | ||
1176 | + "description": "A successful response.", | ||
1177 | + "schema": { | ||
1178 | + "$ref": "#/definitions/SystemArticleUpdateResponse" | ||
1179 | + } | ||
1180 | + } | ||
1181 | + }, | ||
1182 | + "parameters": [ | ||
1183 | + { | ||
1184 | + "name": "body", | ||
1185 | + "description": "编辑", | ||
1186 | + "in": "body", | ||
1187 | + "required": true, | ||
1188 | + "schema": { | ||
1189 | + "$ref": "#/definitions/SystemArticleUpdateRequest" | ||
1190 | + } | ||
1191 | + } | ||
1192 | + ], | ||
1193 | + "requestBody": {}, | ||
1194 | + "tags": [ | ||
1195 | + "article" | ||
1196 | + ] | ||
1197 | + } | ||
1198 | + }, | ||
1199 | + "v1/system/article/history": { | ||
1200 | + "post": { | ||
1201 | + "summary": "管理后台编辑历史", | ||
1202 | + "operationId": "SystemHistoryArticle", | ||
1203 | + "responses": { | ||
1204 | + "200": { | ||
1205 | + "description": "A successful response.", | ||
1206 | + "schema": { | ||
1207 | + "$ref": "#/definitions/SystemArticleHistoryResponse" | ||
1208 | + } | ||
1209 | + } | ||
1210 | + }, | ||
1211 | + "parameters": [ | ||
1212 | + { | ||
1213 | + "name": "body", | ||
1214 | + "description": "历史", | ||
1215 | + "in": "body", | ||
1216 | + "required": true, | ||
1217 | + "schema": { | ||
1218 | + "$ref": "#/definitions/SystemArticleHistoryRequest" | ||
1219 | + } | ||
1220 | + } | ||
1221 | + ], | ||
1222 | + "requestBody": {}, | ||
1223 | + "tags": [ | ||
1224 | + "article" | ||
1225 | + ] | ||
1226 | + } | ||
1227 | + }, | ||
1214 | "v1/system/article/search": { | 1228 | "v1/system/article/search": { |
1215 | "post": { | 1229 | "post": { |
1216 | "summary": "管理后台获取文章列表", | 1230 | "summary": "管理后台获取文章列表", |
@@ -2240,6 +2254,25 @@ | @@ -2240,6 +2254,25 @@ | ||
2240 | "totalComment" | 2254 | "totalComment" |
2241 | ] | 2255 | ] |
2242 | }, | 2256 | }, |
2257 | + "ArticleTagGroup": { | ||
2258 | + "type": "object", | ||
2259 | + "properties": { | ||
2260 | + "group": { | ||
2261 | + "type": "string" | ||
2262 | + }, | ||
2263 | + "tags": { | ||
2264 | + "type": "array", | ||
2265 | + "items": { | ||
2266 | + "$ref": "#/definitions/ArticleTagItem" | ||
2267 | + } | ||
2268 | + } | ||
2269 | + }, | ||
2270 | + "title": "ArticleTagGroup", | ||
2271 | + "required": [ | ||
2272 | + "group", | ||
2273 | + "tags" | ||
2274 | + ] | ||
2275 | + }, | ||
2243 | "ArticleTagItem": { | 2276 | "ArticleTagItem": { |
2244 | "type": "object", | 2277 | "type": "object", |
2245 | "properties": { | 2278 | "properties": { |
@@ -2252,13 +2285,17 @@ | @@ -2252,13 +2285,17 @@ | ||
2252 | }, | 2285 | }, |
2253 | "name": { | 2286 | "name": { |
2254 | "type": "string" | 2287 | "type": "string" |
2288 | + }, | ||
2289 | + "image": { | ||
2290 | + "type": "string" | ||
2255 | } | 2291 | } |
2256 | }, | 2292 | }, |
2257 | "title": "ArticleTagItem", | 2293 | "title": "ArticleTagItem", |
2258 | "required": [ | 2294 | "required": [ |
2259 | "id", | 2295 | "id", |
2260 | "group", | 2296 | "group", |
2261 | - "name" | 2297 | + "name", |
2298 | + "image" | ||
2262 | ] | 2299 | ] |
2263 | }, | 2300 | }, |
2264 | "Auth": { | 2301 | "Auth": { |
@@ -2294,6 +2331,9 @@ | @@ -2294,6 +2331,9 @@ | ||
2294 | }, | 2331 | }, |
2295 | "name": { | 2332 | "name": { |
2296 | "type": "string" | 2333 | "type": "string" |
2334 | + }, | ||
2335 | + "firstLetter": { | ||
2336 | + "type": "string" | ||
2297 | } | 2337 | } |
2298 | }, | 2338 | }, |
2299 | "title": "CommentAtWho", | 2339 | "title": "CommentAtWho", |
@@ -2806,23 +2846,9 @@ | @@ -2806,23 +2846,9 @@ | ||
2806 | "type": "integer", | 2846 | "type": "integer", |
2807 | "format": "int64", | 2847 | "format": "int64", |
2808 | "description": " 公司id" | 2848 | "description": " 公司id" |
2809 | - }, | ||
2810 | - "articleId": { | ||
2811 | - "type": "integer", | ||
2812 | - "format": "int64", | ||
2813 | - "description": " 文章id" | ||
2814 | - }, | ||
2815 | - "tagId": { | ||
2816 | - "type": "integer", | ||
2817 | - "format": "int64", | ||
2818 | - "description": " 标签id" | ||
2819 | } | 2849 | } |
2820 | }, | 2850 | }, |
2821 | - "title": "MiniAllArticleTagRequest", | ||
2822 | - "required": [ | ||
2823 | - "articleId", | ||
2824 | - "tagId" | ||
2825 | - ] | 2851 | + "title": "MiniAllArticleTagRequest" |
2826 | }, | 2852 | }, |
2827 | "MiniAllArticleTagResponse": { | 2853 | "MiniAllArticleTagResponse": { |
2828 | "type": "object", | 2854 | "type": "object", |
@@ -2830,20 +2856,13 @@ | @@ -2830,20 +2856,13 @@ | ||
2830 | "tagGroup": { | 2856 | "tagGroup": { |
2831 | "type": "array", | 2857 | "type": "array", |
2832 | "items": { | 2858 | "items": { |
2833 | - "type": "string" | ||
2834 | - } | ||
2835 | - }, | ||
2836 | - "tags": { | ||
2837 | - "type": "array", | ||
2838 | - "items": { | ||
2839 | - "$ref": "#/definitions/ArticleTagItem" | 2859 | + "$ref": "#/definitions/ArticleTagGroup" |
2840 | } | 2860 | } |
2841 | } | 2861 | } |
2842 | }, | 2862 | }, |
2843 | "title": "MiniAllArticleTagResponse", | 2863 | "title": "MiniAllArticleTagResponse", |
2844 | "required": [ | 2864 | "required": [ |
2845 | - "tagGroup", | ||
2846 | - "tags" | 2865 | + "tagGroup" |
2847 | ] | 2866 | ] |
2848 | }, | 2867 | }, |
2849 | "MiniArticleBackupItem": { | 2868 | "MiniArticleBackupItem": { |
@@ -2931,23 +2950,6 @@ | @@ -2931,23 +2950,6 @@ | ||
2931 | "list" | 2950 | "list" |
2932 | ] | 2951 | ] |
2933 | }, | 2952 | }, |
2934 | - "MiniArticleCommentAtUserRequest": { | ||
2935 | - "type": "object", | ||
2936 | - "properties": { | ||
2937 | - "articleId": { | ||
2938 | - "type": "integer", | ||
2939 | - "format": "int64" | ||
2940 | - } | ||
2941 | - }, | ||
2942 | - "title": "MiniArticleCommentAtUserRequest", | ||
2943 | - "required": [ | ||
2944 | - "articleId" | ||
2945 | - ] | ||
2946 | - }, | ||
2947 | - "MiniArticleCommentAtUserResponse": { | ||
2948 | - "type": "object", | ||
2949 | - "title": "MiniArticleCommentAtUserResponse" | ||
2950 | - }, | ||
2951 | "MiniArticleCommentAtWhoRequest": { | 2953 | "MiniArticleCommentAtWhoRequest": { |
2952 | "type": "object", | 2954 | "type": "object", |
2953 | "properties": { | 2955 | "properties": { |
@@ -5022,6 +5024,96 @@ | @@ -5022,6 +5024,96 @@ | ||
5022 | "show" | 5024 | "show" |
5023 | ] | 5025 | ] |
5024 | }, | 5026 | }, |
5027 | + "SystemArticleHistory": { | ||
5028 | + "type": "object", | ||
5029 | + "properties": { | ||
5030 | + "id": { | ||
5031 | + "type": "integer", | ||
5032 | + "format": "int64", | ||
5033 | + "description": "id" | ||
5034 | + }, | ||
5035 | + "author": { | ||
5036 | + "type": "string", | ||
5037 | + "description": "编辑人" | ||
5038 | + }, | ||
5039 | + "action": { | ||
5040 | + "type": "string", | ||
5041 | + "description": "编辑类型" | ||
5042 | + }, | ||
5043 | + "updatedAt": { | ||
5044 | + "type": "integer", | ||
5045 | + "format": "int64", | ||
5046 | + "description": "编辑时间" | ||
5047 | + } | ||
5048 | + }, | ||
5049 | + "title": "SystemArticleHistory", | ||
5050 | + "required": [ | ||
5051 | + "id", | ||
5052 | + "author", | ||
5053 | + "action", | ||
5054 | + "updatedAt" | ||
5055 | + ] | ||
5056 | + }, | ||
5057 | + "SystemArticleHistoryRequest": { | ||
5058 | + "type": "object", | ||
5059 | + "properties": { | ||
5060 | + "articleId": { | ||
5061 | + "type": "integer", | ||
5062 | + "format": "int64", | ||
5063 | + "description": "文章ID" | ||
5064 | + }, | ||
5065 | + "author": { | ||
5066 | + "type": "string", | ||
5067 | + "description": "发布人" | ||
5068 | + }, | ||
5069 | + "beginTime": { | ||
5070 | + "type": "integer", | ||
5071 | + "format": "int64", | ||
5072 | + "description": "开始时间" | ||
5073 | + }, | ||
5074 | + "endTime": { | ||
5075 | + "type": "integer", | ||
5076 | + "format": "int64", | ||
5077 | + "description": "结束时间" | ||
5078 | + }, | ||
5079 | + "page": { | ||
5080 | + "type": "integer", | ||
5081 | + "format": "int32", | ||
5082 | + "description": "页码" | ||
5083 | + }, | ||
5084 | + "size": { | ||
5085 | + "type": "integer", | ||
5086 | + "format": "int32", | ||
5087 | + "description": "每页行数" | ||
5088 | + } | ||
5089 | + }, | ||
5090 | + "title": "SystemArticleHistoryRequest", | ||
5091 | + "required": [ | ||
5092 | + "articleId", | ||
5093 | + "page", | ||
5094 | + "size" | ||
5095 | + ] | ||
5096 | + }, | ||
5097 | + "SystemArticleHistoryResponse": { | ||
5098 | + "type": "object", | ||
5099 | + "properties": { | ||
5100 | + "total": { | ||
5101 | + "type": "integer", | ||
5102 | + "format": "int32" | ||
5103 | + }, | ||
5104 | + "list": { | ||
5105 | + "type": "array", | ||
5106 | + "items": { | ||
5107 | + "$ref": "#/definitions/SystemArticleHistory" | ||
5108 | + } | ||
5109 | + } | ||
5110 | + }, | ||
5111 | + "title": "SystemArticleHistoryResponse", | ||
5112 | + "required": [ | ||
5113 | + "total", | ||
5114 | + "list" | ||
5115 | + ] | ||
5116 | + }, | ||
5025 | "SystemArticleSearch": { | 5117 | "SystemArticleSearch": { |
5026 | "type": "object", | 5118 | "type": "object", |
5027 | "properties": { | 5119 | "properties": { |
@@ -5149,17 +5241,37 @@ | @@ -5149,17 +5241,37 @@ | ||
5149 | "SystemArticleSearchRequest": { | 5241 | "SystemArticleSearchRequest": { |
5150 | "type": "object", | 5242 | "type": "object", |
5151 | "properties": { | 5243 | "properties": { |
5152 | - "": { | 5244 | + "companyId": { |
5153 | "type": "integer", | 5245 | "type": "integer", |
5154 | "format": "int64" | 5246 | "format": "int64" |
5155 | }, | 5247 | }, |
5248 | + "title": { | ||
5249 | + "type": "string", | ||
5250 | + "description": "标题" | ||
5251 | + }, | ||
5252 | + "author": { | ||
5253 | + "type": "string", | ||
5254 | + "description": "发布人" | ||
5255 | + }, | ||
5256 | + "beginTime": { | ||
5257 | + "type": "integer", | ||
5258 | + "format": "int64", | ||
5259 | + "description": "开始时间" | ||
5260 | + }, | ||
5261 | + "endTime": { | ||
5262 | + "type": "integer", | ||
5263 | + "format": "int64", | ||
5264 | + "description": "结束时间" | ||
5265 | + }, | ||
5156 | "page": { | 5266 | "page": { |
5157 | "type": "integer", | 5267 | "type": "integer", |
5158 | - "format": "int32" | 5268 | + "format": "int32", |
5269 | + "description": "页码" | ||
5159 | }, | 5270 | }, |
5160 | "size": { | 5271 | "size": { |
5161 | "type": "integer", | 5272 | "type": "integer", |
5162 | - "format": "int32" | 5273 | + "format": "int32", |
5274 | + "description": "每页行数" | ||
5163 | } | 5275 | } |
5164 | }, | 5276 | }, |
5165 | "title": "SystemArticleSearchRequest", | 5277 | "title": "SystemArticleSearchRequest", |
@@ -5188,6 +5300,149 @@ | @@ -5188,6 +5300,149 @@ | ||
5188 | "list" | 5300 | "list" |
5189 | ] | 5301 | ] |
5190 | }, | 5302 | }, |
5303 | + "SystemArticleUpdateRequest": { | ||
5304 | + "type": "object", | ||
5305 | + "properties": { | ||
5306 | + "id": { | ||
5307 | + "type": "integer", | ||
5308 | + "format": "int64" | ||
5309 | + }, | ||
5310 | + "companyId": { | ||
5311 | + "type": "integer", | ||
5312 | + "format": "int64" | ||
5313 | + }, | ||
5314 | + "template": { | ||
5315 | + "type": "integer", | ||
5316 | + "format": "int32", | ||
5317 | + "description": " 使用哪个模板进行编辑 0、无 1、演绎式 2、归纳式" | ||
5318 | + }, | ||
5319 | + "section": { | ||
5320 | + "type": "array", | ||
5321 | + "items": { | ||
5322 | + "$ref": "#/definitions/ArticleSection" | ||
5323 | + }, | ||
5324 | + "description": " 填写的内容" | ||
5325 | + }, | ||
5326 | + "title": { | ||
5327 | + "type": "string", | ||
5328 | + "description": " 标题" | ||
5329 | + }, | ||
5330 | + "images": { | ||
5331 | + "type": "array", | ||
5332 | + "items": { | ||
5333 | + "type": "string" | ||
5334 | + }, | ||
5335 | + "description": " 图片" | ||
5336 | + }, | ||
5337 | + "whoRead": { | ||
5338 | + "type": "array", | ||
5339 | + "items": { | ||
5340 | + "type": "integer", | ||
5341 | + "format": "int64" | ||
5342 | + }, | ||
5343 | + "description": " 谁可以看" | ||
5344 | + }, | ||
5345 | + "whoReview": { | ||
5346 | + "type": "array", | ||
5347 | + "items": { | ||
5348 | + "type": "integer", | ||
5349 | + "format": "int64" | ||
5350 | + }, | ||
5351 | + "description": " 评论人" | ||
5352 | + }, | ||
5353 | + "location": { | ||
5354 | + "$ref": "#/definitions/Location", | ||
5355 | + "description": " 坐标" | ||
5356 | + }, | ||
5357 | + "targetUser": { | ||
5358 | + "type": "integer", | ||
5359 | + "format": "int32", | ||
5360 | + "description": "分发方式 [0分发给所有人、1分发给指定的人]" | ||
5361 | + } | ||
5362 | + }, | ||
5363 | + "title": "SystemArticleUpdateRequest", | ||
5364 | + "required": [ | ||
5365 | + "id", | ||
5366 | + "template", | ||
5367 | + "section", | ||
5368 | + "title", | ||
5369 | + "images", | ||
5370 | + "whoRead", | ||
5371 | + "whoReview", | ||
5372 | + "location", | ||
5373 | + "targetUser" | ||
5374 | + ] | ||
5375 | + }, | ||
5376 | + "SystemArticleUpdateResponse": { | ||
5377 | + "type": "object", | ||
5378 | + "properties": { | ||
5379 | + "id": { | ||
5380 | + "type": "integer", | ||
5381 | + "format": "int64", | ||
5382 | + "description": "id" | ||
5383 | + }, | ||
5384 | + "title": { | ||
5385 | + "type": "string", | ||
5386 | + "description": "标题" | ||
5387 | + }, | ||
5388 | + "author": { | ||
5389 | + "type": "string", | ||
5390 | + "description": "发布人" | ||
5391 | + }, | ||
5392 | + "images": { | ||
5393 | + "type": "array", | ||
5394 | + "items": { | ||
5395 | + "type": "string" | ||
5396 | + }, | ||
5397 | + "description": "图片" | ||
5398 | + }, | ||
5399 | + "createdAt": { | ||
5400 | + "type": "integer", | ||
5401 | + "format": "int64", | ||
5402 | + "description": "文章的创建日期" | ||
5403 | + }, | ||
5404 | + "countLove": { | ||
5405 | + "type": "integer", | ||
5406 | + "format": "int32", | ||
5407 | + "description": "点赞数量" | ||
5408 | + }, | ||
5409 | + "CountComment": { | ||
5410 | + "type": "integer", | ||
5411 | + "format": "int32", | ||
5412 | + "description": "评论数量" | ||
5413 | + }, | ||
5414 | + "show": { | ||
5415 | + "type": "integer", | ||
5416 | + "format": "int32", | ||
5417 | + "description": "是否隐藏 [0显示、1不显示]" | ||
5418 | + }, | ||
5419 | + "tags": { | ||
5420 | + "type": "array", | ||
5421 | + "items": { | ||
5422 | + "type": "string" | ||
5423 | + }, | ||
5424 | + "description": "标签" | ||
5425 | + }, | ||
5426 | + "targetUser": { | ||
5427 | + "type": "integer", | ||
5428 | + "format": "int32", | ||
5429 | + "description": "分发方式 [0分发给所有人、1分发给指定的人]" | ||
5430 | + } | ||
5431 | + }, | ||
5432 | + "title": "SystemArticleUpdateResponse", | ||
5433 | + "required": [ | ||
5434 | + "id", | ||
5435 | + "title", | ||
5436 | + "author", | ||
5437 | + "images", | ||
5438 | + "createdAt", | ||
5439 | + "countLove", | ||
5440 | + "CountComment", | ||
5441 | + "show", | ||
5442 | + "tags", | ||
5443 | + "targetUser" | ||
5444 | + ] | ||
5445 | + }, | ||
5191 | "SystemUser": { | 5446 | "SystemUser": { |
5192 | "type": "object", | 5447 | "type": "object", |
5193 | "properties": { | 5448 | "properties": { |
@@ -5608,7 +5863,7 @@ | @@ -5608,7 +5863,7 @@ | ||
5608 | "TagCreateRequest": { | 5863 | "TagCreateRequest": { |
5609 | "type": "object", | 5864 | "type": "object", |
5610 | "properties": { | 5865 | "properties": { |
5611 | - "companyId": { | 5866 | + "": { |
5612 | "type": "integer", | 5867 | "type": "integer", |
5613 | "format": "int64" | 5868 | "format": "int64" |
5614 | }, | 5869 | }, |
@@ -5619,21 +5874,24 @@ | @@ -5619,21 +5874,24 @@ | ||
5619 | "type": "string", | 5874 | "type": "string", |
5620 | "description": " 标签名称" | 5875 | "description": " 标签名称" |
5621 | }, | 5876 | }, |
5622 | - "group": { | 5877 | + "category": { |
5623 | "type": "string", | 5878 | "type": "string", |
5624 | "description": " 标签分类" | 5879 | "description": " 标签分类" |
5625 | }, | 5880 | }, |
5626 | "remark": { | 5881 | "remark": { |
5627 | "type": "string", | 5882 | "type": "string", |
5628 | "description": " 备注" | 5883 | "description": " 备注" |
5884 | + }, | ||
5885 | + "other": { | ||
5886 | + "type": "string" | ||
5629 | } | 5887 | } |
5630 | }, | 5888 | }, |
5631 | "title": "TagCreateRequest", | 5889 | "title": "TagCreateRequest", |
5632 | "required": [ | 5890 | "required": [ |
5633 | - "companyId", | ||
5634 | "image", | 5891 | "image", |
5635 | "name", | 5892 | "name", |
5636 | - "group" | 5893 | + "category", |
5894 | + "other" | ||
5637 | ] | 5895 | ] |
5638 | }, | 5896 | }, |
5639 | "TagCreateResponse": { | 5897 | "TagCreateResponse": { |
@@ -5656,15 +5914,14 @@ | @@ -5656,15 +5914,14 @@ | ||
5656 | "type": "integer", | 5914 | "type": "integer", |
5657 | "format": "int64" | 5915 | "format": "int64" |
5658 | }, | 5916 | }, |
5659 | - "companyId": { | 5917 | + "": { |
5660 | "type": "integer", | 5918 | "type": "integer", |
5661 | "format": "int64" | 5919 | "format": "int64" |
5662 | } | 5920 | } |
5663 | }, | 5921 | }, |
5664 | "title": "TagDeleteRequest", | 5922 | "title": "TagDeleteRequest", |
5665 | "required": [ | 5923 | "required": [ |
5666 | - "id", | ||
5667 | - "-" | 5924 | + "id" |
5668 | ] | 5925 | ] |
5669 | }, | 5926 | }, |
5670 | "TagDeleteResponse": { | 5927 | "TagDeleteResponse": { |
@@ -5687,7 +5944,7 @@ | @@ -5687,7 +5944,7 @@ | ||
5687 | "type": "integer", | 5944 | "type": "integer", |
5688 | "format": "int64" | 5945 | "format": "int64" |
5689 | }, | 5946 | }, |
5690 | - "companyId": { | 5947 | + "": { |
5691 | "type": "integer", | 5948 | "type": "integer", |
5692 | "format": "int64" | 5949 | "format": "int64" |
5693 | }, | 5950 | }, |
@@ -5698,22 +5955,25 @@ | @@ -5698,22 +5955,25 @@ | ||
5698 | "type": "string", | 5955 | "type": "string", |
5699 | "description": " 标签名称" | 5956 | "description": " 标签名称" |
5700 | }, | 5957 | }, |
5701 | - "group": { | 5958 | + "category": { |
5702 | "type": "string", | 5959 | "type": "string", |
5703 | "description": " 标签分类" | 5960 | "description": " 标签分类" |
5704 | }, | 5961 | }, |
5705 | "remark": { | 5962 | "remark": { |
5706 | "type": "string", | 5963 | "type": "string", |
5707 | "description": " 备注" | 5964 | "description": " 备注" |
5965 | + }, | ||
5966 | + "other": { | ||
5967 | + "type": "string" | ||
5708 | } | 5968 | } |
5709 | }, | 5969 | }, |
5710 | "title": "TagEditRequest", | 5970 | "title": "TagEditRequest", |
5711 | "required": [ | 5971 | "required": [ |
5712 | "id", | 5972 | "id", |
5713 | - "-", | ||
5714 | "image", | 5973 | "image", |
5715 | "name", | 5974 | "name", |
5716 | - "group" | 5975 | + "category", |
5976 | + "other" | ||
5717 | ] | 5977 | ] |
5718 | }, | 5978 | }, |
5719 | "TagEditResponse": { | 5979 | "TagEditResponse": { |
@@ -5736,15 +5996,14 @@ | @@ -5736,15 +5996,14 @@ | ||
5736 | "type": "integer", | 5996 | "type": "integer", |
5737 | "format": "int64" | 5997 | "format": "int64" |
5738 | }, | 5998 | }, |
5739 | - "companyId": { | 5999 | + "": { |
5740 | "type": "integer", | 6000 | "type": "integer", |
5741 | "format": "int64" | 6001 | "format": "int64" |
5742 | } | 6002 | } |
5743 | }, | 6003 | }, |
5744 | "title": "TagGetRequest", | 6004 | "title": "TagGetRequest", |
5745 | "required": [ | 6005 | "required": [ |
5746 | - "id", | ||
5747 | - "-" | 6006 | + "id" |
5748 | ] | 6007 | ] |
5749 | }, | 6008 | }, |
5750 | "TagGetResponse": { | 6009 | "TagGetResponse": { |
@@ -5761,13 +6020,16 @@ | @@ -5761,13 +6020,16 @@ | ||
5761 | "type": "string", | 6020 | "type": "string", |
5762 | "description": " 标签名称" | 6021 | "description": " 标签名称" |
5763 | }, | 6022 | }, |
5764 | - "group": { | 6023 | + "category": { |
5765 | "type": "string", | 6024 | "type": "string", |
5766 | "description": " 标签分类" | 6025 | "description": " 标签分类" |
5767 | }, | 6026 | }, |
5768 | "remark": { | 6027 | "remark": { |
5769 | "type": "string", | 6028 | "type": "string", |
5770 | "description": " 备注" | 6029 | "description": " 备注" |
6030 | + }, | ||
6031 | + "other": { | ||
6032 | + "type": "string" | ||
5771 | } | 6033 | } |
5772 | }, | 6034 | }, |
5773 | "title": "TagGetResponse", | 6035 | "title": "TagGetResponse", |
@@ -5775,8 +6037,9 @@ | @@ -5775,8 +6037,9 @@ | ||
5775 | "id", | 6037 | "id", |
5776 | "image", | 6038 | "image", |
5777 | "name", | 6039 | "name", |
5778 | - "group", | ||
5779 | - "remark" | 6040 | + "category", |
6041 | + "remark", | ||
6042 | + "other" | ||
5780 | ] | 6043 | ] |
5781 | }, | 6044 | }, |
5782 | "TagItem": { | 6045 | "TagItem": { |
@@ -5793,7 +6056,7 @@ | @@ -5793,7 +6056,7 @@ | ||
5793 | "type": "string", | 6056 | "type": "string", |
5794 | "description": " 标签名称" | 6057 | "description": " 标签名称" |
5795 | }, | 6058 | }, |
5796 | - "group": { | 6059 | + "category": { |
5797 | "type": "string", | 6060 | "type": "string", |
5798 | "description": " 标签分类" | 6061 | "description": " 标签分类" |
5799 | }, | 6062 | }, |
@@ -5811,7 +6074,7 @@ | @@ -5811,7 +6074,7 @@ | ||
5811 | "id", | 6074 | "id", |
5812 | "image", | 6075 | "image", |
5813 | "name", | 6076 | "name", |
5814 | - "group", | 6077 | + "category", |
5815 | "remark", | 6078 | "remark", |
5816 | "createdAt" | 6079 | "createdAt" |
5817 | ] | 6080 | ] |
@@ -5827,14 +6090,14 @@ | @@ -5827,14 +6090,14 @@ | ||
5827 | "type": "integer", | 6090 | "type": "integer", |
5828 | "format": "int32" | 6091 | "format": "int32" |
5829 | }, | 6092 | }, |
5830 | - "companyId": { | 6093 | + "": { |
5831 | "type": "integer", | 6094 | "type": "integer", |
5832 | "format": "int64" | 6095 | "format": "int64" |
5833 | }, | 6096 | }, |
5834 | "tagName": { | 6097 | "tagName": { |
5835 | "type": "string" | 6098 | "type": "string" |
5836 | }, | 6099 | }, |
5837 | - "group": { | 6100 | + "category": { |
5838 | "type": "string" | 6101 | "type": "string" |
5839 | }, | 6102 | }, |
5840 | "remark": { | 6103 | "remark": { |
@@ -5844,8 +6107,7 @@ | @@ -5844,8 +6107,7 @@ | ||
5844 | "title": "TagListRequest", | 6107 | "title": "TagListRequest", |
5845 | "required": [ | 6108 | "required": [ |
5846 | "page", | 6109 | "page", |
5847 | - "size", | ||
5848 | - "-" | 6110 | + "size" |
5849 | ] | 6111 | ] |
5850 | }, | 6112 | }, |
5851 | "TagListResponse": { | 6113 | "TagListResponse": { |
@@ -6054,8 +6316,7 @@ | @@ -6054,8 +6316,7 @@ | ||
6054 | "format": "int32" | 6316 | "format": "int32" |
6055 | }, | 6317 | }, |
6056 | "name": { | 6318 | "name": { |
6057 | - "type": "integer", | ||
6058 | - "format": "int32" | 6319 | + "type": "string" |
6059 | } | 6320 | } |
6060 | }, | 6321 | }, |
6061 | "title": "UserShowName", | 6322 | "title": "UserShowName", |
@@ -6126,6 +6387,10 @@ | @@ -6126,6 +6387,10 @@ | ||
6126 | "type": "string", | 6387 | "type": "string", |
6127 | "description": " 人员头像" | 6388 | "description": " 人员头像" |
6128 | }, | 6389 | }, |
6390 | + "position": { | ||
6391 | + "type": "string", | ||
6392 | + "description": " 职位" | ||
6393 | + }, | ||
6129 | "createdAt": { | 6394 | "createdAt": { |
6130 | "type": "integer", | 6395 | "type": "integer", |
6131 | "format": "int64", | 6396 | "format": "int64", |
@@ -6138,6 +6403,7 @@ | @@ -6138,6 +6403,7 @@ | ||
6138 | "userId", | 6403 | "userId", |
6139 | "name", | 6404 | "name", |
6140 | "avatar", | 6405 | "avatar", |
6406 | + "position", | ||
6141 | "createdAt" | 6407 | "createdAt" |
6142 | ] | 6408 | ] |
6143 | } | 6409 | } |
@@ -89,7 +89,20 @@ service Core { | @@ -89,7 +89,20 @@ service Core { | ||
89 | @handler SystemSearchArticle | 89 | @handler SystemSearchArticle |
90 | post /article/search (SystemArticleSearchRequest) returns (SystemArticleSearchResponse) | 90 | post /article/search (SystemArticleSearchRequest) returns (SystemArticleSearchResponse) |
91 | 91 | ||
92 | + @doc "管理后台编辑帖子" | ||
93 | + @handler SystemUpdateArticle | ||
94 | + put /article (SystemArticleUpdateRequest) returns (SystemArticleUpdateResponse) | ||
95 | + | ||
96 | + @doc "管理后台编辑历史" | ||
97 | + @handler SystemHistoryArticle | ||
98 | + post /article/history (SystemArticleHistoryRequest) returns (SystemArticleHistoryResponse) | ||
99 | + | ||
100 | + @doc "管理后台帖子历史详情" | ||
101 | + @handler SystemArticleGetHistory | ||
102 | + get /article/history/:id (SystemArticleGetHistoryRequest) returns (SystemArticleGetHistoryResponse) | ||
103 | + | ||
92 | @doc "管理后台获取我发布的文章" | 104 | @doc "管理后台获取我发布的文章" |
93 | @handler SystemArticleSearchMe | 105 | @handler SystemArticleSearchMe |
94 | post /article/search/me (SystemArticleSearchMeRequest) returns (SystemArticleSearchMeResponse) | 106 | post /article/search/me (SystemArticleSearchMeRequest) returns (SystemArticleSearchMeResponse) |
107 | + | ||
95 | } | 108 | } |
@@ -8,14 +8,42 @@ info( | @@ -8,14 +8,42 @@ info( | ||
8 | version: "v1" | 8 | version: "v1" |
9 | ) | 9 | ) |
10 | 10 | ||
11 | +@server( | ||
12 | + prefix: v1/system | ||
13 | + group: tags | ||
14 | + jwt: SystemAuth | ||
15 | +) | ||
16 | +service Core { | ||
17 | + @doc "后台创建文章标签" | ||
18 | + @handler CreateTag | ||
19 | + post /article_tag (TagCreateRequest) returns (TagCreateResponse) | ||
20 | + | ||
21 | + @doc "后台编辑文章标签" | ||
22 | + @handler EditTag | ||
23 | + put /article_tag (TagEditRequest) returns (TagEditResponse) | ||
24 | + | ||
25 | + @doc "后台获取文章标签" | ||
26 | + @handler GetTag | ||
27 | + get /article_tag/:id (TagGetRequest) returns (TagGetResponse) | ||
28 | + | ||
29 | + @doc "后台删除文章标签" | ||
30 | + @handler DeleteTag | ||
31 | + delete /article_tag/:id (TagDeleteRequest) returns (TagDeleteResponse) | ||
32 | + | ||
33 | + @doc "后台搜索标签" | ||
34 | + @handler SearchTag | ||
35 | + post/article_tag/search (TagListRequest) returns (TagListResponse) | ||
36 | +} | ||
37 | + | ||
11 | // 创建标签 | 38 | // 创建标签 |
12 | type ( | 39 | type ( |
13 | TagCreateRequest { | 40 | TagCreateRequest { |
14 | - CompanyId int64 `json:"companyId"` | 41 | + CompanyId int64 `json:",optional"` |
15 | Image string `json:"image"` | 42 | Image string `json:"image"` |
16 | Name string `json:"name"` // 标签名称 | 43 | Name string `json:"name"` // 标签名称 |
17 | - Group string `json:"group"` // 标签分类 | 44 | + Category string `json:"category"` // 标签分类 |
18 | Remark string `json:"remark,optional"` // 备注 | 45 | Remark string `json:"remark,optional"` // 备注 |
46 | + Other string `json:"other"` | ||
19 | } | 47 | } |
20 | 48 | ||
21 | TagCreateResponse { | 49 | TagCreateResponse { |
@@ -27,11 +55,12 @@ type ( | @@ -27,11 +55,12 @@ type ( | ||
27 | type ( | 55 | type ( |
28 | TagEditRequest { | 56 | TagEditRequest { |
29 | Id int64 `json:"id"` | 57 | Id int64 `json:"id"` |
30 | - CompanyId int64 `json:"-"` | 58 | + CompanyId int64 `json:",optional"` |
31 | Image string `json:"image"` | 59 | Image string `json:"image"` |
32 | Name string `json:"name"` // 标签名称 | 60 | Name string `json:"name"` // 标签名称 |
33 | - Group string `json:"group"` // 标签分类 | 61 | + Category string `json:"category"` // 标签分类 |
34 | Remark string `json:"remark,optional"` // 备注 | 62 | Remark string `json:"remark,optional"` // 备注 |
63 | + Other string `json:"other"` | ||
35 | } | 64 | } |
36 | 65 | ||
37 | TagEditResponse { | 66 | TagEditResponse { |
@@ -43,14 +72,15 @@ type ( | @@ -43,14 +72,15 @@ type ( | ||
43 | type ( | 72 | type ( |
44 | TagGetRequest { | 73 | TagGetRequest { |
45 | Id int64 `path:"id"` | 74 | Id int64 `path:"id"` |
46 | - CompanyId int64 `path:"-"` | 75 | + CompanyId int64 `path:",optional"` |
47 | } | 76 | } |
48 | TagGetResponse { | 77 | TagGetResponse { |
49 | Id int64 `json:"id"` | 78 | Id int64 `json:"id"` |
50 | Image string `json:"image"` | 79 | Image string `json:"image"` |
51 | Name string `json:"name"` // 标签名称 | 80 | Name string `json:"name"` // 标签名称 |
52 | - Group string `json:"group"` // 标签分类 | 81 | + Category string `json:"category"` // 标签分类 |
53 | Remark string `json:"remark"` // 备注 | 82 | Remark string `json:"remark"` // 备注 |
83 | + Other string `json:"other"` | ||
54 | } | 84 | } |
55 | ) | 85 | ) |
56 | 86 | ||
@@ -59,9 +89,9 @@ type ( | @@ -59,9 +89,9 @@ type ( | ||
59 | TagListRequest { | 89 | TagListRequest { |
60 | Page int `json:"page"` | 90 | Page int `json:"page"` |
61 | Size int `json:"size"` | 91 | Size int `json:"size"` |
62 | - CompanyId int64 `json:"-"` | 92 | + CompanyId int64 `json:",optional"` |
63 | TagName string `json:"tagName,optional"` | 93 | TagName string `json:"tagName,optional"` |
64 | - Group string `json:"group,optional"` | 94 | + Category string `json:"category,optional"` |
65 | Remark string `json:"remark,optional"` | 95 | Remark string `json:"remark,optional"` |
66 | } | 96 | } |
67 | TagListResponse { | 97 | TagListResponse { |
@@ -72,7 +102,7 @@ type ( | @@ -72,7 +102,7 @@ type ( | ||
72 | Id int64 `json:"id"` | 102 | Id int64 `json:"id"` |
73 | Image string `json:"image"` | 103 | Image string `json:"image"` |
74 | Name string `json:"name"` // 标签名称 | 104 | Name string `json:"name"` // 标签名称 |
75 | - Group string `json:"group"` // 标签分类 | 105 | + Category string `json:"category"` // 标签分类 |
76 | Remark string `json:"remark"` // 备注 | 106 | Remark string `json:"remark"` // 备注 |
77 | CreatedAt int64 `json:"createdAt"` | 107 | CreatedAt int64 `json:"createdAt"` |
78 | } | 108 | } |
@@ -82,36 +112,9 @@ type ( | @@ -82,36 +112,9 @@ type ( | ||
82 | type ( | 112 | type ( |
83 | TagDeleteRequest { | 113 | TagDeleteRequest { |
84 | Id int64 `path:"id"` | 114 | Id int64 `path:"id"` |
85 | - CompanyId int64 `path:"-"` | 115 | + CompanyId int64 `path:",optional"` |
86 | } | 116 | } |
87 | TagDeleteResponse { | 117 | TagDeleteResponse { |
88 | Id int64 `json:"id"` | 118 | Id int64 `json:"id"` |
89 | } | 119 | } |
90 | ) | 120 | ) |
91 | - | ||
92 | -@server( | ||
93 | - prefix: v1/system | ||
94 | - group: tags | ||
95 | - jwt: MiniAuth | ||
96 | -) | ||
97 | -service Core { | ||
98 | - @doc "后台创建文章标签" | ||
99 | - @handler CreateTag | ||
100 | - post /article_tag (TagCreateRequest) returns (TagCreateResponse) | ||
101 | - | ||
102 | - @doc "后台编辑文章标签" | ||
103 | - @handler EditTag | ||
104 | - put /article_tag (TagEditRequest) returns (TagEditResponse) | ||
105 | - | ||
106 | - @doc "后台获取文章标签" | ||
107 | - @handler GetTag | ||
108 | - get /article_tag/:id (TagGetRequest) returns (TagGetResponse) | ||
109 | - | ||
110 | - @doc "后台删除文章标签" | ||
111 | - @handler DeleteTag | ||
112 | - delete /article_tag/:id (TagDeleteRequest) returns (TagDeleteResponse) | ||
113 | - | ||
114 | - @doc "后台搜索标签" | ||
115 | - @handler SearchTag | ||
116 | - post/article_tag/search (TagListRequest) returns (TagListResponse) | ||
117 | -} |
@@ -36,7 +36,7 @@ type ( | @@ -36,7 +36,7 @@ type ( | ||
36 | type ( | 36 | type ( |
37 | MiniArticleGetRequest { | 37 | MiniArticleGetRequest { |
38 | Id int64 `path:"id"` //id | 38 | Id int64 `path:"id"` //id |
39 | - CompanyId int64 `path:",optional"`//当前公司 | 39 | + CompanyId int64 `path:",optional"` //当前公司 |
40 | UserId int `path:",optional"` //当前用户 | 40 | UserId int `path:",optional"` //当前用户 |
41 | } | 41 | } |
42 | MiniArticleGetResponse { | 42 | MiniArticleGetResponse { |
@@ -119,6 +119,7 @@ type ( | @@ -119,6 +119,7 @@ type ( | ||
119 | UserId int64 `json:"userId"` // 人员id | 119 | UserId int64 `json:"userId"` // 人员id |
120 | Name string `json:"name"` // 人员名称 | 120 | Name string `json:"name"` // 人员名称 |
121 | Avatar string `json:"avatar"` // 人员头像 | 121 | Avatar string `json:"avatar"` // 人员头像 |
122 | + Position string `json:"position"` // 职位 | ||
122 | CreatedAt int64 `json:"createdAt"` // 点赞记录的时间 | 123 | CreatedAt int64 `json:"createdAt"` // 点赞记录的时间 |
123 | } | 124 | } |
124 | ) | 125 | ) |
@@ -292,27 +293,24 @@ type ( | @@ -292,27 +293,24 @@ type ( | ||
292 | 293 | ||
293 | //小程序端设置文章的定性标签 | 294 | //小程序端设置文章的定性标签 |
294 | type ( | 295 | type ( |
295 | - MiniArticleSetTagRequest{ | 296 | + MiniArticleSetTagRequest { |
296 | CompanyId int64 `json:",optional"` // 公司id | 297 | CompanyId int64 `json:",optional"` // 公司id |
297 | UserId int64 `json:",optional"` // 公司id | 298 | UserId int64 `json:",optional"` // 公司id |
298 | ArticleId int64 `json:"articleId"` // 文章id | 299 | ArticleId int64 `json:"articleId"` // 文章id |
299 | TagId int64 `json:"tagId"` // 标签id | 300 | TagId int64 `json:"tagId"` // 标签id |
300 | } | 301 | } |
301 | - MiniArticleSetTagResponse{ | 302 | + MiniArticleSetTagResponse { |
302 | Id int64 `json:"id"` | 303 | Id int64 `json:"id"` |
303 | } | 304 | } |
304 | ) | 305 | ) |
305 | 306 | ||
306 | - | ||
307 | //小程序端获取所有的定性标签 | 307 | //小程序端获取所有的定性标签 |
308 | type ( | 308 | type ( |
309 | - MiniAllArticleTagRequest{ | 309 | + MiniAllArticleTagRequest { |
310 | CompanyId int64 `json:",optional"` // 公司id | 310 | CompanyId int64 `json:",optional"` // 公司id |
311 | UserId int64 `json:",optional"` // 公司id | 311 | UserId int64 `json:",optional"` // 公司id |
312 | - ArticleId int64 `json:"articleId"` // 文章id | ||
313 | - TagId int64 `json:"tagId"` // 标签id | ||
314 | } | 312 | } |
315 | - MiniAllArticleTagResponse{ | 313 | + MiniAllArticleTagResponse { |
316 | TagGroup []ArticleTagGroup `json:"tagGroup"` | 314 | TagGroup []ArticleTagGroup `json:"tagGroup"` |
317 | } | 315 | } |
318 | ArticleTagGroup { | 316 | ArticleTagGroup { |
@@ -323,11 +321,10 @@ type ( | @@ -323,11 +321,10 @@ type ( | ||
323 | Id int64 `json:"id"` | 321 | Id int64 `json:"id"` |
324 | Group string `json:"group"` | 322 | Group string `json:"group"` |
325 | Name string `json:"name"` | 323 | Name string `json:"name"` |
324 | + Image string `json:"image"` | ||
326 | } | 325 | } |
327 | ) | 326 | ) |
328 | 327 | ||
329 | - | ||
330 | - | ||
331 | //管理后台获取文章详情 | 328 | //管理后台获取文章详情 |
332 | type ( | 329 | type ( |
333 | SystemArticleGetRequest { | 330 | SystemArticleGetRequest { |
@@ -337,7 +334,7 @@ type ( | @@ -337,7 +334,7 @@ type ( | ||
337 | 334 | ||
338 | UserShowName { | 335 | UserShowName { |
339 | Id int `json:"id"` | 336 | Id int `json:"id"` |
340 | - Name int `json:"name"` | 337 | + Name string `json:"name"` |
341 | } | 338 | } |
342 | 339 | ||
343 | SystemArticleGetResponse { | 340 | SystemArticleGetResponse { |
@@ -357,15 +354,21 @@ type ( | @@ -357,15 +354,21 @@ type ( | ||
357 | CountComment int `json:"countComment"` // 评论数量 | 354 | CountComment int `json:"countComment"` // 评论数量 |
358 | CountRead int `json:"countRead"` // 浏览数量 | 355 | CountRead int `json:"countRead"` // 浏览数量 |
359 | Show int `json:"show"` // 评论的展示状态(0显示、1不显示) | 356 | Show int `json:"show"` // 评论的展示状态(0显示、1不显示) |
357 | + Tags []ArticleTagItem `json:"tags"` //标签 | ||
360 | } | 358 | } |
361 | ) | 359 | ) |
362 | 360 | ||
363 | //管理后台获取文章列表 | 361 | //管理后台获取文章列表 |
364 | type ( | 362 | type ( |
365 | SystemArticleSearchRequest { | 363 | SystemArticleSearchRequest { |
366 | - CompanyId int64 `json:",optional"` | ||
367 | - Page int `json:"page"` | ||
368 | - Size int `json:"size"` | 364 | + CompanyId int64 `json:"companyId,optional"` |
365 | + Title string `json:"title,optional"` //标题 | ||
366 | + Author string `json:"author,optional"` //发布人 | ||
367 | + BeginTime int64 `json:"beginTime,optional"` //开始时间 | ||
368 | + EndTime int64 `json:"endTime,optional"` //结束时间 | ||
369 | + Tags []int64 `json:"tags,optional"` //标签 | ||
370 | + Page int `json:"page"` //页码 | ||
371 | + Size int `json:"size"` //每页行数 | ||
369 | } | 372 | } |
370 | 373 | ||
371 | SystemArticleSearchResponse { | 374 | SystemArticleSearchResponse { |
@@ -384,4 +387,73 @@ type ( | @@ -384,4 +387,73 @@ type ( | ||
384 | Tags []string `json:"tags"` //标签 | 387 | Tags []string `json:"tags"` //标签 |
385 | TargetUser int `json:"targetUser"` //分发方式 [0分发给所有人、1分发给指定的人] | 388 | TargetUser int `json:"targetUser"` //分发方式 [0分发给所有人、1分发给指定的人] |
386 | } | 389 | } |
390 | + //编辑 | ||
391 | + SystemArticleUpdateRequest { | ||
392 | + Id int64 `json:"id"` | ||
393 | + CompanyId int64 `json:"companyId,optional"` | ||
394 | + Template int `json:"template"` // 使用哪个模板进行编辑 0、无 1、演绎式 2、归纳式 | ||
395 | + Section []ArticleSection `json:"section"` // 填写的内容 | ||
396 | + Title string `json:"title"` // 标题 | ||
397 | + Images []string `json:"images"` // 图片 | ||
398 | + WhoRead []int64 `json:"whoRead"` // 谁可以看 | ||
399 | + WhoReview []int64 `json:"whoReview"` // 评论人 | ||
400 | + Location Location `json:"location"` // 坐标 | ||
401 | + TargetUser int `json:"targetUser"` //分发方式 [0分发给所有人、1分发给指定的人] | ||
402 | + Tags []int64 `json:"tags"` // 标签 | ||
403 | + } | ||
404 | + SystemArticleUpdateResponse { | ||
405 | + Id int64 `json:"id"` //id | ||
406 | + Title string `json:"title"` //标题 | ||
407 | + Author string `json:"author"` //发布人 | ||
408 | + Images []string `json:"images"` //图片 | ||
409 | + CreatedAt int64 `json:"createdAt"` //文章的创建日期 | ||
410 | + CountLove int `json:"countLove"` //点赞数量 | ||
411 | + CountComment int `json:"CountComment"` //评论数量 | ||
412 | + Show int `json:"show"` //是否隐藏 [0显示、1不显示] | ||
413 | + Tags []int64 `json:"tags"` //标签 | ||
414 | + TargetUser int `json:"targetUser"` //分发方式 [0分发给所有人、1分发给指定的人] | ||
415 | + } | ||
416 | + //历史 | ||
417 | + SystemArticleHistoryRequest { | ||
418 | + ArticleId int64 `json:"articleId"` //文章ID | ||
419 | + Author string `json:"author,optional"` //发布人 | ||
420 | + BeginTime int64 `json:"beginTime,optional"` //开始时间 | ||
421 | + EndTime int64 `json:"endTime,optional"` //结束时间 | ||
422 | + Page int `json:"page"` //页码 | ||
423 | + Size int `json:"size"` //每页行数 | ||
424 | + } | ||
425 | + SystemArticleHistoryResponse { | ||
426 | + Total int `json:"total"` | ||
427 | + List []SystemArticleHistory `json:"list"` | ||
428 | + } | ||
429 | + SystemArticleHistory { | ||
430 | + Id int64 `json:"id"` //id | ||
431 | + Author string `json:"author"` //编辑人 | ||
432 | + Action string `json:"action"` //编辑类型 | ||
433 | + UpdatedAt int64 `json:"updatedAt"` //编辑时间 | ||
434 | + } | ||
435 | + SystemArticleGetHistoryRequest { | ||
436 | + Id int64 `path:"id"` //id | ||
437 | + CompanyId int64 `path:",optional"` | ||
438 | + } | ||
439 | + SystemArticleGetHistoryResponse { | ||
440 | + Id int64 `json:"id"` // id | ||
441 | + ArticleId int64 `json:"articleId"` // 文章ID | ||
442 | + Title string `json:"title"` // 标题 | ||
443 | + AuthorId int64 `json:"authorId"` // 发布人id | ||
444 | + Author ArticleAuthor `json:"author"` // 发布人 | ||
445 | + CreatedAt int64 `json:"createdAt"` // 文章的发布时间 | ||
446 | + Section []ArticleSection `json:"section"` // 文章的文本内容 | ||
447 | + Images []string `json:"images"` // 图片 | ||
448 | + WhoRead []int64 `json:"whoRead"` // 谁可查看 | ||
449 | + WhoReadInfo []UserShowName `json:"whoReadInfo"` // 谁可查看 | ||
450 | + WhoReview []int64 `json:"whoReview"` // 谁可评论 | ||
451 | + WhoReviewInfo []UserShowName `json:"whoReviewInfo"` // 谁可评论 | ||
452 | + Location Location `json:"location"` // 定位坐标 | ||
453 | + CountLove int `json:"countLove"` // 点赞数量 | ||
454 | + CountComment int `json:"countComment"` // 评论数量 | ||
455 | + CountRead int `json:"countRead"` // 浏览数量 | ||
456 | + Show int `json:"show"` // 评论的展示状态(0显示、1不显示) | ||
457 | + TargetUser int `json:"targetUser"` //分发方式 [0分发给所有人、1分发给指定的人] | ||
458 | + } | ||
387 | ) | 459 | ) |
@@ -16,10 +16,6 @@ info( | @@ -16,10 +16,6 @@ info( | ||
16 | ) | 16 | ) |
17 | service Core { | 17 | service Core { |
18 | 18 | ||
19 | - @doc "小程序获取回复@人可选列表" | ||
20 | - @handler MiniArticleCommentAtUser | ||
21 | - post /article_comment/at_user/select (MiniArticleCommentAtUserRequest) returns (MiniArticleCommentAtUserResponse) | ||
22 | - | ||
23 | @doc "小程序填写文章的评论" | 19 | @doc "小程序填写文章的评论" |
24 | @handler MiniCreateArticleComment | 20 | @handler MiniCreateArticleComment |
25 | post /article_comment (MiniCreateArticleCommentRequest) returns (MiniCreateArticleCommentResponse) | 21 | post /article_comment (MiniCreateArticleCommentRequest) returns (MiniCreateArticleCommentResponse) |
@@ -58,17 +54,6 @@ service Core { | @@ -58,17 +54,6 @@ service Core { | ||
58 | post /article_comment/search/me (SystemArticleCommentSearchMeRequest) returns (SystemArticleCommentSearchMeResponse) | 54 | post /article_comment/search/me (SystemArticleCommentSearchMeRequest) returns (SystemArticleCommentSearchMeResponse) |
59 | } | 55 | } |
60 | 56 | ||
61 | -// | ||
62 | -// 小程序获取回复@人可选列表 | ||
63 | -type ( | ||
64 | - MiniArticleCommentAtUserRequest { | ||
65 | - ArtitceId int64 `json:"articleId"` | ||
66 | - } | ||
67 | - | ||
68 | - MiniArticleCommentAtUserResponse { | ||
69 | - } | ||
70 | -) | ||
71 | - | ||
72 | //评论的填写人 | 57 | //评论的填写人 |
73 | type CommentAuthor { | 58 | type CommentAuthor { |
74 | Id int64 `json:"id"` // 人员id | 59 | Id int64 `json:"id"` // 人员id |
@@ -93,6 +78,7 @@ type ( | @@ -93,6 +78,7 @@ type ( | ||
93 | CommentAtWho { | 78 | CommentAtWho { |
94 | Id int64 `json:"id"` | 79 | Id int64 `json:"id"` |
95 | Name string `json:"name,optional"` | 80 | Name string `json:"name,optional"` |
81 | + FirstLetter string `json:"firstLetter,optional"` | ||
96 | } | 82 | } |
97 | MiniCreateArticleCommentResponse { | 83 | MiniCreateArticleCommentResponse { |
98 | Id int64 `json:"id"` | 84 | Id int64 `json:"id"` |
@@ -205,15 +191,15 @@ type ( | @@ -205,15 +191,15 @@ type ( | ||
205 | } | 191 | } |
206 | ) | 192 | ) |
207 | 193 | ||
208 | -type( | ||
209 | - SystemArticleCommentSearchMeRequest{ | 194 | +type ( |
195 | + SystemArticleCommentSearchMeRequest { | ||
210 | Page int `json:"page"` | 196 | Page int `json:"page"` |
211 | Size int `json:"size"` | 197 | Size int `json:"size"` |
212 | AuthorId int64 `json:"authorId"` // 用户 | 198 | AuthorId int64 `json:"authorId"` // 用户 |
213 | BeginTime int64 `json:"beginTime,optional"` // 开始时间 | 199 | BeginTime int64 `json:"beginTime,optional"` // 开始时间 |
214 | EndTime int64 `json:"endTime,optional"` // 结束时间 | 200 | EndTime int64 `json:"endTime,optional"` // 结束时间 |
215 | } | 201 | } |
216 | - SystemArticleCommentSearchMeResponse{ | 202 | + SystemArticleCommentSearchMeResponse { |
217 | List []ArticleCommentItem `json:"list"` | 203 | List []ArticleCommentItem `json:"list"` |
218 | Total int64 `json:"total"` | 204 | Total int64 `json:"total"` |
219 | } | 205 | } |
@@ -44,18 +44,18 @@ service Core { | @@ -44,18 +44,18 @@ service Core { | ||
44 | } | 44 | } |
45 | 45 | ||
46 | type ( | 46 | type ( |
47 | - CompanySearchRequest struct{ | 47 | + CompanySearchRequest { |
48 | Page int `json:"page,optional"` | 48 | Page int `json:"page,optional"` |
49 | Size int `json:"size,optional"` | 49 | Size int `json:"size,optional"` |
50 | Flag int `json:"flag,optional"` // 1:用户已加入的 2:用户未加入的公司 | 50 | Flag int `json:"flag,optional"` // 1:用户已加入的 2:用户未加入的公司 |
51 | UserId int64 `json:"userId,optional"` // 按用户搜索(用户所加入的企业) | 51 | UserId int64 `json:"userId,optional"` // 按用户搜索(用户所加入的企业) |
52 | Code string `json:"code,optional"` // 按编码搜索 | 52 | Code string `json:"code,optional"` // 按编码搜索 |
53 | } | 53 | } |
54 | - CompanySearchResponse{ | 54 | + CompanySearchResponse { |
55 | List []Company `json:"list"` | 55 | List []Company `json:"list"` |
56 | Total int64 `json:"total"` | 56 | Total int64 `json:"total"` |
57 | } | 57 | } |
58 | - Company struct{ | 58 | + Company { |
59 | Id int64 `json:"id,omitempty"` // 唯一标识 | 59 | Id int64 `json:"id,omitempty"` // 唯一标识 |
60 | Name string `json:"name,omitempty"` // 名称 | 60 | Name string `json:"name,omitempty"` // 名称 |
61 | Code string `json:"code,omitempty"` // 编码(搜索使用,4位字母数字) | 61 | Code string `json:"code,omitempty"` // 编码(搜索使用,4位字母数字) |
@@ -36,37 +36,37 @@ type ( | @@ -36,37 +36,37 @@ type ( | ||
36 | RoleGetRequest { | 36 | RoleGetRequest { |
37 | Id int64 `path:"id"` | 37 | Id int64 `path:"id"` |
38 | } | 38 | } |
39 | - RoleGetResponse struct{ | 39 | + RoleGetResponse { |
40 | Role RoleItem `json:"role"` | 40 | Role RoleItem `json:"role"` |
41 | AuthList []Auth `json:"authList"` | 41 | AuthList []Auth `json:"authList"` |
42 | } | 42 | } |
43 | 43 | ||
44 | - RoleSaveRequest struct{ | 44 | + RoleSaveRequest { |
45 | Role RoleItem `json:"role"` | 45 | Role RoleItem `json:"role"` |
46 | } | 46 | } |
47 | RoleSaveResponse struct{} | 47 | RoleSaveResponse struct{} |
48 | 48 | ||
49 | - RoleDeleteRequest struct{ | 49 | + RoleDeleteRequest { |
50 | Id int64 `path:"id"` | 50 | Id int64 `path:"id"` |
51 | } | 51 | } |
52 | RoleDeleteResponse struct{} | 52 | RoleDeleteResponse struct{} |
53 | 53 | ||
54 | - RoleUpdateRequest struct{ | 54 | + RoleUpdateRequest { |
55 | Id int64 `path:"id"` | 55 | Id int64 `path:"id"` |
56 | Role RoleItem `json:"role"` | 56 | Role RoleItem `json:"role"` |
57 | } | 57 | } |
58 | RoleUpdateResponse struct{} | 58 | RoleUpdateResponse struct{} |
59 | 59 | ||
60 | - RoleSearchRequest struct{ | 60 | + RoleSearchRequest { |
61 | Page int `json:"page,optional"` | 61 | Page int `json:"page,optional"` |
62 | Size int `json:"size,optional"` | 62 | Size int `json:"size,optional"` |
63 | Style string `json:"style,options=[simple,,full]"` // simple:只返回角色ID名称 full:所有字段都返回 | 63 | Style string `json:"style,options=[simple,,full]"` // simple:只返回角色ID名称 full:所有字段都返回 |
64 | } | 64 | } |
65 | - RoleSearchResponse{ | 65 | + RoleSearchResponse { |
66 | List []RoleItem `json:"list"` | 66 | List []RoleItem `json:"list"` |
67 | Total int64 `json:"total"` | 67 | Total int64 `json:"total"` |
68 | } | 68 | } |
69 | - RoleItem struct{ | 69 | + RoleItem { |
70 | Id int64 `json:"id,optional"` // 角色ID | 70 | Id int64 `json:"id,optional"` // 角色ID |
71 | CompanyId int64 `json:"companyId,optional,omitempty"` // 公司ID | 71 | CompanyId int64 `json:"companyId,optional,omitempty"` // 公司ID |
72 | Name string `json:"name"` // 角色名称 | 72 | Name string `json:"name"` // 角色名称 |
@@ -7,6 +7,8 @@ import ( | @@ -7,6 +7,8 @@ import ( | ||
7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/article" | 7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/article" |
8 | "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" |
9 | "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" |
10 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata" | ||
11 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result" | ||
10 | ) | 12 | ) |
11 | 13 | ||
12 | func MiniAllArticleTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | 14 | func MiniAllArticleTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { |
@@ -18,11 +20,10 @@ func MiniAllArticleTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -18,11 +20,10 @@ func MiniAllArticleTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
18 | } | 20 | } |
19 | 21 | ||
20 | l := article.NewMiniAllArticleTagLogic(r.Context(), svcCtx) | 22 | l := article.NewMiniAllArticleTagLogic(r.Context(), svcCtx) |
23 | + token := contextdata.GetUserTokenFromCtx(r.Context()) | ||
24 | + req.CompanyId = token.CompanyId | ||
25 | + req.UserId = token.UserId | ||
21 | resp, err := l.MiniAllArticleTag(&req) | 26 | resp, err := l.MiniAllArticleTag(&req) |
22 | - if err != nil { | ||
23 | - httpx.ErrorCtx(r.Context(), w, err) | ||
24 | - } else { | ||
25 | - httpx.OkJsonCtx(r.Context(), w, resp) | ||
26 | - } | 27 | + result.HttpResult(r, w, resp, err) |
27 | } | 28 | } |
28 | } | 29 | } |
@@ -7,6 +7,8 @@ import ( | @@ -7,6 +7,8 @@ import ( | ||
7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/article" | 7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/article" |
8 | "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" |
9 | "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" |
10 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata" | ||
11 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result" | ||
10 | ) | 12 | ) |
11 | 13 | ||
12 | func MiniArticleSetTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | 14 | func MiniArticleSetTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { |
@@ -18,11 +20,10 @@ func MiniArticleSetTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -18,11 +20,10 @@ func MiniArticleSetTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
18 | } | 20 | } |
19 | 21 | ||
20 | l := article.NewMiniArticleSetTagLogic(r.Context(), svcCtx) | 22 | l := article.NewMiniArticleSetTagLogic(r.Context(), svcCtx) |
23 | + token := contextdata.GetUserTokenFromCtx(r.Context()) | ||
24 | + req.UserId = token.UserId | ||
25 | + req.CompanyId = token.CompanyId | ||
21 | resp, err := l.MiniArticleSetTag(&req) | 26 | resp, err := l.MiniArticleSetTag(&req) |
22 | - if err != nil { | ||
23 | - httpx.ErrorCtx(r.Context(), w, err) | ||
24 | - } else { | ||
25 | - httpx.OkJsonCtx(r.Context(), w, resp) | ||
26 | - } | 27 | + result.HttpResult(r, w, resp, err) |
27 | } | 28 | } |
28 | } | 29 | } |
1 | +package article | ||
2 | + | ||
3 | +import ( | ||
4 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result" | ||
5 | + "net/http" | ||
6 | + | ||
7 | + "github.com/zeromicro/go-zero/rest/httpx" | ||
8 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/article" | ||
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/types" | ||
11 | +) | ||
12 | + | ||
13 | +func SystemArticleGetHistoryHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
14 | + return func(w http.ResponseWriter, r *http.Request) { | ||
15 | + var req types.SystemArticleGetHistoryRequest | ||
16 | + if err := httpx.Parse(r, &req); err != nil { | ||
17 | + result.ParamErrorResult(r, w, err) | ||
18 | + return | ||
19 | + } | ||
20 | + | ||
21 | + l := article.NewSystemArticleGetHistoryLogic(r.Context(), svcCtx) | ||
22 | + resp, err := l.SystemArticleGetHistory(&req) | ||
23 | + result.HttpResult(r, w, resp, err) | ||
24 | + } | ||
25 | +} |
@@ -15,7 +15,7 @@ func SystemGetArticleHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -15,7 +15,7 @@ func SystemGetArticleHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
15 | return func(w http.ResponseWriter, r *http.Request) { | 15 | return func(w http.ResponseWriter, r *http.Request) { |
16 | var req types.SystemArticleGetRequest | 16 | var req types.SystemArticleGetRequest |
17 | if err := httpx.Parse(r, &req); err != nil { | 17 | if err := httpx.Parse(r, &req); err != nil { |
18 | - httpx.ErrorCtx(r.Context(), w, err) | 18 | + result.ParamErrorResult(r, w, err) |
19 | return | 19 | return |
20 | } | 20 | } |
21 | 21 |
1 | -package comment | 1 | +package article |
2 | 2 | ||
3 | import ( | 3 | import ( |
4 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result" | ||
4 | "net/http" | 5 | "net/http" |
5 | 6 | ||
6 | "github.com/zeromicro/go-zero/rest/httpx" | 7 | "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/logic/article" |
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/svc" |
9 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types" | 10 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types" |
10 | ) | 11 | ) |
11 | 12 | ||
12 | -func MiniArticleCommentAtUserHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | 13 | +func SystemHistoryArticleHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { |
13 | return func(w http.ResponseWriter, r *http.Request) { | 14 | return func(w http.ResponseWriter, r *http.Request) { |
14 | - var req types.MiniArticleCommentAtUserRequest | 15 | + var req types.SystemArticleHistoryRequest |
15 | if err := httpx.Parse(r, &req); err != nil { | 16 | if err := httpx.Parse(r, &req); err != nil { |
16 | - httpx.ErrorCtx(r.Context(), w, err) | 17 | + result.ParamErrorResult(r, w, err) |
17 | return | 18 | return |
18 | } | 19 | } |
19 | 20 | ||
20 | - l := comment.NewMiniArticleCommentAtUserLogic(r.Context(), svcCtx) | ||
21 | - resp, err := l.MiniArticleCommentAtUser(&req) | ||
22 | - if err != nil { | ||
23 | - httpx.ErrorCtx(r.Context(), w, err) | ||
24 | - } else { | ||
25 | - httpx.OkJsonCtx(r.Context(), w, resp) | ||
26 | - } | 21 | + l := article.NewSystemHistoryArticleLogic(r.Context(), svcCtx) |
22 | + resp, err := l.SystemHistoryArticle(&req) | ||
23 | + result.HttpResult(r, w, resp, err) | ||
27 | } | 24 | } |
28 | } | 25 | } |
@@ -15,7 +15,7 @@ func SystemSearchArticleHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -15,7 +15,7 @@ func SystemSearchArticleHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
15 | return func(w http.ResponseWriter, r *http.Request) { | 15 | return func(w http.ResponseWriter, r *http.Request) { |
16 | var req types.SystemArticleSearchRequest | 16 | var req types.SystemArticleSearchRequest |
17 | if err := httpx.Parse(r, &req); err != nil { | 17 | if err := httpx.Parse(r, &req); err != nil { |
18 | - httpx.ErrorCtx(r.Context(), w, err) | 18 | + result.ParamErrorResult(r, w, err) |
19 | return | 19 | return |
20 | } | 20 | } |
21 | 21 |
1 | +package article | ||
2 | + | ||
3 | +import ( | ||
4 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result" | ||
5 | + "net/http" | ||
6 | + | ||
7 | + "github.com/zeromicro/go-zero/rest/httpx" | ||
8 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/article" | ||
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/types" | ||
11 | +) | ||
12 | + | ||
13 | +func SystemUpdateArticleHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
14 | + return func(w http.ResponseWriter, r *http.Request) { | ||
15 | + var req types.SystemArticleUpdateRequest | ||
16 | + if err := httpx.Parse(r, &req); err != nil { | ||
17 | + result.ParamErrorResult(r, w, err) | ||
18 | + return | ||
19 | + } | ||
20 | + l := article.NewSystemUpdateArticleLogic(r.Context(), svcCtx) | ||
21 | + resp, err := l.SystemUpdateArticle(&req, r.Header.Get("x-mmm-accesstoken")) | ||
22 | + result.HttpResult(r, w, resp, err) | ||
23 | + } | ||
24 | +} |
@@ -14,7 +14,7 @@ func SystemAddHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -14,7 +14,7 @@ func SystemAddHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
14 | return func(w http.ResponseWriter, r *http.Request) { | 14 | return func(w http.ResponseWriter, r *http.Request) { |
15 | var req types.DepartmentAddRequest | 15 | var req types.DepartmentAddRequest |
16 | if err := httpx.Parse(r, &req); err != nil { | 16 | if err := httpx.Parse(r, &req); err != nil { |
17 | - httpx.ErrorCtx(r.Context(), w, err) | 17 | + result.ParamErrorResult(r, w, err) |
18 | return | 18 | return |
19 | } | 19 | } |
20 | 20 |
@@ -14,7 +14,7 @@ func SystemDeleteHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -14,7 +14,7 @@ func SystemDeleteHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
14 | return func(w http.ResponseWriter, r *http.Request) { | 14 | return func(w http.ResponseWriter, r *http.Request) { |
15 | var req types.DepartmentGetRequest | 15 | var req types.DepartmentGetRequest |
16 | if err := httpx.Parse(r, &req); err != nil { | 16 | if err := httpx.Parse(r, &req); err != nil { |
17 | - httpx.ErrorCtx(r.Context(), w, err) | 17 | + result.ParamErrorResult(r, w, err) |
18 | return | 18 | return |
19 | } | 19 | } |
20 | 20 |
@@ -14,7 +14,7 @@ func SystemGetHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -14,7 +14,7 @@ func SystemGetHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
14 | return func(w http.ResponseWriter, r *http.Request) { | 14 | return func(w http.ResponseWriter, r *http.Request) { |
15 | var req types.DepartmentGetRequest | 15 | var req types.DepartmentGetRequest |
16 | if err := httpx.Parse(r, &req); err != nil { | 16 | if err := httpx.Parse(r, &req); err != nil { |
17 | - httpx.ErrorCtx(r.Context(), w, err) | 17 | + result.ParamErrorResult(r, w, err) |
18 | return | 18 | return |
19 | } | 19 | } |
20 | 20 |
@@ -14,7 +14,7 @@ func SystemListHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -14,7 +14,7 @@ func SystemListHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
14 | return func(w http.ResponseWriter, r *http.Request) { | 14 | return func(w http.ResponseWriter, r *http.Request) { |
15 | var req types.DepartmentListRequest | 15 | var req types.DepartmentListRequest |
16 | if err := httpx.Parse(r, &req); err != nil { | 16 | if err := httpx.Parse(r, &req); err != nil { |
17 | - httpx.ErrorCtx(r.Context(), w, err) | 17 | + result.ParamErrorResult(r, w, err) |
18 | return | 18 | return |
19 | } | 19 | } |
20 | 20 |
@@ -14,7 +14,7 @@ func SystemUpdateHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -14,7 +14,7 @@ func SystemUpdateHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
14 | return func(w http.ResponseWriter, r *http.Request) { | 14 | return func(w http.ResponseWriter, r *http.Request) { |
15 | var req types.DepartmentUpdateRequest | 15 | var req types.DepartmentUpdateRequest |
16 | if err := httpx.Parse(r, &req); err != nil { | 16 | if err := httpx.Parse(r, &req); err != nil { |
17 | - httpx.ErrorCtx(r.Context(), w, err) | 17 | + result.ParamErrorResult(r, w, err) |
18 | return | 18 | return |
19 | } | 19 | } |
20 | 20 |
@@ -14,7 +14,7 @@ func MiniBusinessHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -14,7 +14,7 @@ func MiniBusinessHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
14 | return func(w http.ResponseWriter, r *http.Request) { | 14 | return func(w http.ResponseWriter, r *http.Request) { |
15 | var req types.MessageBusinessRequest | 15 | var req types.MessageBusinessRequest |
16 | if err := httpx.Parse(r, &req); err != nil { | 16 | if err := httpx.Parse(r, &req); err != nil { |
17 | - httpx.ErrorCtx(r.Context(), w, err) | 17 | + result.ParamErrorResult(r, w, err) |
18 | return | 18 | return |
19 | } | 19 | } |
20 | 20 |
@@ -14,7 +14,7 @@ func MiniSystemHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -14,7 +14,7 @@ func MiniSystemHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
14 | return func(w http.ResponseWriter, r *http.Request) { | 14 | return func(w http.ResponseWriter, r *http.Request) { |
15 | var req types.MessageSystemRequest | 15 | var req types.MessageSystemRequest |
16 | if err := httpx.Parse(r, &req); err != nil { | 16 | if err := httpx.Parse(r, &req); err != nil { |
17 | - httpx.ErrorCtx(r.Context(), w, err) | 17 | + result.ParamErrorResult(r, w, err) |
18 | return | 18 | return |
19 | } | 19 | } |
20 | 20 |
@@ -22,11 +22,6 @@ func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) { | @@ -22,11 +22,6 @@ func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) { | ||
22 | []rest.Route{ | 22 | []rest.Route{ |
23 | { | 23 | { |
24 | Method: http.MethodPost, | 24 | Method: http.MethodPost, |
25 | - Path: "/article_comment/at_user/select", | ||
26 | - Handler: comment.MiniArticleCommentAtUserHandler(serverCtx), | ||
27 | - }, | ||
28 | - { | ||
29 | - Method: http.MethodPost, | ||
30 | Path: "/article_comment", | 25 | Path: "/article_comment", |
31 | Handler: comment.MiniCreateArticleCommentHandler(serverCtx), | 26 | Handler: comment.MiniCreateArticleCommentHandler(serverCtx), |
32 | }, | 27 | }, |
@@ -120,7 +115,7 @@ func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) { | @@ -120,7 +115,7 @@ func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) { | ||
120 | Handler: tags.SearchTagHandler(serverCtx), | 115 | Handler: tags.SearchTagHandler(serverCtx), |
121 | }, | 116 | }, |
122 | }, | 117 | }, |
123 | - rest.WithJwt(serverCtx.Config.MiniAuth.AccessSecret), | 118 | + rest.WithJwt(serverCtx.Config.SystemAuth.AccessSecret), |
124 | rest.WithPrefix("/v1/system"), | 119 | rest.WithPrefix("/v1/system"), |
125 | ) | 120 | ) |
126 | 121 | ||
@@ -387,6 +382,21 @@ func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) { | @@ -387,6 +382,21 @@ func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) { | ||
387 | Handler: article.SystemSearchArticleHandler(serverCtx), | 382 | Handler: article.SystemSearchArticleHandler(serverCtx), |
388 | }, | 383 | }, |
389 | { | 384 | { |
385 | + Method: http.MethodPut, | ||
386 | + Path: "/article", | ||
387 | + Handler: article.SystemUpdateArticleHandler(serverCtx), | ||
388 | + }, | ||
389 | + { | ||
390 | + Method: http.MethodPost, | ||
391 | + Path: "/article/history", | ||
392 | + Handler: article.SystemHistoryArticleHandler(serverCtx), | ||
393 | + }, | ||
394 | + { | ||
395 | + Method: http.MethodGet, | ||
396 | + Path: "/article/history/:id", | ||
397 | + Handler: article.SystemArticleGetHistoryHandler(serverCtx), | ||
398 | + }, | ||
399 | + { | ||
390 | Method: http.MethodPost, | 400 | Method: http.MethodPost, |
391 | Path: "/article/search/me", | 401 | Path: "/article/search/me", |
392 | Handler: article.SystemArticleSearchMeHandler(serverCtx), | 402 | Handler: article.SystemArticleSearchMeHandler(serverCtx), |
@@ -7,6 +7,8 @@ import ( | @@ -7,6 +7,8 @@ import ( | ||
7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/tags" | 7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/tags" |
8 | "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" |
9 | "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" |
10 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata" | ||
11 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result" | ||
10 | ) | 12 | ) |
11 | 13 | ||
12 | func CreateTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | 14 | func CreateTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { |
@@ -18,11 +20,9 @@ func CreateTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -18,11 +20,9 @@ func CreateTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
18 | } | 20 | } |
19 | 21 | ||
20 | l := tags.NewCreateTagLogic(r.Context(), svcCtx) | 22 | l := tags.NewCreateTagLogic(r.Context(), svcCtx) |
23 | + token := contextdata.GetUserTokenFromCtx(r.Context()) | ||
24 | + req.CompanyId = token.CompanyId | ||
21 | resp, err := l.CreateTag(&req) | 25 | resp, err := l.CreateTag(&req) |
22 | - if err != nil { | ||
23 | - httpx.ErrorCtx(r.Context(), w, err) | ||
24 | - } else { | ||
25 | - httpx.OkJsonCtx(r.Context(), w, resp) | ||
26 | - } | 26 | + result.HttpResult(r, w, resp, err) |
27 | } | 27 | } |
28 | } | 28 | } |
@@ -7,6 +7,8 @@ import ( | @@ -7,6 +7,8 @@ import ( | ||
7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/tags" | 7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/tags" |
8 | "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" |
9 | "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" |
10 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata" | ||
11 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result" | ||
10 | ) | 12 | ) |
11 | 13 | ||
12 | func DeleteTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | 14 | func DeleteTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { |
@@ -18,11 +20,9 @@ func DeleteTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -18,11 +20,9 @@ func DeleteTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
18 | } | 20 | } |
19 | 21 | ||
20 | l := tags.NewDeleteTagLogic(r.Context(), svcCtx) | 22 | l := tags.NewDeleteTagLogic(r.Context(), svcCtx) |
23 | + token := contextdata.GetUserTokenFromCtx(r.Context()) | ||
24 | + req.CompanyId = token.CompanyId | ||
21 | resp, err := l.DeleteTag(&req) | 25 | resp, err := l.DeleteTag(&req) |
22 | - if err != nil { | ||
23 | - httpx.ErrorCtx(r.Context(), w, err) | ||
24 | - } else { | ||
25 | - httpx.OkJsonCtx(r.Context(), w, resp) | ||
26 | - } | 26 | + result.HttpResult(r, w, resp, err) |
27 | } | 27 | } |
28 | } | 28 | } |
@@ -7,6 +7,8 @@ import ( | @@ -7,6 +7,8 @@ import ( | ||
7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/tags" | 7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/tags" |
8 | "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" |
9 | "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" |
10 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata" | ||
11 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result" | ||
10 | ) | 12 | ) |
11 | 13 | ||
12 | func EditTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | 14 | func EditTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { |
@@ -18,11 +20,9 @@ func EditTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -18,11 +20,9 @@ func EditTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
18 | } | 20 | } |
19 | 21 | ||
20 | l := tags.NewEditTagLogic(r.Context(), svcCtx) | 22 | l := tags.NewEditTagLogic(r.Context(), svcCtx) |
23 | + token := contextdata.GetUserTokenFromCtx(r.Context()) | ||
24 | + req.CompanyId = token.CompanyId | ||
21 | resp, err := l.EditTag(&req) | 25 | resp, err := l.EditTag(&req) |
22 | - if err != nil { | ||
23 | - httpx.ErrorCtx(r.Context(), w, err) | ||
24 | - } else { | ||
25 | - httpx.OkJsonCtx(r.Context(), w, resp) | ||
26 | - } | 26 | + result.HttpResult(r, w, resp, err) |
27 | } | 27 | } |
28 | } | 28 | } |
@@ -7,6 +7,8 @@ import ( | @@ -7,6 +7,8 @@ import ( | ||
7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/tags" | 7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/tags" |
8 | "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" |
9 | "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" |
10 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata" | ||
11 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result" | ||
10 | ) | 12 | ) |
11 | 13 | ||
12 | func GetTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | 14 | func GetTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { |
@@ -16,13 +18,10 @@ func GetTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -16,13 +18,10 @@ func GetTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
16 | httpx.ErrorCtx(r.Context(), w, err) | 18 | httpx.ErrorCtx(r.Context(), w, err) |
17 | return | 19 | return |
18 | } | 20 | } |
19 | - | 21 | + token := contextdata.GetUserTokenFromCtx(r.Context()) |
22 | + req.CompanyId = token.CompanyId | ||
20 | l := tags.NewGetTagLogic(r.Context(), svcCtx) | 23 | l := tags.NewGetTagLogic(r.Context(), svcCtx) |
21 | resp, err := l.GetTag(&req) | 24 | resp, err := l.GetTag(&req) |
22 | - if err != nil { | ||
23 | - httpx.ErrorCtx(r.Context(), w, err) | ||
24 | - } else { | ||
25 | - httpx.OkJsonCtx(r.Context(), w, resp) | ||
26 | - } | 25 | + result.HttpResult(r, w, resp, err) |
27 | } | 26 | } |
28 | } | 27 | } |
@@ -7,6 +7,8 @@ import ( | @@ -7,6 +7,8 @@ import ( | ||
7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/tags" | 7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/logic/tags" |
8 | "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" |
9 | "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" |
10 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata" | ||
11 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/result" | ||
10 | ) | 12 | ) |
11 | 13 | ||
12 | func SearchTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | 14 | func SearchTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { |
@@ -18,11 +20,9 @@ func SearchTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -18,11 +20,9 @@ func SearchTagHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
18 | } | 20 | } |
19 | 21 | ||
20 | l := tags.NewSearchTagLogic(r.Context(), svcCtx) | 22 | l := tags.NewSearchTagLogic(r.Context(), svcCtx) |
23 | + token := contextdata.GetUserTokenFromCtx(r.Context()) | ||
24 | + req.CompanyId = token.CompanyId | ||
21 | resp, err := l.SearchTag(&req) | 25 | resp, err := l.SearchTag(&req) |
22 | - if err != nil { | ||
23 | - httpx.ErrorCtx(r.Context(), w, err) | ||
24 | - } else { | ||
25 | - httpx.OkJsonCtx(r.Context(), w, resp) | ||
26 | - } | 26 | + result.HttpResult(r, w, resp, err) |
27 | } | 27 | } |
28 | } | 28 | } |
@@ -14,7 +14,7 @@ func MiniMyLikeHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | @@ -14,7 +14,7 @@ func MiniMyLikeHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { | ||
14 | return func(w http.ResponseWriter, r *http.Request) { | 14 | return func(w http.ResponseWriter, r *http.Request) { |
15 | var req types.MiniMyLikeRequest | 15 | var req types.MiniMyLikeRequest |
16 | if err := httpx.Parse(r, &req); err != nil { | 16 | if err := httpx.Parse(r, &req); err != nil { |
17 | - httpx.ErrorCtx(r.Context(), w, err) | 17 | + result.ParamErrorResult(r, w, err) |
18 | return | 18 | return |
19 | } | 19 | } |
20 | 20 |
@@ -5,6 +5,8 @@ import ( | @@ -5,6 +5,8 @@ import ( | ||
5 | 5 | ||
6 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc" | 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" | 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/domain" | ||
9 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr" | ||
8 | 10 | ||
9 | "github.com/zeromicro/go-zero/core/logx" | 11 | "github.com/zeromicro/go-zero/core/logx" |
10 | ) | 12 | ) |
@@ -24,7 +26,44 @@ func NewMiniAllArticleTagLogic(ctx context.Context, svcCtx *svc.ServiceContext) | @@ -24,7 +26,44 @@ func NewMiniAllArticleTagLogic(ctx context.Context, svcCtx *svc.ServiceContext) | ||
24 | } | 26 | } |
25 | 27 | ||
26 | func (l *MiniAllArticleTagLogic) MiniAllArticleTag(req *types.MiniAllArticleTagRequest) (resp *types.MiniAllArticleTagResponse, err error) { | 28 | func (l *MiniAllArticleTagLogic) MiniAllArticleTag(req *types.MiniAllArticleTagRequest) (resp *types.MiniAllArticleTagResponse, err error) { |
27 | - // todo: add your logic here and delete this line | ||
28 | - | ||
29 | - return | 29 | + var conn = l.svcCtx.DefaultDBConn() |
30 | + queryOption := domain.NewQueryOptions().WithFindOnly() | ||
31 | + _, tagList, err := l.svcCtx.ArticleTagRepository.Find(l.ctx, conn, req.CompanyId, queryOption) | ||
32 | + if err != nil { | ||
33 | + return nil, xerr.NewErrMsgErr("获取标签列表失败", err) | ||
34 | + } | ||
35 | + // 合并输出数据 | ||
36 | + var group []string | ||
37 | + tagMap := map[string][]types.ArticleTagItem{} | ||
38 | + for _, val := range tagList { | ||
39 | + if m, ok := tagMap[val.Category]; ok { | ||
40 | + m = append(m, types.ArticleTagItem{ | ||
41 | + Id: val.Id, | ||
42 | + Group: val.Category, | ||
43 | + Name: val.Name, | ||
44 | + Image: val.Image.Url, | ||
45 | + }) | ||
46 | + tagMap[val.Category] = m | ||
47 | + } else { | ||
48 | + group = append(group, val.Category) | ||
49 | + tagMap[val.Category] = []types.ArticleTagItem{ | ||
50 | + { | ||
51 | + Id: val.Id, | ||
52 | + Group: val.Category, | ||
53 | + Name: val.Name, | ||
54 | + Image: val.Image.Url, | ||
55 | + }, | ||
56 | + } | ||
57 | + } | ||
58 | + } | ||
59 | + resp = &types.MiniAllArticleTagResponse{ | ||
60 | + TagGroup: make([]types.ArticleTagGroup, 0), | ||
61 | + } | ||
62 | + for i := range group { | ||
63 | + resp.TagGroup = append(resp.TagGroup, types.ArticleTagGroup{ | ||
64 | + Group: group[i], | ||
65 | + Tags: tagMap[group[i]], | ||
66 | + }) | ||
67 | + } | ||
68 | + return resp, nil | ||
30 | } | 69 | } |
@@ -2,6 +2,7 @@ package article | @@ -2,6 +2,7 @@ package article | ||
2 | 2 | ||
3 | import ( | 3 | import ( |
4 | "context" | 4 | "context" |
5 | + | ||
5 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain" | 6 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain" |
6 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata" | 7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata" |
7 | 8 | ||
@@ -25,6 +26,7 @@ func NewMiniArticleMarkListLogic(ctx context.Context, svcCtx *svc.ServiceContext | @@ -25,6 +26,7 @@ func NewMiniArticleMarkListLogic(ctx context.Context, svcCtx *svc.ServiceContext | ||
25 | } | 26 | } |
26 | } | 27 | } |
27 | 28 | ||
29 | +// 获取我的文章浏览记录 | ||
28 | func (l *MiniArticleMarkListLogic) MiniArticleMarkList(req *types.MiniArticleMarkListRequest) (resp *types.MiniArticleMarkListResponse, err error) { | 30 | func (l *MiniArticleMarkListLogic) MiniArticleMarkList(req *types.MiniArticleMarkListRequest) (resp *types.MiniArticleMarkListResponse, err error) { |
29 | var userToken = contextdata.GetUserTokenFromCtx(l.ctx) | 31 | var userToken = contextdata.GetUserTokenFromCtx(l.ctx) |
30 | 32 |
@@ -5,6 +5,9 @@ import ( | @@ -5,6 +5,9 @@ import ( | ||
5 | 5 | ||
6 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc" | 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" | 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" | ||
8 | 11 | ||
9 | "github.com/zeromicro/go-zero/core/logx" | 12 | "github.com/zeromicro/go-zero/core/logx" |
10 | ) | 13 | ) |
@@ -23,8 +26,65 @@ func NewMiniArticleSetTagLogic(ctx context.Context, svcCtx *svc.ServiceContext) | @@ -23,8 +26,65 @@ func NewMiniArticleSetTagLogic(ctx context.Context, svcCtx *svc.ServiceContext) | ||
23 | } | 26 | } |
24 | } | 27 | } |
25 | 28 | ||
29 | +// 设置文章的定性标签 | ||
26 | func (l *MiniArticleSetTagLogic) MiniArticleSetTag(req *types.MiniArticleSetTagRequest) (resp *types.MiniArticleSetTagResponse, err error) { | 30 | func (l *MiniArticleSetTagLogic) MiniArticleSetTag(req *types.MiniArticleSetTagRequest) (resp *types.MiniArticleSetTagResponse, err error) { |
27 | - // todo: add your logic here and delete this line | 31 | + var conn = l.svcCtx.DefaultDBConn() |
32 | + // | ||
33 | + articleInfo, err := l.svcCtx.ArticleRepository.FindOne(l.ctx, conn, req.ArticleId) | ||
34 | + if err != nil { | ||
35 | + return nil, xerr.NewErrMsgErr("获取文章信息失败", err) | ||
36 | + } | ||
37 | + if articleInfo.CompanyId != req.CompanyId { | ||
38 | + return nil, xerr.NewErrMsg("获取文章信息失败") | ||
39 | + } | ||
40 | + | ||
41 | + tagInfo, err := l.svcCtx.ArticleTagRepository.FindOne(l.ctx, conn, req.TagId) | ||
42 | + if err != nil { | ||
43 | + return nil, xerr.NewErrMsgErr("获取标签信息失败", err) | ||
44 | + } | ||
28 | 45 | ||
29 | - return | 46 | + if tagInfo.CompanyId != req.CompanyId { |
47 | + return nil, xerr.NewErrMsg("获取标签信息失败") | ||
48 | + } | ||
49 | + // 查询可能存在的 ArticleAndTag | ||
50 | + queryOption := domain.NewQueryOptions().WithFindOnly().MustWithKV("articleId", articleInfo.Id) | ||
51 | + _, oldTags, err := l.svcCtx.ArticleAndTagRepository.Find(l.ctx, conn, queryOption) | ||
52 | + if err != nil { | ||
53 | + return nil, xerr.NewErrMsgErr("检查文章的标签失败", err) | ||
54 | + } | ||
55 | + // 更新article中的tags | ||
56 | + articleInfo.Tags = []int64{tagInfo.Id} | ||
57 | + // 额外保存一份ArticleAndTag | ||
58 | + articleAndTag := domain.ArticleAndTag{ | ||
59 | + Id: 0, | ||
60 | + CompanyId: articleInfo.CompanyId, | ||
61 | + CreatedAt: 0, | ||
62 | + UpdatedAt: 0, | ||
63 | + ArticleId: articleInfo.Id, | ||
64 | + TagId: tagInfo.Id, | ||
65 | + } | ||
66 | + err = transaction.UseTrans(l.ctx, conn.DB(), func(ctx context.Context, c transaction.Conn) error { | ||
67 | + //清理可能存在的 ArticleAndTag | ||
68 | + for _, v := range oldTags { | ||
69 | + _, err = l.svcCtx.ArticleAndTagRepository.Delete(ctx, c, v) | ||
70 | + if err != nil { | ||
71 | + return err | ||
72 | + } | ||
73 | + } | ||
74 | + // 更新article | ||
75 | + _, err = l.svcCtx.ArticleRepository.UpdateWithVersion(ctx, c, articleInfo) | ||
76 | + if err != nil { | ||
77 | + return err | ||
78 | + } | ||
79 | + _, err = l.svcCtx.ArticleAndTagRepository.Insert(ctx, c, &articleAndTag) | ||
80 | + if err != nil { | ||
81 | + return err | ||
82 | + } | ||
83 | + return nil | ||
84 | + }, true) | ||
85 | + | ||
86 | + resp = &types.MiniArticleSetTagResponse{ | ||
87 | + Id: articleAndTag.Id, | ||
88 | + } | ||
89 | + return resp, nil | ||
30 | } | 90 | } |
@@ -71,6 +71,7 @@ func (l *MiniUserLikeArticleLogic) MiniUserLikeArticle(req *types.MiniUserLikeAr | @@ -71,6 +71,7 @@ func (l *MiniUserLikeArticleLogic) MiniUserLikeArticle(req *types.MiniUserLikeAr | ||
71 | if u, ok := userMap[val.UserId]; ok { | 71 | if u, ok := userMap[val.UserId]; ok { |
72 | item.Name = u.Name | 72 | item.Name = u.Name |
73 | item.Avatar = u.Avatar | 73 | item.Avatar = u.Avatar |
74 | + item.Position = u.Position | ||
74 | } | 75 | } |
75 | resp.List[i] = item | 76 | resp.List[i] = item |
76 | } | 77 | } |
1 | -package comment | 1 | +package article |
2 | 2 | ||
3 | import ( | 3 | import ( |
4 | "context" | 4 | "context" |
@@ -9,22 +9,22 @@ import ( | @@ -9,22 +9,22 @@ import ( | ||
9 | "github.com/zeromicro/go-zero/core/logx" | 9 | "github.com/zeromicro/go-zero/core/logx" |
10 | ) | 10 | ) |
11 | 11 | ||
12 | -type MiniArticleCommentAtUserLogic struct { | 12 | +type SystemArticleGetHistoryLogic struct { |
13 | logx.Logger | 13 | logx.Logger |
14 | ctx context.Context | 14 | ctx context.Context |
15 | svcCtx *svc.ServiceContext | 15 | svcCtx *svc.ServiceContext |
16 | } | 16 | } |
17 | 17 | ||
18 | -func NewMiniArticleCommentAtUserLogic(ctx context.Context, svcCtx *svc.ServiceContext) *MiniArticleCommentAtUserLogic { | ||
19 | - return &MiniArticleCommentAtUserLogic{ | 18 | +func NewSystemArticleGetHistoryLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SystemArticleGetHistoryLogic { |
19 | + return &SystemArticleGetHistoryLogic{ | ||
20 | Logger: logx.WithContext(ctx), | 20 | Logger: logx.WithContext(ctx), |
21 | ctx: ctx, | 21 | ctx: ctx, |
22 | svcCtx: svcCtx, | 22 | svcCtx: svcCtx, |
23 | } | 23 | } |
24 | } | 24 | } |
25 | 25 | ||
26 | -func (l *MiniArticleCommentAtUserLogic) MiniArticleCommentAtUser(req *types.MiniArticleCommentAtUserRequest) (resp *types.MiniArticleCommentAtUserResponse, err error) { | ||
27 | - // todo: add your logic here and delete this line | 26 | +func (l *SystemArticleGetHistoryLogic) SystemArticleGetHistory(req *types.SystemArticleGetHistoryRequest) (resp *types.SystemArticleGetHistoryResponse, err error) { |
27 | + //var conn = l.svcCtx.DefaultDBConn() | ||
28 | 28 | ||
29 | return | 29 | return |
30 | } | 30 | } |
@@ -2,6 +2,9 @@ package article | @@ -2,6 +2,9 @@ package article | ||
2 | 2 | ||
3 | import ( | 3 | import ( |
4 | "context" | 4 | "context" |
5 | + "github.com/samber/lo" | ||
6 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain" | ||
7 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr" | ||
5 | 8 | ||
6 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc" | 9 | "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" | 10 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types" |
@@ -24,7 +27,94 @@ func NewSystemGetArticleLogic(ctx context.Context, svcCtx *svc.ServiceContext) * | @@ -24,7 +27,94 @@ func NewSystemGetArticleLogic(ctx context.Context, svcCtx *svc.ServiceContext) * | ||
24 | } | 27 | } |
25 | 28 | ||
26 | func (l *SystemGetArticleLogic) SystemGetArticle(req *types.SystemArticleGetRequest) (resp *types.SystemArticleGetResponse, err error) { | 29 | func (l *SystemGetArticleLogic) SystemGetArticle(req *types.SystemArticleGetRequest) (resp *types.SystemArticleGetResponse, err error) { |
27 | - // todo: add your logic here and delete this line | ||
28 | - | ||
29 | - return | 30 | + var conn = l.svcCtx.DefaultDBConn() |
31 | + article, err := l.svcCtx.ArticleRepository.FindOne(l.ctx, conn, req.Id) | ||
32 | + if err != nil { | ||
33 | + return nil, xerr.NewErrMsgErr("获取帖子异常", err) | ||
34 | + } | ||
35 | + images := make([]string, 0) | ||
36 | + lo.ForEach(article.Images, func(img domain.Image, n int) { | ||
37 | + images = append(images, img.Url) | ||
38 | + }) | ||
39 | + resp = &types.SystemArticleGetResponse{ | ||
40 | + Id: article.Id, | ||
41 | + Title: article.Title, | ||
42 | + AuthorId: article.AuthorId, | ||
43 | + Author: types.ArticleAuthor{ | ||
44 | + Id: article.Author.Id, | ||
45 | + Name: article.Author.Name, | ||
46 | + Avatar: article.Author.Avatar, | ||
47 | + Position: article.Author.Position, | ||
48 | + Company: article.Author.Company, | ||
49 | + }, | ||
50 | + CreatedAt: article.CreatedAt, | ||
51 | + Section: make([]types.ArticleSection, 0), | ||
52 | + Images: images, | ||
53 | + WhoRead: article.WhoRead, | ||
54 | + WhoReadInfo: make([]types.UserShowName, 0), | ||
55 | + WhoReview: article.WhoReview, | ||
56 | + WhoReviewInfo: make([]types.UserShowName, 0), | ||
57 | + Location: types.Location{ | ||
58 | + Longitude: article.Location.Longitude, | ||
59 | + Latitude: article.Location.Latitude, | ||
60 | + Descript: article.Location.Descript, | ||
61 | + }, | ||
62 | + CountLove: article.CountLove, | ||
63 | + CountComment: article.CountComment, | ||
64 | + CountRead: article.CountRead, | ||
65 | + Show: int(article.Show), | ||
66 | + Tags: make([]types.ArticleTagItem, 0), | ||
67 | + } | ||
68 | + //标签 | ||
69 | + if len(article.Tags) > 0 { | ||
70 | + _, tags, err := l.svcCtx.ArticleTagRepository.Find(l.ctx, conn, article.CompanyId, domain.NewQueryOptions().WithKV("ids", article.Tags)) | ||
71 | + if err == nil && len(tags) > 0 { | ||
72 | + lo.ForEach(tags, func(tag *domain.ArticleTag, index int) { | ||
73 | + resp.Tags = append(resp.Tags, types.ArticleTagItem{ | ||
74 | + Id: tag.Id, | ||
75 | + Group: tag.Category, | ||
76 | + Name: tag.Name, | ||
77 | + Image: tag.Image.Url, | ||
78 | + }) | ||
79 | + }) | ||
80 | + } | ||
81 | + } | ||
82 | + //文章段落 | ||
83 | + _, articleSections, err := l.svcCtx.ArticleSectionRepository.Find(l.ctx, conn, domain.NewQueryOptions().WithKV("articleId", req.Id)) | ||
84 | + if err != nil { | ||
85 | + return nil, xerr.NewErrMsgErr("获取帖子异常", err) | ||
86 | + } | ||
87 | + lo.ForEach(articleSections, func(item *domain.ArticleSection, index int) { | ||
88 | + resp.Section = append(resp.Section, types.ArticleSection{ | ||
89 | + Id: item.Id, | ||
90 | + Content: item.Content, | ||
91 | + SortBy: item.SortBy, | ||
92 | + TotalComment: item.TotalComment, | ||
93 | + }) | ||
94 | + }) | ||
95 | + userIds := lo.Union(resp.WhoRead, resp.WhoReview) | ||
96 | + if len(userIds) > 0 { | ||
97 | + _, users, err := l.svcCtx.UserRepository.Find(l.ctx, conn, domain.NewQueryOptions().WithKV("ids", userIds)) | ||
98 | + if err != nil { | ||
99 | + return nil, xerr.NewErrMsgErr("获取帖子异常", err) | ||
100 | + } | ||
101 | + userSlices := make(map[int64]types.UserShowName) | ||
102 | + lo.ForEach(users, func(user *domain.User, index int) { | ||
103 | + userSlices[user.Id] = types.UserShowName{ | ||
104 | + Id: int(user.Id), | ||
105 | + Name: user.Name, | ||
106 | + } | ||
107 | + }) | ||
108 | + lo.ForEach(resp.WhoRead, func(userId int64, index int) { | ||
109 | + if value, ok := userSlices[userId]; ok { | ||
110 | + resp.WhoReadInfo = append(resp.WhoReadInfo, value) | ||
111 | + } | ||
112 | + }) | ||
113 | + lo.ForEach(resp.WhoReview, func(userId int64, index int) { | ||
114 | + if value, ok := userSlices[userId]; ok { | ||
115 | + resp.WhoReviewInfo = append(resp.WhoReviewInfo, value) | ||
116 | + } | ||
117 | + }) | ||
118 | + } | ||
119 | + return resp, nil | ||
30 | } | 120 | } |
1 | +package article | ||
2 | + | ||
3 | +import ( | ||
4 | + "context" | ||
5 | + "github.com/samber/lo" | ||
6 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain" | ||
7 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr" | ||
8 | + | ||
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/types" | ||
11 | + | ||
12 | + "github.com/zeromicro/go-zero/core/logx" | ||
13 | +) | ||
14 | + | ||
15 | +type SystemHistoryArticleLogic struct { | ||
16 | + logx.Logger | ||
17 | + ctx context.Context | ||
18 | + svcCtx *svc.ServiceContext | ||
19 | +} | ||
20 | + | ||
21 | +func NewSystemHistoryArticleLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SystemHistoryArticleLogic { | ||
22 | + return &SystemHistoryArticleLogic{ | ||
23 | + Logger: logx.WithContext(ctx), | ||
24 | + ctx: ctx, | ||
25 | + svcCtx: svcCtx, | ||
26 | + } | ||
27 | +} | ||
28 | + | ||
29 | +func (l *SystemHistoryArticleLogic) SystemHistoryArticle(req *types.SystemArticleHistoryRequest) (resp *types.SystemArticleHistoryResponse, err error) { | ||
30 | + var conn = l.svcCtx.DefaultDBConn() | ||
31 | + total, list, err := l.svcCtx.ArticleBackupRepository.Find( | ||
32 | + l.ctx, | ||
33 | + conn, | ||
34 | + domain.NewQueryOptions(). | ||
35 | + WithOffsetLimit(req.Page, req.Size). | ||
36 | + WithKV("articleId", req.ArticleId). | ||
37 | + WithKV("operator", req.Author). | ||
38 | + WithKV("beginCreatedAt", req.BeginTime). | ||
39 | + WithKV("endCreatedAt", req.EndTime), | ||
40 | + ) | ||
41 | + if err != nil { | ||
42 | + return nil, xerr.NewErrMsgErr("搜索编辑历史异常", err) | ||
43 | + } | ||
44 | + resp = &types.SystemArticleHistoryResponse{ | ||
45 | + Total: int(total), | ||
46 | + List: make([]types.SystemArticleHistory, 0), | ||
47 | + } | ||
48 | + lo.ForEach(list, func(item *domain.ArticleBackup, index int) { | ||
49 | + resp.List = append(resp.List, types.SystemArticleHistory{ | ||
50 | + Id: item.Id, | ||
51 | + Author: item.Operator.Name, | ||
52 | + Action: item.Action, | ||
53 | + UpdatedAt: item.CreatedAt, | ||
54 | + }) | ||
55 | + }) | ||
56 | + return | ||
57 | +} |
@@ -2,9 +2,11 @@ package article | @@ -2,9 +2,11 @@ package article | ||
2 | 2 | ||
3 | import ( | 3 | import ( |
4 | "context" | 4 | "context" |
5 | - | 5 | + "github.com/samber/lo" |
6 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc" | 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" | 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/domain" | ||
9 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr" | ||
8 | 10 | ||
9 | "github.com/zeromicro/go-zero/core/logx" | 11 | "github.com/zeromicro/go-zero/core/logx" |
10 | ) | 12 | ) |
@@ -24,7 +26,38 @@ func NewSystemSearchArticleLogic(ctx context.Context, svcCtx *svc.ServiceContext | @@ -24,7 +26,38 @@ func NewSystemSearchArticleLogic(ctx context.Context, svcCtx *svc.ServiceContext | ||
24 | } | 26 | } |
25 | 27 | ||
26 | func (l *SystemSearchArticleLogic) SystemSearchArticle(req *types.SystemArticleSearchRequest) (resp *types.SystemArticleSearchResponse, err error) { | 28 | func (l *SystemSearchArticleLogic) SystemSearchArticle(req *types.SystemArticleSearchRequest) (resp *types.SystemArticleSearchResponse, err error) { |
27 | - // todo: add your logic here and delete this line | ||
28 | - | ||
29 | - return | 29 | + var conn = l.svcCtx.DefaultDBConn() |
30 | + queryOptions := domain.NewQueryOptions(). | ||
31 | + WithOffsetLimit(req.Page, req.Size). | ||
32 | + WithKV("title", req.Title). | ||
33 | + WithKV("author", req.Author). | ||
34 | + WithKV("beginCreatedAt", req.BeginTime). | ||
35 | + WithKV("endCreatedAt", req.EndTime) | ||
36 | + total, articles, err := l.svcCtx.ArticleRepository.Find(l.ctx, conn, req.CompanyId, queryOptions) | ||
37 | + if err != nil { | ||
38 | + return nil, xerr.NewErrMsgErr("搜索帖子异常", err) | ||
39 | + } | ||
40 | + resp = &types.SystemArticleSearchResponse{ | ||
41 | + Total: int(total), | ||
42 | + List: make([]types.SystemArticleSearch, 0), | ||
43 | + } | ||
44 | + lo.ForEach(articles, func(item *domain.Article, index int) { | ||
45 | + images := make([]string, 0) | ||
46 | + lo.ForEach(item.Images, func(img domain.Image, n int) { | ||
47 | + images = append(images, img.Url) | ||
48 | + }) | ||
49 | + resp.List = append(resp.List, types.SystemArticleSearch{ | ||
50 | + Id: item.Id, | ||
51 | + Title: item.Title, | ||
52 | + Author: item.Author.Name, | ||
53 | + Images: images, | ||
54 | + CreatedAt: item.CreatedAt, | ||
55 | + CountLove: item.CountLove, | ||
56 | + CountComment: item.CountComment, | ||
57 | + Show: int(item.Show), | ||
58 | + Tags: nil, | ||
59 | + TargetUser: int(item.TargetUser), | ||
60 | + }) | ||
61 | + }) | ||
62 | + return resp, nil | ||
30 | } | 63 | } |
1 | +package article | ||
2 | + | ||
3 | +import ( | ||
4 | + "context" | ||
5 | + "github.com/samber/lo" | ||
6 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/db/transaction" | ||
7 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain" | ||
8 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/gateway/authlib" | ||
9 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata" | ||
10 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr" | ||
11 | + | ||
12 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc" | ||
13 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types" | ||
14 | + | ||
15 | + "github.com/zeromicro/go-zero/core/logx" | ||
16 | +) | ||
17 | + | ||
18 | +type SystemUpdateArticleLogic struct { | ||
19 | + logx.Logger | ||
20 | + ctx context.Context | ||
21 | + svcCtx *svc.ServiceContext | ||
22 | +} | ||
23 | + | ||
24 | +func NewSystemUpdateArticleLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SystemUpdateArticleLogic { | ||
25 | + return &SystemUpdateArticleLogic{ | ||
26 | + Logger: logx.WithContext(ctx), | ||
27 | + ctx: ctx, | ||
28 | + svcCtx: svcCtx, | ||
29 | + } | ||
30 | +} | ||
31 | + | ||
32 | +func (l *SystemUpdateArticleLogic) SystemUpdateArticle(req *types.SystemArticleUpdateRequest, accessToken string) (resp *types.SystemArticleUpdateResponse, err error) { | ||
33 | + var conn = l.svcCtx.DefaultDBConn() | ||
34 | + userToken := contextdata.GetUserTokenFromCtx(l.ctx) | ||
35 | + article, err := l.svcCtx.ArticleRepository.FindOne(l.ctx, conn, req.Id) | ||
36 | + if err != nil { | ||
37 | + return nil, xerr.NewErrMsgErr("帖子不存在", err) | ||
38 | + } | ||
39 | + //TODO 获取图片的尺寸大小 | ||
40 | + images := []domain.Image{} | ||
41 | + for _, val := range req.Images { | ||
42 | + images = append(images, domain.Image{ | ||
43 | + Url: val, | ||
44 | + Width: 0, | ||
45 | + Height: 0, | ||
46 | + }) | ||
47 | + } | ||
48 | + article.Title = req.Title | ||
49 | + article.Version = article.Version + 1 | ||
50 | + article.Images = images | ||
51 | + article.WhoRead = req.WhoRead | ||
52 | + article.WhoReview = req.WhoReview | ||
53 | + article.TargetUser = domain.ArticleTarget(req.TargetUser) | ||
54 | + article.Location = domain.Location{ | ||
55 | + Longitude: req.Location.Longitude, | ||
56 | + Latitude: req.Location.Latitude, | ||
57 | + Descript: req.Location.Descript, | ||
58 | + } | ||
59 | + article.Tags = req.Tags | ||
60 | + //文章内容 | ||
61 | + articleSections := []domain.ArticleSection{} | ||
62 | + lo.ForEach(req.Section, func(item types.ArticleSection, index int) { | ||
63 | + articleSections = append(articleSections, domain.ArticleSection{ | ||
64 | + Id: item.Id, | ||
65 | + CompanyId: article.CompanyId, | ||
66 | + Version: article.Version, | ||
67 | + ArticleId: article.Id, | ||
68 | + Content: item.Content, | ||
69 | + SortBy: index + 1, | ||
70 | + }) | ||
71 | + }) | ||
72 | + //设置内容概要 | ||
73 | + if len(req.Section) > 0 { | ||
74 | + // 截取内容 30个字 | ||
75 | + runeNumber := 0 //字数 | ||
76 | + stringIndex := 0 //字符串长度 | ||
77 | + for i := range req.Section[0].Content { | ||
78 | + if runeNumber > 30 { | ||
79 | + break | ||
80 | + } | ||
81 | + runeNumber += 1 | ||
82 | + stringIndex = i | ||
83 | + } | ||
84 | + article.Summary = req.Section[0].Content[0:stringIndex] | ||
85 | + } | ||
86 | + //获取当前用户信息 | ||
87 | + userMe, err := l.svcCtx.ApiAuthService.MeInfo(l.ctx, authlib.RequestUserMeQuery{Token: accessToken}) | ||
88 | + if err != nil { | ||
89 | + return nil, xerr.NewErrMsgErr("获取当前用户信息失败", err) | ||
90 | + } | ||
91 | + err = transaction.UseTrans(l.ctx, conn.DB(), func(ctx context.Context, c transaction.Conn) error { | ||
92 | + _, err = l.svcCtx.ArticleRepository.Update(l.ctx, c, article) | ||
93 | + if err != nil { | ||
94 | + return xerr.NewErrMsgErr("保存文章失败", err) | ||
95 | + } | ||
96 | + //文章内容 | ||
97 | + updateSectionIds := []int64{} | ||
98 | + for _, item := range articleSections { | ||
99 | + if item.Id > 0 { | ||
100 | + section, err := l.svcCtx.ArticleSectionRepository.FindOne(ctx, c, item.Id) | ||
101 | + if err != nil { | ||
102 | + return xerr.NewErrMsgErr("获取文章段落内容失败", err) | ||
103 | + } | ||
104 | + section.Content = item.Content | ||
105 | + section.ArticleId = item.ArticleId | ||
106 | + section.Version = item.Version | ||
107 | + section.SortBy = item.SortBy | ||
108 | + section.CompanyId = item.CompanyId | ||
109 | + _, err = l.svcCtx.ArticleSectionRepository.Update(ctx, c, section) | ||
110 | + if err != nil { | ||
111 | + return xerr.NewErrMsgErr("保存文章段落内容失败", err) | ||
112 | + } | ||
113 | + } else { | ||
114 | + _, err = l.svcCtx.ArticleSectionRepository.Insert(ctx, c, &item) | ||
115 | + if err != nil { | ||
116 | + return xerr.NewErrMsgErr("保存文章段落内容失败", err) | ||
117 | + } | ||
118 | + } | ||
119 | + updateSectionIds = append(updateSectionIds, item.Id) | ||
120 | + } | ||
121 | + if len(updateSectionIds) > 0 { | ||
122 | + err = l.svcCtx.ArticleSectionRepository.DeleteBy(ctx, c, domain.NewQueryOptions().WithKV("articleId", article.Id).WithKV("notIds", updateSectionIds)) | ||
123 | + if err != nil { | ||
124 | + return xerr.NewErrMsgErr("保存文章内容失败", err) | ||
125 | + } | ||
126 | + } | ||
127 | + //备份数据 | ||
128 | + backup := article.MakeBackup(domain.UserSimple{ | ||
129 | + Id: userToken.UserId, | ||
130 | + Name: userMe.User.NickName, | ||
131 | + Avatar: userMe.User.Avatar, | ||
132 | + CompanyId: userToken.CompanyId, | ||
133 | + Company: userMe.CurrentCompany.Name, | ||
134 | + }, articleSections) | ||
135 | + backup.Action = "编辑" | ||
136 | + _, err = l.svcCtx.ArticleBackupRepository.Insert(ctx, c, backup) | ||
137 | + if err != nil { | ||
138 | + return xerr.NewErrMsgErr("保存文章内容失败", err) | ||
139 | + } | ||
140 | + return nil | ||
141 | + }, true) | ||
142 | + resp = &types.SystemArticleUpdateResponse{ | ||
143 | + Id: article.Id, | ||
144 | + Title: article.Title, | ||
145 | + Images: req.Images, | ||
146 | + CreatedAt: article.CreatedAt, | ||
147 | + CountLove: article.CountLove, | ||
148 | + CountComment: article.CountComment, | ||
149 | + Show: int(article.Show), | ||
150 | + TargetUser: int(article.TargetUser), | ||
151 | + Tags: article.Tags, | ||
152 | + } | ||
153 | + return | ||
154 | +} |
@@ -2,9 +2,12 @@ package comment | @@ -2,9 +2,12 @@ package comment | ||
2 | 2 | ||
3 | import ( | 3 | import ( |
4 | "context" | 4 | "context" |
5 | + "sort" | ||
6 | + "strings" | ||
5 | 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" |
10 | + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain" | ||
8 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr" | 11 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr" |
9 | 12 | ||
10 | "github.com/zeromicro/go-zero/core/logx" | 13 | "github.com/zeromicro/go-zero/core/logx" |
@@ -24,6 +27,7 @@ func NewMiniArticleCommentAtWhoLogic(ctx context.Context, svcCtx *svc.ServiceCon | @@ -24,6 +27,7 @@ func NewMiniArticleCommentAtWhoLogic(ctx context.Context, svcCtx *svc.ServiceCon | ||
24 | } | 27 | } |
25 | } | 28 | } |
26 | 29 | ||
30 | +// MiniArticleCommentAtWho 填写评估时@谁 的可选择者列表 | ||
27 | func (l *MiniArticleCommentAtWhoLogic) MiniArticleCommentAtWho(req *types.MiniArticleCommentAtWhoRequest) (resp *types.MiniArticleCommentAtWhoResponse, err error) { | 31 | func (l *MiniArticleCommentAtWhoLogic) MiniArticleCommentAtWho(req *types.MiniArticleCommentAtWhoRequest) (resp *types.MiniArticleCommentAtWhoResponse, err error) { |
28 | var conn = l.svcCtx.DefaultDBConn() | 32 | var conn = l.svcCtx.DefaultDBConn() |
29 | articleInfo, err := l.svcCtx.ArticleRepository.FindOne(l.ctx, conn, req.ArticleId) | 33 | articleInfo, err := l.svcCtx.ArticleRepository.FindOne(l.ctx, conn, req.ArticleId) |
@@ -35,11 +39,42 @@ func (l *MiniArticleCommentAtWhoLogic) MiniArticleCommentAtWho(req *types.MiniAr | @@ -35,11 +39,42 @@ func (l *MiniArticleCommentAtWhoLogic) MiniArticleCommentAtWho(req *types.MiniAr | ||
35 | return resp, nil | 39 | return resp, nil |
36 | } | 40 | } |
37 | 41 | ||
38 | - // userList := []*domain.User{} | ||
39 | - // if len(articleInfo.WhoRead) == 0 { | 42 | + var userList []*domain.User |
43 | + if len(articleInfo.WhoRead) == 0 { | ||
44 | + //获取所有人 | ||
45 | + queryOption := domain.NewQueryOptions().WithFindOnly().MustWithKV("companyId", articleInfo.CompanyId) | ||
46 | + _, userList, err = l.svcCtx.UserRepository.Find(l.ctx, conn, queryOption) | ||
47 | + if err != nil { | ||
48 | + resp = &types.MiniArticleCommentAtWhoResponse{} | ||
49 | + return resp, nil | ||
50 | + } | ||
51 | + } else { | ||
52 | + queryOption := domain.NewQueryOptions().WithFindOnly().MustWithKV("ids", articleInfo.WhoRead) | ||
53 | + _, userList, err = l.svcCtx.UserRepository.Find(l.ctx, conn, queryOption) | ||
54 | + if err != nil { | ||
55 | + resp = &types.MiniArticleCommentAtWhoResponse{} | ||
56 | + return resp, nil | ||
57 | + } | ||
58 | + } | ||
40 | 59 | ||
41 | - // return | ||
42 | - // } | 60 | + uList := make([]types.CommentAtWho, len(userList)) |
43 | 61 | ||
44 | - return | 62 | + for i := range userList { |
63 | + uList[i] = types.CommentAtWho{ | ||
64 | + Id: userList[i].Id, | ||
65 | + Name: userList[i].Name, | ||
66 | + FirstLetter: "", | ||
67 | + } | ||
68 | + for _, val := range userList[i].PinYinName { | ||
69 | + uList[i].FirstLetter = strings.ToUpper(string(val)) | ||
70 | + break | ||
71 | + } | ||
72 | + } | ||
73 | + sort.Slice(uList, func(i, j int) bool { | ||
74 | + return uList[i].FirstLetter < uList[j].FirstLetter | ||
75 | + }) | ||
76 | + resp = &types.MiniArticleCommentAtWhoResponse{ | ||
77 | + List: uList, | ||
78 | + } | ||
79 | + return resp, nil | ||
45 | } | 80 | } |
@@ -52,12 +52,12 @@ func (l *MiniCreateArticleCommentLogic) MiniCreateArticleComment(req *types.Mini | @@ -52,12 +52,12 @@ func (l *MiniCreateArticleCommentLogic) MiniCreateArticleComment(req *types.Mini | ||
52 | return nil, xerr.NewErrMsg("没有评论权限") | 52 | return nil, xerr.NewErrMsg("没有评论权限") |
53 | } | 53 | } |
54 | //查看评论权限, | 54 | //查看评论权限, |
55 | - // if len(articleInfo.WhoReview) > 0 { | ||
56 | - // ok := lo.IndexOf(articleInfo.WhoReview, req.FromUserId) | ||
57 | - // if ok < 0 { | ||
58 | - // return nil, xerr.NewErrMsg("没有评论权限") | ||
59 | - // } | ||
60 | - // } | 55 | + if len(articleInfo.WhoReview) > 0 { |
56 | + ok := lo.IndexOf(articleInfo.WhoReview, req.FromUserId) | ||
57 | + if ok < 0 { | ||
58 | + return nil, xerr.NewErrMsg("没有评论权限") | ||
59 | + } | ||
60 | + } | ||
61 | // 对段落进行评论 | 61 | // 对段落进行评论 |
62 | var selctionInfo *domain.ArticleSection | 62 | var selctionInfo *domain.ArticleSection |
63 | if req.SectionId > 0 { | 63 | if req.SectionId > 0 { |
@@ -43,7 +43,6 @@ func (l *SystemAddLogic) SystemAdd(req *types.DepartmentAddRequest) (resp *types | @@ -43,7 +43,6 @@ func (l *SystemAddLogic) SystemAdd(req *types.DepartmentAddRequest) (resp *types | ||
43 | } | 43 | } |
44 | 44 | ||
45 | insert := &domain.Department{ | 45 | insert := &domain.Department{ |
46 | - Id: 0, | ||
47 | ParentId: 0, | 46 | ParentId: 0, |
48 | CompanyId: userToken.CompanyId, | 47 | CompanyId: userToken.CompanyId, |
49 | Name: req.Name, | 48 | Name: req.Name, |
@@ -32,14 +32,14 @@ func (l *CreateTagLogic) CreateTag(req *types.TagCreateRequest) (resp *types.Tag | @@ -32,14 +32,14 @@ func (l *CreateTagLogic) CreateTag(req *types.TagCreateRequest) (resp *types.Tag | ||
32 | //检查重复 | 32 | //检查重复 |
33 | cnt, _, err := l.svcCtx.ArticleTagRepository.Find(l.ctx, conn, req.CompanyId, map[string]interface{}{ | 33 | cnt, _, err := l.svcCtx.ArticleTagRepository.Find(l.ctx, conn, req.CompanyId, map[string]interface{}{ |
34 | "name": req.Name, | 34 | "name": req.Name, |
35 | - "group": req.Group, | 35 | + "category": req.Category, |
36 | "countOnly": true, | 36 | "countOnly": true, |
37 | }) | 37 | }) |
38 | if err != nil { | 38 | if err != nil { |
39 | return nil, xerr.NewErrMsgErr("添加标签失败", err) | 39 | return nil, xerr.NewErrMsgErr("添加标签失败", err) |
40 | } | 40 | } |
41 | if cnt > 0 { | 41 | if cnt > 0 { |
42 | - return nil, xerr.NewErrMsg(fmt.Sprintf("已存在标签 分类[%s]名称[%s]", req.Group, req.Name)) | 42 | + return nil, xerr.NewErrMsg(fmt.Sprintf("已存在标签 分类[%s]名称[%s]", req.Category, req.Name)) |
43 | } | 43 | } |
44 | //TODO 获取图片的尺寸大小 | 44 | //TODO 获取图片的尺寸大小 |
45 | 45 | ||
@@ -56,8 +56,9 @@ func (l *CreateTagLogic) CreateTag(req *types.TagCreateRequest) (resp *types.Tag | @@ -56,8 +56,9 @@ func (l *CreateTagLogic) CreateTag(req *types.TagCreateRequest) (resp *types.Tag | ||
56 | Height: 0, | 56 | Height: 0, |
57 | }, | 57 | }, |
58 | Name: req.Name, | 58 | Name: req.Name, |
59 | - Group: req.Group, | 59 | + Category: req.Category, |
60 | Remark: req.Remark, | 60 | Remark: req.Remark, |
61 | + Other: req.Other, | ||
61 | } | 62 | } |
62 | 63 | ||
63 | newTag, err = l.svcCtx.ArticleTagRepository.Insert(l.ctx, conn, newTag) | 64 | newTag, err = l.svcCtx.ArticleTagRepository.Insert(l.ctx, conn, newTag) |
@@ -33,7 +33,7 @@ func (l *EditTagLogic) EditTag(req *types.TagEditRequest) (resp *types.TagEditRe | @@ -33,7 +33,7 @@ func (l *EditTagLogic) EditTag(req *types.TagEditRequest) (resp *types.TagEditRe | ||
33 | queryOptions := domain.NewQueryOptions(). | 33 | queryOptions := domain.NewQueryOptions(). |
34 | WithFindOnly(). | 34 | WithFindOnly(). |
35 | MustWithKV("name", req.Name). | 35 | MustWithKV("name", req.Name). |
36 | - MustWithKV("group", req.Group). | 36 | + MustWithKV("category", req.Category). |
37 | WithOffsetLimit(1, 1) | 37 | WithOffsetLimit(1, 1) |
38 | 38 | ||
39 | _, tagList, err := l.svcCtx.ArticleTagRepository.Find(l.ctx, conn, req.CompanyId, queryOptions) | 39 | _, tagList, err := l.svcCtx.ArticleTagRepository.Find(l.ctx, conn, req.CompanyId, queryOptions) |
@@ -42,7 +42,7 @@ func (l *EditTagLogic) EditTag(req *types.TagEditRequest) (resp *types.TagEditRe | @@ -42,7 +42,7 @@ func (l *EditTagLogic) EditTag(req *types.TagEditRequest) (resp *types.TagEditRe | ||
42 | } | 42 | } |
43 | if len(tagList) > 0 { | 43 | if len(tagList) > 0 { |
44 | if tagList[0].Id != req.Id { | 44 | if tagList[0].Id != req.Id { |
45 | - return nil, xerr.NewErrMsg(fmt.Sprintf("已存在标签 分类[%s]名称[%s]", req.Group, req.Name)) | 45 | + return nil, xerr.NewErrMsg(fmt.Sprintf("已存在标签 分类[%s]名称[%s]", req.Category, req.Name)) |
46 | } | 46 | } |
47 | } | 47 | } |
48 | oldTag, err := l.svcCtx.ArticleTagRepository.FindOne(l.ctx, conn, req.Id) | 48 | oldTag, err := l.svcCtx.ArticleTagRepository.FindOne(l.ctx, conn, req.Id) |
@@ -55,11 +55,11 @@ func (l *EditTagLogic) EditTag(req *types.TagEditRequest) (resp *types.TagEditRe | @@ -55,11 +55,11 @@ func (l *EditTagLogic) EditTag(req *types.TagEditRequest) (resp *types.TagEditRe | ||
55 | 55 | ||
56 | //TODO 获取图片的尺寸大小 | 56 | //TODO 获取图片的尺寸大小 |
57 | 57 | ||
58 | - oldTag.Group = req.Group | 58 | + oldTag.Category = req.Category |
59 | oldTag.Image.Url = req.Image | 59 | oldTag.Image.Url = req.Image |
60 | oldTag.Name = req.Name | 60 | oldTag.Name = req.Name |
61 | oldTag.Remark = req.Remark | 61 | oldTag.Remark = req.Remark |
62 | - | 62 | + oldTag.Other = req.Other |
63 | oldTag, err = l.svcCtx.ArticleTagRepository.Update(l.ctx, conn, oldTag) | 63 | oldTag, err = l.svcCtx.ArticleTagRepository.Update(l.ctx, conn, oldTag) |
64 | if err != nil { | 64 | if err != nil { |
65 | return nil, xerr.NewErrMsgErr("添加标签失败", err) | 65 | return nil, xerr.NewErrMsgErr("添加标签失败", err) |
@@ -38,8 +38,9 @@ func (l *GetTagLogic) GetTag(req *types.TagGetRequest) (resp *types.TagGetRespon | @@ -38,8 +38,9 @@ func (l *GetTagLogic) GetTag(req *types.TagGetRequest) (resp *types.TagGetRespon | ||
38 | Id: oldTag.Id, | 38 | Id: oldTag.Id, |
39 | Image: oldTag.Image.Url, | 39 | Image: oldTag.Image.Url, |
40 | Name: oldTag.Name, | 40 | Name: oldTag.Name, |
41 | - Group: oldTag.Group, | 41 | + Category: oldTag.Category, |
42 | Remark: oldTag.Remark, | 42 | Remark: oldTag.Remark, |
43 | + Other: oldTag.Other, | ||
43 | } | 44 | } |
44 | return | 45 | return |
45 | } | 46 | } |
@@ -27,8 +27,8 @@ func (l *SearchTagLogic) SearchTag(req *types.TagListRequest) (resp *types.TagLi | @@ -27,8 +27,8 @@ func (l *SearchTagLogic) SearchTag(req *types.TagListRequest) (resp *types.TagLi | ||
27 | var conn = l.svcCtx.DefaultDBConn() | 27 | var conn = l.svcCtx.DefaultDBConn() |
28 | queryOptions := domain.NewQueryOptions().WithOffsetLimit(req.Page, req.Size) | 28 | queryOptions := domain.NewQueryOptions().WithOffsetLimit(req.Page, req.Size) |
29 | 29 | ||
30 | - if len(req.Group) > 0 { | ||
31 | - queryOptions = queryOptions.MustWithKV("group", req.Group) | 30 | + if len(req.Category) > 0 { |
31 | + queryOptions = queryOptions.MustWithKV("group", req.Category) | ||
32 | } | 32 | } |
33 | if len(req.TagName) > 0 { | 33 | if len(req.TagName) > 0 { |
34 | queryOptions = queryOptions.MustWithKV("name", req.TagName) | 34 | queryOptions = queryOptions.MustWithKV("name", req.TagName) |
@@ -50,10 +50,10 @@ func (l *SearchTagLogic) SearchTag(req *types.TagListRequest) (resp *types.TagLi | @@ -50,10 +50,10 @@ func (l *SearchTagLogic) SearchTag(req *types.TagListRequest) (resp *types.TagLi | ||
50 | Id: tagList[i].Id, | 50 | Id: tagList[i].Id, |
51 | Image: tagList[i].Image.Url, | 51 | Image: tagList[i].Image.Url, |
52 | Name: tagList[i].Name, | 52 | Name: tagList[i].Name, |
53 | - Group: tagList[i].Group, | 53 | + Category: tagList[i].Category, |
54 | Remark: tagList[i].Remark, | 54 | Remark: tagList[i].Remark, |
55 | CreatedAt: tagList[i].CreatedAt, | 55 | CreatedAt: tagList[i].CreatedAt, |
56 | } | 56 | } |
57 | } | 57 | } |
58 | - return | 58 | + return resp, nil |
59 | } | 59 | } |
@@ -26,6 +26,7 @@ type ServiceContext struct { | @@ -26,6 +26,7 @@ type ServiceContext struct { | ||
26 | ArticleRepository domain.ArticleRepository | 26 | ArticleRepository domain.ArticleRepository |
27 | ArticleSectionRepository domain.ArticleSectionRepository | 27 | ArticleSectionRepository domain.ArticleSectionRepository |
28 | ArticleTagRepository domain.ArticleTagRepository | 28 | ArticleTagRepository domain.ArticleTagRepository |
29 | + ArticleAndTagRepository domain.ArticleAndTagRepository | ||
29 | 30 | ||
30 | CompanyRepository domain.CompanyRepository | 31 | CompanyRepository domain.CompanyRepository |
31 | CommentRepository domain.CommentRepository // 待移除 | 32 | CommentRepository domain.CommentRepository // 待移除 |
@@ -65,6 +66,8 @@ func NewServiceContext(c config.Config) *ServiceContext { | @@ -65,6 +66,8 @@ func NewServiceContext(c config.Config) *ServiceContext { | ||
65 | ArticleDraftRepository: repository.NewArticleDraftRepository(cache.NewCachedRepository(mlCache)), | 66 | ArticleDraftRepository: repository.NewArticleDraftRepository(cache.NewCachedRepository(mlCache)), |
66 | ArticleRepository: repository.NewArticleRepository(cache.NewCachedRepository(mlCache)), | 67 | ArticleRepository: repository.NewArticleRepository(cache.NewCachedRepository(mlCache)), |
67 | ArticleSectionRepository: repository.NewArticleSectionRepository(cache.NewCachedRepository(mlCache)), | 68 | ArticleSectionRepository: repository.NewArticleSectionRepository(cache.NewCachedRepository(mlCache)), |
69 | + ArticleAndTagRepository: repository.NewArticleAndTagRepository(cache.NewCachedRepository(mlCache)), | ||
70 | + | ||
68 | CompanyRepository: repository.NewCompanyRepository(cache.NewCachedRepository(mlCache)), | 71 | CompanyRepository: repository.NewCompanyRepository(cache.NewCachedRepository(mlCache)), |
69 | DepartmentRepository: repository.NewDepartmentRepository(cache.NewCachedRepository(mlCache)), | 72 | DepartmentRepository: repository.NewDepartmentRepository(cache.NewCachedRepository(mlCache)), |
70 | MessageBusinessRepository: repository.NewMessageBusinessRepository(cache.NewCachedRepository(mlCache)), | 73 | MessageBusinessRepository: repository.NewMessageBusinessRepository(cache.NewCachedRepository(mlCache)), |
1 | // Code generated by goctl. DO NOT EDIT. | 1 | // Code generated by goctl. DO NOT EDIT. |
2 | package types | 2 | package types |
3 | 3 | ||
4 | -type MiniArticleCommentAtUserRequest struct { | ||
5 | - ArtitceId int64 `json:"articleId"` | ||
6 | -} | ||
7 | - | ||
8 | -type MiniArticleCommentAtUserResponse struct { | ||
9 | -} | ||
10 | - | ||
11 | type CommentAuthor struct { | 4 | type CommentAuthor struct { |
12 | Id int64 `json:"id"` // 人员id | 5 | Id int64 `json:"id"` // 人员id |
13 | Name string `json:"name"` // 人员的名字 | 6 | Name string `json:"name"` // 人员的名字 |
@@ -29,6 +22,7 @@ type MiniCreateArticleCommentRequest struct { | @@ -29,6 +22,7 @@ type MiniCreateArticleCommentRequest struct { | ||
29 | type CommentAtWho struct { | 22 | type CommentAtWho struct { |
30 | Id int64 `json:"id"` | 23 | Id int64 `json:"id"` |
31 | Name string `json:"name,optional"` | 24 | Name string `json:"name,optional"` |
25 | + FirstLetter string `json:"firstLetter,optional"` | ||
32 | } | 26 | } |
33 | 27 | ||
34 | type MiniCreateArticleCommentResponse struct { | 28 | type MiniCreateArticleCommentResponse struct { |
@@ -208,11 +202,12 @@ type SimpleArticle struct { | @@ -208,11 +202,12 @@ type SimpleArticle struct { | ||
208 | } | 202 | } |
209 | 203 | ||
210 | type TagCreateRequest struct { | 204 | type TagCreateRequest struct { |
211 | - CompanyId int64 `json:"companyId"` | 205 | + CompanyId int64 `json:",optional"` |
212 | Image string `json:"image"` | 206 | Image string `json:"image"` |
213 | Name string `json:"name"` // 标签名称 | 207 | Name string `json:"name"` // 标签名称 |
214 | - Group string `json:"group"` // 标签分类 | 208 | + Category string `json:"category"` // 标签分类 |
215 | Remark string `json:"remark,optional"` // 备注 | 209 | Remark string `json:"remark,optional"` // 备注 |
210 | + Other string `json:"other"` | ||
216 | } | 211 | } |
217 | 212 | ||
218 | type TagCreateResponse struct { | 213 | type TagCreateResponse struct { |
@@ -221,11 +216,12 @@ type TagCreateResponse struct { | @@ -221,11 +216,12 @@ type TagCreateResponse struct { | ||
221 | 216 | ||
222 | type TagEditRequest struct { | 217 | type TagEditRequest struct { |
223 | Id int64 `json:"id"` | 218 | Id int64 `json:"id"` |
224 | - CompanyId int64 `json:"-"` | 219 | + CompanyId int64 `json:",optional"` |
225 | Image string `json:"image"` | 220 | Image string `json:"image"` |
226 | Name string `json:"name"` // 标签名称 | 221 | Name string `json:"name"` // 标签名称 |
227 | - Group string `json:"group"` // 标签分类 | 222 | + Category string `json:"category"` // 标签分类 |
228 | Remark string `json:"remark,optional"` // 备注 | 223 | Remark string `json:"remark,optional"` // 备注 |
224 | + Other string `json:"other"` | ||
229 | } | 225 | } |
230 | 226 | ||
231 | type TagEditResponse struct { | 227 | type TagEditResponse struct { |
@@ -234,23 +230,24 @@ type TagEditResponse struct { | @@ -234,23 +230,24 @@ type TagEditResponse struct { | ||
234 | 230 | ||
235 | type TagGetRequest struct { | 231 | type TagGetRequest struct { |
236 | Id int64 `path:"id"` | 232 | Id int64 `path:"id"` |
237 | - CompanyId int64 `path:"-"` | 233 | + CompanyId int64 `path:",optional"` |
238 | } | 234 | } |
239 | 235 | ||
240 | type TagGetResponse struct { | 236 | type TagGetResponse struct { |
241 | Id int64 `json:"id"` | 237 | Id int64 `json:"id"` |
242 | Image string `json:"image"` | 238 | Image string `json:"image"` |
243 | Name string `json:"name"` // 标签名称 | 239 | Name string `json:"name"` // 标签名称 |
244 | - Group string `json:"group"` // 标签分类 | 240 | + Category string `json:"category"` // 标签分类 |
245 | Remark string `json:"remark"` // 备注 | 241 | Remark string `json:"remark"` // 备注 |
242 | + Other string `json:"other"` | ||
246 | } | 243 | } |
247 | 244 | ||
248 | type TagListRequest struct { | 245 | type TagListRequest struct { |
249 | Page int `json:"page"` | 246 | Page int `json:"page"` |
250 | Size int `json:"size"` | 247 | Size int `json:"size"` |
251 | - CompanyId int64 `json:"-"` | 248 | + CompanyId int64 `json:",optional"` |
252 | TagName string `json:"tagName,optional"` | 249 | TagName string `json:"tagName,optional"` |
253 | - Group string `json:"group,optional"` | 250 | + Category string `json:"category,optional"` |
254 | Remark string `json:"remark,optional"` | 251 | Remark string `json:"remark,optional"` |
255 | } | 252 | } |
256 | 253 | ||
@@ -263,14 +260,14 @@ type TagItem struct { | @@ -263,14 +260,14 @@ type TagItem struct { | ||
263 | Id int64 `json:"id"` | 260 | Id int64 `json:"id"` |
264 | Image string `json:"image"` | 261 | Image string `json:"image"` |
265 | Name string `json:"name"` // 标签名称 | 262 | Name string `json:"name"` // 标签名称 |
266 | - Group string `json:"group"` // 标签分类 | 263 | + Category string `json:"category"` // 标签分类 |
267 | Remark string `json:"remark"` // 备注 | 264 | Remark string `json:"remark"` // 备注 |
268 | CreatedAt int64 `json:"createdAt"` | 265 | CreatedAt int64 `json:"createdAt"` |
269 | } | 266 | } |
270 | 267 | ||
271 | type TagDeleteRequest struct { | 268 | type TagDeleteRequest struct { |
272 | Id int64 `path:"id"` | 269 | Id int64 `path:"id"` |
273 | - CompanyId int64 `path:"-"` | 270 | + CompanyId int64 `path:",optional"` |
274 | } | 271 | } |
275 | 272 | ||
276 | type TagDeleteResponse struct { | 273 | type TagDeleteResponse struct { |
@@ -682,6 +679,7 @@ type WhichUserLikeArticle struct { | @@ -682,6 +679,7 @@ type WhichUserLikeArticle struct { | ||
682 | UserId int64 `json:"userId"` // 人员id | 679 | UserId int64 `json:"userId"` // 人员id |
683 | Name string `json:"name"` // 人员名称 | 680 | Name string `json:"name"` // 人员名称 |
684 | Avatar string `json:"avatar"` // 人员头像 | 681 | Avatar string `json:"avatar"` // 人员头像 |
682 | + Position string `json:"position"` // 职位 | ||
685 | CreatedAt int64 `json:"createdAt"` // 点赞记录的时间 | 683 | CreatedAt int64 `json:"createdAt"` // 点赞记录的时间 |
686 | } | 684 | } |
687 | 685 | ||
@@ -844,8 +842,6 @@ type MiniArticleSetTagResponse struct { | @@ -844,8 +842,6 @@ type MiniArticleSetTagResponse struct { | ||
844 | type MiniAllArticleTagRequest struct { | 842 | type MiniAllArticleTagRequest struct { |
845 | CompanyId int64 `json:",optional"` // 公司id | 843 | CompanyId int64 `json:",optional"` // 公司id |
846 | UserId int64 `json:",optional"` // 公司id | 844 | UserId int64 `json:",optional"` // 公司id |
847 | - ArticleId int64 `json:"articleId"` // 文章id | ||
848 | - TagId int64 `json:"tagId"` // 标签id | ||
849 | } | 845 | } |
850 | 846 | ||
851 | type MiniAllArticleTagResponse struct { | 847 | type MiniAllArticleTagResponse struct { |
@@ -861,6 +857,7 @@ type ArticleTagItem struct { | @@ -861,6 +857,7 @@ type ArticleTagItem struct { | ||
861 | Id int64 `json:"id"` | 857 | Id int64 `json:"id"` |
862 | Group string `json:"group"` | 858 | Group string `json:"group"` |
863 | Name string `json:"name"` | 859 | Name string `json:"name"` |
860 | + Image string `json:"image"` | ||
864 | } | 861 | } |
865 | 862 | ||
866 | type SystemArticleGetRequest struct { | 863 | type SystemArticleGetRequest struct { |
@@ -870,7 +867,7 @@ type SystemArticleGetRequest struct { | @@ -870,7 +867,7 @@ type SystemArticleGetRequest struct { | ||
870 | 867 | ||
871 | type UserShowName struct { | 868 | type UserShowName struct { |
872 | Id int `json:"id"` | 869 | Id int `json:"id"` |
873 | - Name int `json:"name"` | 870 | + Name string `json:"name"` |
874 | } | 871 | } |
875 | 872 | ||
876 | type SystemArticleGetResponse struct { | 873 | type SystemArticleGetResponse struct { |
@@ -890,12 +887,18 @@ type SystemArticleGetResponse struct { | @@ -890,12 +887,18 @@ type SystemArticleGetResponse struct { | ||
890 | CountComment int `json:"countComment"` // 评论数量 | 887 | CountComment int `json:"countComment"` // 评论数量 |
891 | CountRead int `json:"countRead"` // 浏览数量 | 888 | CountRead int `json:"countRead"` // 浏览数量 |
892 | Show int `json:"show"` // 评论的展示状态(0显示、1不显示) | 889 | Show int `json:"show"` // 评论的展示状态(0显示、1不显示) |
890 | + Tags []ArticleTagItem `json:"tags"` //标签 | ||
893 | } | 891 | } |
894 | 892 | ||
895 | type SystemArticleSearchRequest struct { | 893 | type SystemArticleSearchRequest struct { |
896 | - CompanyId int64 `json:",optional"` | ||
897 | - Page int `json:"page"` | ||
898 | - Size int `json:"size"` | 894 | + CompanyId int64 `json:"companyId,optional"` |
895 | + Title string `json:"title,optional"` //标题 | ||
896 | + Author string `json:"author,optional"` //发布人 | ||
897 | + BeginTime int64 `json:"beginTime,optional"` //开始时间 | ||
898 | + EndTime int64 `json:"endTime,optional"` //结束时间 | ||
899 | + Tags []int64 `json:"tags,optional"` //标签 | ||
900 | + Page int `json:"page"` //页码 | ||
901 | + Size int `json:"size"` //每页行数 | ||
899 | } | 902 | } |
900 | 903 | ||
901 | type SystemArticleSearchResponse struct { | 904 | type SystemArticleSearchResponse struct { |
@@ -916,6 +919,80 @@ type SystemArticleSearch struct { | @@ -916,6 +919,80 @@ type SystemArticleSearch struct { | ||
916 | TargetUser int `json:"targetUser"` //分发方式 [0分发给所有人、1分发给指定的人] | 919 | TargetUser int `json:"targetUser"` //分发方式 [0分发给所有人、1分发给指定的人] |
917 | } | 920 | } |
918 | 921 | ||
922 | +type SystemArticleUpdateRequest struct { | ||
923 | + Id int64 `json:"id"` | ||
924 | + CompanyId int64 `json:"companyId,optional"` | ||
925 | + Template int `json:"template"` // 使用哪个模板进行编辑 0、无 1、演绎式 2、归纳式 | ||
926 | + Section []ArticleSection `json:"section"` // 填写的内容 | ||
927 | + Title string `json:"title"` // 标题 | ||
928 | + Images []string `json:"images"` // 图片 | ||
929 | + WhoRead []int64 `json:"whoRead"` // 谁可以看 | ||
930 | + WhoReview []int64 `json:"whoReview"` // 评论人 | ||
931 | + Location Location `json:"location"` // 坐标 | ||
932 | + TargetUser int `json:"targetUser"` //分发方式 [0分发给所有人、1分发给指定的人] | ||
933 | + Tags []int64 `json:"tags"` // 标签 | ||
934 | +} | ||
935 | + | ||
936 | +type SystemArticleUpdateResponse struct { | ||
937 | + Id int64 `json:"id"` //id | ||
938 | + Title string `json:"title"` //标题 | ||
939 | + Author string `json:"author"` //发布人 | ||
940 | + Images []string `json:"images"` //图片 | ||
941 | + CreatedAt int64 `json:"createdAt"` //文章的创建日期 | ||
942 | + CountLove int `json:"countLove"` //点赞数量 | ||
943 | + CountComment int `json:"CountComment"` //评论数量 | ||
944 | + Show int `json:"show"` //是否隐藏 [0显示、1不显示] | ||
945 | + Tags []int64 `json:"tags"` //标签 | ||
946 | + TargetUser int `json:"targetUser"` //分发方式 [0分发给所有人、1分发给指定的人] | ||
947 | +} | ||
948 | + | ||
949 | +type SystemArticleHistoryRequest struct { | ||
950 | + ArticleId int64 `json:"articleId"` //文章ID | ||
951 | + Author string `json:"author,optional"` //发布人 | ||
952 | + BeginTime int64 `json:"beginTime,optional"` //开始时间 | ||
953 | + EndTime int64 `json:"endTime,optional"` //结束时间 | ||
954 | + Page int `json:"page"` //页码 | ||
955 | + Size int `json:"size"` //每页行数 | ||
956 | +} | ||
957 | + | ||
958 | +type SystemArticleHistoryResponse struct { | ||
959 | + Total int `json:"total"` | ||
960 | + List []SystemArticleHistory `json:"list"` | ||
961 | +} | ||
962 | + | ||
963 | +type SystemArticleHistory struct { | ||
964 | + Id int64 `json:"id"` //id | ||
965 | + Author string `json:"author"` //编辑人 | ||
966 | + Action string `json:"action"` //编辑类型 | ||
967 | + UpdatedAt int64 `json:"updatedAt"` //编辑时间 | ||
968 | +} | ||
969 | + | ||
970 | +type SystemArticleGetHistoryRequest struct { | ||
971 | + Id int64 `path:"id"` //id | ||
972 | + CompanyId int64 `path:",optional"` | ||
973 | +} | ||
974 | + | ||
975 | +type SystemArticleGetHistoryResponse struct { | ||
976 | + Id int64 `json:"id"` // id | ||
977 | + ArticleId int64 `json:"articleId"` // 文章ID | ||
978 | + Title string `json:"title"` // 标题 | ||
979 | + AuthorId int64 `json:"authorId"` // 发布人id | ||
980 | + Author ArticleAuthor `json:"author"` // 发布人 | ||
981 | + CreatedAt int64 `json:"createdAt"` // 文章的发布时间 | ||
982 | + Section []ArticleSection `json:"section"` // 文章的文本内容 | ||
983 | + Images []string `json:"images"` // 图片 | ||
984 | + WhoRead []int64 `json:"whoRead"` // 谁可查看 | ||
985 | + WhoReadInfo []UserShowName `json:"whoReadInfo"` // 谁可查看 | ||
986 | + WhoReview []int64 `json:"whoReview"` // 谁可评论 | ||
987 | + WhoReviewInfo []UserShowName `json:"whoReviewInfo"` // 谁可评论 | ||
988 | + Location Location `json:"location"` // 定位坐标 | ||
989 | + CountLove int `json:"countLove"` // 点赞数量 | ||
990 | + CountComment int `json:"countComment"` // 评论数量 | ||
991 | + CountRead int `json:"countRead"` // 浏览数量 | ||
992 | + Show int `json:"show"` // 评论的展示状态(0显示、1不显示) | ||
993 | + TargetUser int `json:"targetUser"` //分发方式 [0分发给所有人、1分发给指定的人] | ||
994 | +} | ||
995 | + | ||
919 | type RoleGetRequest struct { | 996 | type RoleGetRequest struct { |
920 | Id int64 `path:"id"` | 997 | Id int64 `path:"id"` |
921 | } | 998 | } |
@@ -22,6 +22,7 @@ func Migrate(db *gorm.DB) { | @@ -22,6 +22,7 @@ func Migrate(db *gorm.DB) { | ||
22 | &models.MessageSystem{}, | 22 | &models.MessageSystem{}, |
23 | &models.MessageBusiness{}, | 23 | &models.MessageBusiness{}, |
24 | &models.Department{}, | 24 | &models.Department{}, |
25 | + &models.ArticleAndTag{}, | ||
25 | } | 26 | } |
26 | 27 | ||
27 | db.AutoMigrate(modelsList...) | 28 | db.AutoMigrate(modelsList...) |
@@ -10,12 +10,12 @@ import ( | @@ -10,12 +10,12 @@ import ( | ||
10 | 10 | ||
11 | // 保存文章和标签的关系,主要用于分组统计用 | 11 | // 保存文章和标签的关系,主要用于分组统计用 |
12 | type ArticleAndTag struct { | 12 | type ArticleAndTag struct { |
13 | - Id int64 // 唯一标识 | ||
14 | - CompanyId int64 `json:"companyId"` | ||
15 | - CreatedAt int64 `json:"createdAt,omitempty"` | ||
16 | - UpdatedAt int64 `json:"updatedAt,omitempty"` | ||
17 | - ArticleId int64 `json:"articleId"` | ||
18 | - TagId int64 `json:"tagId"` | 13 | + Id int64 `gorm:"primaryKey"` // 唯一标识 |
14 | + CompanyId int64 | ||
15 | + CreatedAt int64 | ||
16 | + UpdatedAt int64 | ||
17 | + ArticleId int64 | ||
18 | + TagId int64 | ||
19 | } | 19 | } |
20 | 20 | ||
21 | func (m *ArticleAndTag) TableName() string { | 21 | func (m *ArticleAndTag) TableName() string { |
@@ -20,9 +20,10 @@ type ArticleTag struct { | @@ -20,9 +20,10 @@ type ArticleTag struct { | ||
20 | Version int | 20 | Version int |
21 | Image domain.Image `gorm:"type:jsonb;serializer:json"` // 图片 | 21 | Image domain.Image `gorm:"type:jsonb;serializer:json"` // 图片 |
22 | Name string // 标签名称 | 22 | Name string // 标签名称 |
23 | - Group string // 标签分类 | ||
24 | Remark string // 备注 | 23 | Remark string // 备注 |
24 | + Category string // 标签分类 | ||
25 | SortBy int64 // 顺序 | 25 | SortBy int64 // 顺序 |
26 | + Other string // 其他 | ||
26 | } | 27 | } |
27 | 28 | ||
28 | func (m *ArticleTag) TableName() string { | 29 | func (m *ArticleTag) TableName() string { |
@@ -2,9 +2,10 @@ package models | @@ -2,9 +2,10 @@ package models | ||
2 | 2 | ||
3 | import ( | 3 | import ( |
4 | "fmt" | 4 | "fmt" |
5 | + "time" | ||
6 | + | ||
5 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain" | 7 | "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain" |
6 | "gorm.io/gorm" | 8 | "gorm.io/gorm" |
7 | - "time" | ||
8 | ) | 9 | ) |
9 | 10 | ||
10 | type UserFollow struct { | 11 | type UserFollow struct { |
@@ -97,6 +97,9 @@ func (repository *ArticleAndTagRepository) Find(ctx context.Context, conn transa | @@ -97,6 +97,9 @@ func (repository *ArticleAndTagRepository) Find(ctx context.Context, conn transa | ||
97 | ) | 97 | ) |
98 | queryFunc := func() (interface{}, error) { | 98 | queryFunc := func() (interface{}, error) { |
99 | tx = tx.Model(&ms).Order("id desc") | 99 | tx = tx.Model(&ms).Order("id desc") |
100 | + if v, ok := queryOptions["articleId"]; ok { | ||
101 | + tx = tx.Where("article_id=?", v) | ||
102 | + } | ||
100 | if total, tx = transaction.PaginationAndCount(ctx, tx, queryOptions, &ms); tx.Error != nil { | 103 | if total, tx = transaction.PaginationAndCount(ctx, tx, queryOptions, &ms); tx.Error != nil { |
101 | return dms, tx.Error | 104 | return dms, tx.Error |
102 | } | 105 | } |
@@ -120,6 +120,18 @@ func (repository *ArticleBackupRepository) Find(ctx context.Context, conn transa | @@ -120,6 +120,18 @@ func (repository *ArticleBackupRepository) Find(ctx context.Context, conn transa | ||
120 | ) | 120 | ) |
121 | queryFunc := func() (interface{}, error) { | 121 | queryFunc := func() (interface{}, error) { |
122 | tx = tx.Model(&ms).Order("id desc") | 122 | tx = tx.Model(&ms).Order("id desc") |
123 | + if v, ok := queryOptions["beginCreatedAt"]; ok { | ||
124 | + tx = tx.Where("created_at >= ?", v) | ||
125 | + } | ||
126 | + if v, ok := queryOptions["endCreatedAt"]; ok { | ||
127 | + tx = tx.Where("created_at < ?", v) | ||
128 | + } | ||
129 | + if v, ok := queryOptions["articleId"]; ok { | ||
130 | + tx = tx.Where("article_id = ?", v) | ||
131 | + } | ||
132 | + if v, ok := queryOptions["operator"]; ok && v.(string) != "" { | ||
133 | + tx = tx.Where(`operator #>> '{"name"}' like ?`, "%"+v.(string)+"%") | ||
134 | + } | ||
123 | if total, tx = transaction.PaginationAndCount(ctx, tx, queryOptions, &ms); tx.Error != nil { | 135 | if total, tx = transaction.PaginationAndCount(ctx, tx, queryOptions, &ms); tx.Error != nil { |
124 | return dms, tx.Error | 136 | return dms, tx.Error |
125 | } | 137 | } |
@@ -121,11 +121,13 @@ func (repository *ArticleRepository) Find(ctx context.Context, conn transaction. | @@ -121,11 +121,13 @@ func (repository *ArticleRepository) Find(ctx context.Context, conn transaction. | ||
121 | queryFunc := func() (interface{}, error) { | 121 | queryFunc := func() (interface{}, error) { |
122 | tx = tx.Model(&ms).Order("id desc").Where("company_id=?", companyId) | 122 | tx = tx.Model(&ms).Order("id desc").Where("company_id=?", companyId) |
123 | if v, ok := queryOptions["ids"]; ok { | 123 | if v, ok := queryOptions["ids"]; ok { |
124 | - tx.Where("id in (?)", v) | 124 | + tx = tx.Where("id in (?)", v) |
125 | } | 125 | } |
126 | - | ||
127 | - if v, ok := queryOptions["authorId"]; ok { | ||
128 | - tx = tx.Where("author_id = ?", v) | 126 | + if v, ok := queryOptions["title"]; ok && v.(string) != "" { |
127 | + tx = tx.Where("title like ?", "%"+v.(string)+"%") | ||
128 | + } | ||
129 | + if v, ok := queryOptions["author"]; ok && v.(string) != "" { | ||
130 | + tx = tx.Where(`author #>> '{"name"}' like ?`, "%"+v.(string)+"%") | ||
129 | } | 131 | } |
130 | if v, ok := queryOptions["beginCreatedAt"]; ok { | 132 | if v, ok := queryOptions["beginCreatedAt"]; ok { |
131 | tx = tx.Where("created_at >= ?", v) | 133 | tx = tx.Where("created_at >= ?", v) |
@@ -275,3 +277,35 @@ func (repository *ArticleRepository) IncreaseCountComment(ctx context.Context, c | @@ -275,3 +277,35 @@ func (repository *ArticleRepository) IncreaseCountComment(ctx context.Context, c | ||
275 | func NewArticleRepository(cache *cache.CachedRepository) domain.ArticleRepository { | 277 | func NewArticleRepository(cache *cache.CachedRepository) domain.ArticleRepository { |
276 | return &ArticleRepository{CachedRepository: cache} | 278 | return &ArticleRepository{CachedRepository: cache} |
277 | } | 279 | } |
280 | + | ||
281 | +// with | ||
282 | +// -- 按查看权限查询文章 | ||
283 | +// t_article as( | ||
284 | +// select article.id | ||
285 | +// from article | ||
286 | +// where article.deleted_at=0 | ||
287 | +// and article.company_id =1598224576532189184 | ||
288 | +// and article."show" =0 | ||
289 | +// and (article.target_user =0 or article.who_read @>'[1]') | ||
290 | +// ), | ||
291 | +// -- 获取有标签的文章 | ||
292 | +// t_article_and_tag as ( | ||
293 | +// select article_and_tag.article_id ,article_and_tag.tag_id | ||
294 | +// from article_and_tag | ||
295 | +// where article_and_tag.company_id =1598224576532189184 | ||
296 | +// ), | ||
297 | +// -- 过滤出可展示的文章id | ||
298 | +// t_article_and_tag_2 as ( | ||
299 | +// select t_article_and_tag.article_id, t_article_and_tag.tag_id | ||
300 | +// from t_article_and_tag | ||
301 | +// join t_article on t_article_and_tag.article_id = t_article.id | ||
302 | +// ), | ||
303 | +// -- 查询人员已查看的文章 | ||
304 | +// t_user_read as( | ||
305 | +// select user_read_article.article_id from user_read_article where user_read_article.user_id =1 | ||
306 | +// ) | ||
307 | +// -- 汇总统计 cnt_1符合条件的文章总数,cnt_2 已浏览的数量 | ||
308 | +// select count(t_article_and_tag_2.article_id) as cnt_1 ,count(t_user_read.article_id) as cnt_2, t_article_and_tag_2.tag_id | ||
309 | +// from t_article_and_tag_2 | ||
310 | +// left join t_user_read on t_article_and_tag_2.article_id=t_user_read.article_id | ||
311 | +// group by t_article_and_tag_2.tag_id |
@@ -90,6 +90,28 @@ func (repository *ArticleSectionRepository) Delete(ctx context.Context, conn tra | @@ -90,6 +90,28 @@ func (repository *ArticleSectionRepository) Delete(ctx context.Context, conn tra | ||
90 | return repository.ModelToDomainModel(m) | 90 | return repository.ModelToDomainModel(m) |
91 | } | 91 | } |
92 | 92 | ||
93 | +func (repository *ArticleSectionRepository) DeleteBy(ctx context.Context, conn transaction.Conn, queryOptions map[string]interface{}) error { | ||
94 | + var ( | ||
95 | + tx = conn.DB() | ||
96 | + m = &models.ArticleSection{} | ||
97 | + ) | ||
98 | + queryFunc := func() (interface{}, error) { | ||
99 | + tx = tx.Where("id = ?", m.Id) | ||
100 | + if v, ok := queryOptions["articleId"]; ok { | ||
101 | + tx = tx.Where("article_id = ?", v) | ||
102 | + } | ||
103 | + if v, ok := queryOptions["notIds"]; ok { | ||
104 | + tx = tx.Where("id not in (?)", v) | ||
105 | + } | ||
106 | + tx.Delete(m) | ||
107 | + return m, tx.Error | ||
108 | + } | ||
109 | + if _, err := repository.Query(queryFunc, m.CacheKeyFunc()); err != nil { | ||
110 | + return err | ||
111 | + } | ||
112 | + return nil | ||
113 | +} | ||
114 | + | ||
93 | func (repository *ArticleSectionRepository) FindOne(ctx context.Context, conn transaction.Conn, id int64) (*domain.ArticleSection, error) { | 115 | func (repository *ArticleSectionRepository) FindOne(ctx context.Context, conn transaction.Conn, id int64) (*domain.ArticleSection, error) { |
94 | var ( | 116 | var ( |
95 | err error | 117 | err error |
@@ -122,13 +122,16 @@ func (repository *ArticleTagRepository) Find(ctx context.Context, conn transacti | @@ -122,13 +122,16 @@ func (repository *ArticleTagRepository) Find(ctx context.Context, conn transacti | ||
122 | queryFunc := func() (interface{}, error) { | 122 | queryFunc := func() (interface{}, error) { |
123 | tx = tx.Model(&ms). | 123 | tx = tx.Model(&ms). |
124 | Where("company_id=?", companyId). | 124 | Where("company_id=?", companyId). |
125 | - Order("id desc") | 125 | + Order("id asc") |
126 | 126 | ||
127 | if v, ok := queryOptions["name"]; ok { | 127 | if v, ok := queryOptions["name"]; ok { |
128 | tx = tx.Where("name like ?", v) | 128 | tx = tx.Where("name like ?", v) |
129 | } | 129 | } |
130 | - if v, ok := queryOptions["group"]; ok { | ||
131 | - tx = tx.Where("group like ?", v) | 130 | + if v, ok := queryOptions["category"]; ok { |
131 | + tx = tx.Where("category like ?", v) | ||
132 | + } | ||
133 | + if v, ok := queryOptions["ids"]; ok { | ||
134 | + tx = tx.Where("id in (?)", v) | ||
132 | } | 135 | } |
133 | 136 | ||
134 | if total, tx = transaction.PaginationAndCount(ctx, tx, queryOptions, &ms); tx.Error != nil { | 137 | if total, tx = transaction.PaginationAndCount(ctx, tx, queryOptions, &ms); tx.Error != nil { |
@@ -86,7 +86,7 @@ func (m *Article) MakeBackup(operator UserSimple, section []ArticleSection) *Art | @@ -86,7 +86,7 @@ func (m *Article) MakeBackup(operator UserSimple, section []ArticleSection) *Art | ||
86 | CreatedAt: 0, | 86 | CreatedAt: 0, |
87 | UpdatedAt: 0, | 87 | UpdatedAt: 0, |
88 | DeletedAt: 0, | 88 | DeletedAt: 0, |
89 | - Version: 0, | 89 | + Version: m.Version, |
90 | Operator: operator, | 90 | Operator: operator, |
91 | ArticleId: m.Id, | 91 | ArticleId: m.Id, |
92 | Title: m.Title, | 92 | Title: m.Title, |
@@ -15,7 +15,7 @@ type ArticleBackup struct { | @@ -15,7 +15,7 @@ type ArticleBackup struct { | ||
15 | DeletedAt int64 `json:"deletedAt,omitempty"` | 15 | DeletedAt int64 `json:"deletedAt,omitempty"` |
16 | Version int `json:"version,omitempty"` | 16 | Version int `json:"version,omitempty"` |
17 | Operator UserSimple `json:"operator"` // 操作人 | 17 | Operator UserSimple `json:"operator"` // 操作人 |
18 | - ArticleId int64 `json:"articleId"` | 18 | + ArticleId int64 `json:"articleId"` // |
19 | Title string `json:"title"` // 标题 | 19 | Title string `json:"title"` // 标题 |
20 | Section []ArticleSection `json:"section"` // 分段内容 | 20 | Section []ArticleSection `json:"section"` // 分段内容 |
21 | Images []Image `json:"images"` // 图片 | 21 | Images []Image `json:"images"` // 图片 |
@@ -25,6 +25,7 @@ type ArticleSectionRepository interface { | @@ -25,6 +25,7 @@ type ArticleSectionRepository interface { | ||
25 | Update(ctx context.Context, conn transaction.Conn, dm *ArticleSection) (*ArticleSection, error) | 25 | Update(ctx context.Context, conn transaction.Conn, dm *ArticleSection) (*ArticleSection, error) |
26 | UpdateWithVersion(ctx context.Context, conn transaction.Conn, dm *ArticleSection) (*ArticleSection, error) | 26 | UpdateWithVersion(ctx context.Context, conn transaction.Conn, dm *ArticleSection) (*ArticleSection, error) |
27 | Delete(ctx context.Context, conn transaction.Conn, dm *ArticleSection) (*ArticleSection, error) | 27 | Delete(ctx context.Context, conn transaction.Conn, dm *ArticleSection) (*ArticleSection, error) |
28 | + DeleteBy(ctx context.Context, conn transaction.Conn, queryOptions map[string]interface{}) error | ||
28 | FindOne(ctx context.Context, conn transaction.Conn, id int64) (*ArticleSection, error) | 29 | FindOne(ctx context.Context, conn transaction.Conn, id int64) (*ArticleSection, error) |
29 | Find(ctx context.Context, conn transaction.Conn, queryOptions map[string]interface{}) (int64, []*ArticleSection, error) | 30 | Find(ctx context.Context, conn transaction.Conn, queryOptions map[string]interface{}) (int64, []*ArticleSection, error) |
30 | IncreaseCountComment(ctx context.Context, conn transaction.Conn, incr int, sectionId int64) error //评论数量变动 | 31 | IncreaseCountComment(ctx context.Context, conn transaction.Conn, incr int, sectionId int64) error //评论数量变动 |
@@ -17,9 +17,10 @@ type ArticleTag struct { | @@ -17,9 +17,10 @@ type ArticleTag struct { | ||
17 | Version int `json:"version,omitempty"` | 17 | Version int `json:"version,omitempty"` |
18 | Image Image `json:"image"` // 图片 | 18 | Image Image `json:"image"` // 图片 |
19 | Name string `json:"name"` // 标签名称 | 19 | Name string `json:"name"` // 标签名称 |
20 | - Group string `json:"group"` // 标签分类 | 20 | + Category string `json:"category"` // 标签分类 [紧急重要]、[机会风险] |
21 | Remark string `json:"remark"` // 备注 | 21 | Remark string `json:"remark"` // 备注 |
22 | SortBy int64 `json:"sortBy"` // 顺序 | 22 | SortBy int64 `json:"sortBy"` // 顺序 |
23 | + Other string `json:"other"` // | ||
23 | } | 24 | } |
24 | type ArticleTagRepository interface { | 25 | type ArticleTagRepository interface { |
25 | Insert(ctx context.Context, conn transaction.Conn, dm *ArticleTag) (*ArticleTag, error) | 26 | Insert(ctx context.Context, conn transaction.Conn, dm *ArticleTag) (*ArticleTag, error) |
@@ -32,8 +32,6 @@ type UserSimple struct { | @@ -32,8 +32,6 @@ type UserSimple struct { | ||
32 | Id int64 `json:"id"` // 人员id | 32 | Id int64 `json:"id"` // 人员id |
33 | Name string `json:"name"` // 人员的名字 | 33 | Name string `json:"name"` // 人员的名字 |
34 | Avatar string `json:"avatar,omitempty"` // 人员头像URL | 34 | Avatar string `json:"avatar,omitempty"` // 人员头像URL |
35 | - // GroupId int64 `json:"groupId"` //分组id | ||
36 | - //Group string `json:"group,omitempty"` // 人员的分组 | ||
37 | Position string `json:"position,omitempty"` // 职位 | 35 | Position string `json:"position,omitempty"` // 职位 |
38 | Company string `json:"company,omitempty"` // 公司 | 36 | Company string `json:"company,omitempty"` // 公司 |
39 | CompanyId int64 `json:"companyId"` | 37 | CompanyId int64 `json:"companyId"` |
-
请 注册 或 登录 后发表评论