作者 郑周

Merge remote-tracking branch 'origin/dev' into dev

正在显示 29 个修改的文件 包含 2726 行增加407 行删除
@@ -4,4 +4,5 @@ import "core/message.api" @@ -4,4 +4,5 @@ import "core/message.api"
4 import "core/article_tag.api" 4 import "core/article_tag.api"
5 import "core/user.api" 5 import "core/user.api"
6 import "core/company.api" 6 import "core/company.api"
7 -import "core/article.api"  
  7 +import "core/article.api"
  8 +import "core/role.api"
@@ -15,15 +15,15 @@ @@ -15,15 +15,15 @@
15 "application/json" 15 "application/json"
16 ], 16 ],
17 "paths": { 17 "paths": {
18 - "v1/mini/article_tag": {  
19 - "delete": {  
20 - "summary": "后台删除文章标签",  
21 - "operationId": "DeleteTag", 18 + "v1/mini/article": {
  19 + "post": {
  20 + "summary": "小程序创建发布内容",
  21 + "operationId": "MiniCreateArticle",
22 "responses": { 22 "responses": {
23 "200": { 23 "200": {
24 "description": "A successful response.", 24 "description": "A successful response.",
25 "schema": { 25 "schema": {
26 - "$ref": "#/definitions/TagDeleteResponse" 26 + "$ref": "#/definitions/MiniArticleCreateResponse"
27 } 27 }
28 } 28 }
29 }, 29 },
@@ -33,23 +33,25 @@ @@ -33,23 +33,25 @@
33 "in": "body", 33 "in": "body",
34 "required": true, 34 "required": true,
35 "schema": { 35 "schema": {
36 - "$ref": "#/definitions/TagDeleteRequest" 36 + "$ref": "#/definitions/MiniArticleCreateRequest"
37 } 37 }
38 } 38 }
39 ], 39 ],
40 "requestBody": {}, 40 "requestBody": {},
41 "tags": [ 41 "tags": [
42 - "tags" 42 + "article"
43 ] 43 ]
44 - }, 44 + }
  45 + },
  46 + "v1/mini/article/search/me": {
45 "post": { 47 "post": {
46 - "summary": "后台创建文章标签",  
47 - "operationId": "CreateTag", 48 + "summary": "小程序获取我发布的文章",
  49 + "operationId": "MiniArticleSearchMe",
48 "responses": { 50 "responses": {
49 "200": { 51 "200": {
50 "description": "A successful response.", 52 "description": "A successful response.",
51 "schema": { 53 "schema": {
52 - "$ref": "#/definitions/TagCreateResponse" 54 + "$ref": "#/definitions/MiniArticleSearchMeResponse"
53 } 55 }
54 } 56 }
55 }, 57 },
@@ -59,23 +61,25 @@ @@ -59,23 +61,25 @@
59 "in": "body", 61 "in": "body",
60 "required": true, 62 "required": true,
61 "schema": { 63 "schema": {
62 - "$ref": "#/definitions/TagCreateRequest" 64 + "$ref": "#/definitions/MiniArticleSearchMeRequest"
63 } 65 }
64 } 66 }
65 ], 67 ],
66 "requestBody": {}, 68 "requestBody": {},
67 "tags": [ 69 "tags": [
68 - "tags" 70 + "article"
69 ] 71 ]
70 - },  
71 - "put": {  
72 - "summary": "后台编辑文章标签",  
73 - "operationId": "EditTag", 72 + }
  73 + },
  74 + "v1/mini/article/user_like/list": {
  75 + "post": {
  76 + "summary": "小程序获取文章的点赞人员列表",
  77 + "operationId": "MiniUserLikeArticle",
74 "responses": { 78 "responses": {
75 "200": { 79 "200": {
76 "description": "A successful response.", 80 "description": "A successful response.",
77 "schema": { 81 "schema": {
78 - "$ref": "#/definitions/TagEditResponse" 82 + "$ref": "#/definitions/MiniUserLikeArticleResponse"
79 } 83 }
80 } 84 }
81 }, 85 },
@@ -85,25 +89,53 @@ @@ -85,25 +89,53 @@
85 "in": "body", 89 "in": "body",
86 "required": true, 90 "required": true,
87 "schema": { 91 "schema": {
88 - "$ref": "#/definitions/TagEditRequest" 92 + "$ref": "#/definitions/MiniUserLikeArticleRequest"
89 } 93 }
90 } 94 }
91 ], 95 ],
92 "requestBody": {}, 96 "requestBody": {},
93 "tags": [ 97 "tags": [
94 - "tags" 98 + "article"
  99 + ]
  100 + }
  101 + },
  102 + "v1/mini/article/user_like/set": {
  103 + "post": {
  104 + "summary": "小程序人员操作点赞文章/评论",
  105 + "operationId": "MiniSetUserLike",
  106 + "responses": {
  107 + "200": {
  108 + "description": "A successful response.",
  109 + "schema": {
  110 + "$ref": "#/definitions/MiniSetUserLikeResponse"
  111 + }
  112 + }
  113 + },
  114 + "parameters": [
  115 + {
  116 + "name": "body",
  117 + "in": "body",
  118 + "required": true,
  119 + "schema": {
  120 + "$ref": "#/definitions/MiniSetUserLikeRequset"
  121 + }
  122 + }
  123 + ],
  124 + "requestBody": {},
  125 + "tags": [
  126 + "article"
95 ] 127 ]
96 } 128 }
97 }, 129 },
98 - "v1/mini/article_tag/{id}": { 130 + "v1/mini/article/{id}": {
99 "get": { 131 "get": {
100 - "summary": "后台获取文章标签",  
101 - "operationId": "GetTag", 132 + "summary": "小程序获取文章内容详情",
  133 + "operationId": "MiniGetArticle",
102 "responses": { 134 "responses": {
103 "200": { 135 "200": {
104 "description": "A successful response.", 136 "description": "A successful response.",
105 "schema": { 137 "schema": {
106 - "$ref": "#/definitions/TagGetResponse" 138 + "$ref": "#/definitions/MiniArticleGetResponse"
107 } 139 }
108 } 140 }
109 }, 141 },
@@ -113,18 +145,11 @@ @@ -113,18 +145,11 @@
113 "in": "path", 145 "in": "path",
114 "required": true, 146 "required": true,
115 "type": "string" 147 "type": "string"
116 - },  
117 - {  
118 - "name": "id",  
119 - "in": "query",  
120 - "required": true,  
121 - "type": "integer",  
122 - "format": "int64"  
123 } 148 }
124 ], 149 ],
125 "requestBody": {}, 150 "requestBody": {},
126 "tags": [ 151 "tags": [
127 - "tags" 152 + "article"
128 ] 153 ]
129 } 154 }
130 }, 155 },
@@ -374,7 +399,7 @@ @@ -374,7 +399,7 @@
374 "200": { 399 "200": {
375 "description": "A successful response.", 400 "description": "A successful response.",
376 "schema": { 401 "schema": {
377 - "$ref": "#/definitions/UserSearchResponse" 402 + "$ref": "#/definitions/MiniUserFollowedSearchResponse"
378 } 403 }
379 } 404 }
380 }, 405 },
@@ -384,7 +409,7 @@ @@ -384,7 +409,7 @@
384 "in": "body", 409 "in": "body",
385 "required": true, 410 "required": true,
386 "schema": { 411 "schema": {
387 - "$ref": "#/definitions/UserSearchRequest" 412 + "$ref": "#/definitions/MiniUserFollowedSearchRequest"
388 } 413 }
389 } 414 }
390 ], 415 ],
@@ -402,7 +427,7 @@ @@ -402,7 +427,7 @@
402 "200": { 427 "200": {
403 "description": "A successful response.", 428 "description": "A successful response.",
404 "schema": { 429 "schema": {
405 - "$ref": "#/definitions/UserSearchResponse" 430 + "$ref": "#/definitions/MiniUserFollowedSearchResponse"
406 } 431 }
407 } 432 }
408 }, 433 },
@@ -412,7 +437,7 @@ @@ -412,7 +437,7 @@
412 "in": "body", 437 "in": "body",
413 "required": true, 438 "required": true,
414 "schema": { 439 "schema": {
415 - "$ref": "#/definitions/UserSearchRequest" 440 + "$ref": "#/definitions/MiniUserFollowedSearchRequest"
416 } 441 }
417 } 442 }
418 ], 443 ],
@@ -478,6 +503,34 @@ @@ -478,6 +503,34 @@
478 ] 503 ]
479 } 504 }
480 }, 505 },
  506 + "v1/mini/user/switch-account": {
  507 + "post": {
  508 + "summary": "切换账号",
  509 + "operationId": "miniUserSwitchAccount",
  510 + "responses": {
  511 + "200": {
  512 + "description": "A successful response.",
  513 + "schema": {
  514 + "$ref": "#/definitions/MiniUserLoginResponse"
  515 + }
  516 + }
  517 + },
  518 + "parameters": [
  519 + {
  520 + "name": "body",
  521 + "in": "body",
  522 + "required": true,
  523 + "schema": {
  524 + "$ref": "#/definitions/MiniUserSwitchAccountRequest"
  525 + }
  526 + }
  527 + ],
  528 + "requestBody": {},
  529 + "tags": [
  530 + "user"
  531 + ]
  532 + }
  533 + },
481 "v1/mini/user/unfollow": { 534 "v1/mini/user/unfollow": {
482 "post": { 535 "post": {
483 "summary": "取消关注", 536 "summary": "取消关注",
@@ -504,6 +557,146 @@ @@ -504,6 +557,146 @@
504 ] 557 ]
505 } 558 }
506 }, 559 },
  560 + "v1/system/article_tag": {
  561 + "post": {
  562 + "summary": "后台创建文章标签",
  563 + "operationId": "CreateTag",
  564 + "responses": {
  565 + "200": {
  566 + "description": "A successful response.",
  567 + "schema": {
  568 + "$ref": "#/definitions/TagCreateResponse"
  569 + }
  570 + }
  571 + },
  572 + "parameters": [
  573 + {
  574 + "name": "body",
  575 + "in": "body",
  576 + "required": true,
  577 + "schema": {
  578 + "$ref": "#/definitions/TagCreateRequest"
  579 + }
  580 + }
  581 + ],
  582 + "requestBody": {},
  583 + "tags": [
  584 + "tags"
  585 + ]
  586 + },
  587 + "put": {
  588 + "summary": "后台编辑文章标签",
  589 + "operationId": "EditTag",
  590 + "responses": {
  591 + "200": {
  592 + "description": "A successful response.",
  593 + "schema": {
  594 + "$ref": "#/definitions/TagEditResponse"
  595 + }
  596 + }
  597 + },
  598 + "parameters": [
  599 + {
  600 + "name": "body",
  601 + "in": "body",
  602 + "required": true,
  603 + "schema": {
  604 + "$ref": "#/definitions/TagEditRequest"
  605 + }
  606 + }
  607 + ],
  608 + "requestBody": {},
  609 + "tags": [
  610 + "tags"
  611 + ]
  612 + }
  613 + },
  614 + "v1/system/article_tag/search": {
  615 + "post": {
  616 + "summary": "后台搜索标签",
  617 + "operationId": "SearchTag",
  618 + "responses": {
  619 + "200": {
  620 + "description": "A successful response.",
  621 + "schema": {
  622 + "$ref": "#/definitions/TagListResponse"
  623 + }
  624 + }
  625 + },
  626 + "parameters": [
  627 + {
  628 + "name": "body",
  629 + "in": "body",
  630 + "required": true,
  631 + "schema": {
  632 + "$ref": "#/definitions/TagListRequest"
  633 + }
  634 + }
  635 + ],
  636 + "requestBody": {},
  637 + "tags": [
  638 + "tags"
  639 + ]
  640 + }
  641 + },
  642 + "v1/system/article_tag/{id}": {
  643 + "get": {
  644 + "summary": "后台获取文章标签",
  645 + "operationId": "GetTag",
  646 + "responses": {
  647 + "200": {
  648 + "description": "A successful response.",
  649 + "schema": {
  650 + "$ref": "#/definitions/TagGetResponse"
  651 + }
  652 + }
  653 + },
  654 + "parameters": [
  655 + {
  656 + "name": "id",
  657 + "in": "path",
  658 + "required": true,
  659 + "type": "string"
  660 + }
  661 + ],
  662 + "requestBody": {},
  663 + "tags": [
  664 + "tags"
  665 + ]
  666 + },
  667 + "delete": {
  668 + "summary": "后台删除文章标签",
  669 + "operationId": "DeleteTag",
  670 + "responses": {
  671 + "200": {
  672 + "description": "A successful response.",
  673 + "schema": {
  674 + "$ref": "#/definitions/TagDeleteResponse"
  675 + }
  676 + }
  677 + },
  678 + "parameters": [
  679 + {
  680 + "name": "id",
  681 + "in": "path",
  682 + "required": true,
  683 + "type": "string"
  684 + },
  685 + {
  686 + "name": "body",
  687 + "in": "body",
  688 + "required": true,
  689 + "schema": {
  690 + "$ref": "#/definitions/TagDeleteRequest"
  691 + }
  692 + }
  693 + ],
  694 + "requestBody": {},
  695 + "tags": [
  696 + "tags"
  697 + ]
  698 + }
  699 + },
507 "v1/system/comment": { 700 "v1/system/comment": {
508 "get": { 701 "get": {
509 "summary": "系统评论", 702 "summary": "系统评论",
@@ -549,64 +742,911 @@ @@ -549,64 +742,911 @@
549 "company" 742 "company"
550 ] 743 ]
551 } 744 }
552 - }  
553 - },  
554 - "definitions": {  
555 - "Comment": {  
556 - "type": "object",  
557 - "title": "Comment"  
558 }, 745 },
559 - "CommentRequest": {  
560 - "type": "object",  
561 - "title": "CommentRequest"  
562 - },  
563 - "CommentResposne": {  
564 - "type": "object",  
565 - "properties": {  
566 - "list": {  
567 - "type": "array",  
568 - "items": {  
569 - "$ref": "#/definitions/Comment" 746 + "v1/system/role": {
  747 + "post": {
  748 + "operationId": "systemSaveRole",
  749 + "responses": {
  750 + "200": {
  751 + "description": "A successful response.",
  752 + "schema": {
  753 + "$ref": "#/definitions/RoleSaveResponse"
  754 + }
570 } 755 }
571 - }  
572 - },  
573 - "title": "CommentResposne",  
574 - "required": [  
575 - "list"  
576 - ]  
577 - },  
578 - "Company": {  
579 - "type": "object",  
580 - "properties": {  
581 - "id": {  
582 - "type": "integer",  
583 - "format": "int64",  
584 - "description": " 唯一标识"  
585 }, 756 },
586 - "name": { 757 + "parameters": [
  758 + {
  759 + "name": "body",
  760 + "in": "body",
  761 + "required": true,
  762 + "schema": {
  763 + "$ref": "#/definitions/RoleSaveRequest"
  764 + }
  765 + }
  766 + ],
  767 + "requestBody": {},
  768 + "tags": [
  769 + "role"
  770 + ]
  771 + }
  772 + },
  773 + "v1/system/role/search": {
  774 + "post": {
  775 + "operationId": "systemSearchRole",
  776 + "responses": {
  777 + "200": {
  778 + "description": "A successful response.",
  779 + "schema": {
  780 + "$ref": "#/definitions/RoleSearchResponse"
  781 + }
  782 + }
  783 + },
  784 + "parameters": [
  785 + {
  786 + "name": "body",
  787 + "in": "body",
  788 + "required": true,
  789 + "schema": {
  790 + "$ref": "#/definitions/RoleSearchRequest"
  791 + }
  792 + }
  793 + ],
  794 + "requestBody": {},
  795 + "tags": [
  796 + "role"
  797 + ]
  798 + }
  799 + },
  800 + "v1/system/role/{id}": {
  801 + "delete": {
  802 + "operationId": "systemDeleteRole",
  803 + "responses": {
  804 + "200": {
  805 + "description": "A successful response.",
  806 + "schema": {
  807 + "$ref": "#/definitions/RoleDeleteResponse"
  808 + }
  809 + }
  810 + },
  811 + "parameters": [
  812 + {
  813 + "name": "id",
  814 + "in": "path",
  815 + "required": true,
  816 + "type": "string"
  817 + },
  818 + {
  819 + "name": "body",
  820 + "in": "body",
  821 + "required": true,
  822 + "schema": {
  823 + "$ref": "#/definitions/RoleDeleteRequest"
  824 + }
  825 + }
  826 + ],
  827 + "requestBody": {},
  828 + "tags": [
  829 + "role"
  830 + ]
  831 + },
  832 + "post": {
  833 + "operationId": "systemGetRole",
  834 + "responses": {
  835 + "200": {
  836 + "description": "A successful response.",
  837 + "schema": {
  838 + "$ref": "#/definitions/RoleGetResponse"
  839 + }
  840 + }
  841 + },
  842 + "parameters": [
  843 + {
  844 + "name": "id",
  845 + "in": "path",
  846 + "required": true,
  847 + "type": "string"
  848 + },
  849 + {
  850 + "name": "body",
  851 + "in": "body",
  852 + "required": true,
  853 + "schema": {
  854 + "$ref": "#/definitions/RoleGetRequest"
  855 + }
  856 + }
  857 + ],
  858 + "requestBody": {},
  859 + "tags": [
  860 + "role"
  861 + ]
  862 + },
  863 + "put": {
  864 + "operationId": "systemUpdateRole",
  865 + "responses": {
  866 + "200": {
  867 + "description": "A successful response.",
  868 + "schema": {
  869 + "$ref": "#/definitions/RoleUpdateResponse"
  870 + }
  871 + }
  872 + },
  873 + "parameters": [
  874 + {
  875 + "name": "id",
  876 + "in": "path",
  877 + "required": true,
  878 + "type": "string"
  879 + },
  880 + {
  881 + "name": "body",
  882 + "in": "body",
  883 + "required": true,
  884 + "schema": {
  885 + "$ref": "#/definitions/RoleUpdateRequest"
  886 + }
  887 + }
  888 + ],
  889 + "requestBody": {},
  890 + "tags": [
  891 + "role"
  892 + ]
  893 + }
  894 + }
  895 + },
  896 + "definitions": {
  897 + "Account": {
  898 + "type": "object",
  899 + "properties": {
  900 + "companyId": {
  901 + "type": "integer",
  902 + "format": "int64",
  903 + "description": " 公司ID"
  904 + },
  905 + "companyName": {
  906 + "type": "string",
  907 + "description": " 公司名称"
  908 + },
  909 + "logo": {
  910 + "type": "string",
  911 + "description": " 公司图标"
  912 + },
  913 + "userId": {
  914 + "type": "integer",
  915 + "format": "int64",
  916 + "description": " 用户ID"
  917 + },
  918 + "name": {
  919 + "type": "string",
  920 + "description": " 名称"
  921 + },
  922 + "position": {
  923 + "type": "string",
  924 + "description": " 职位"
  925 + }
  926 + },
  927 + "title": "Account",
  928 + "required": [
  929 + "companyId",
  930 + "companyName",
  931 + "logo",
  932 + "userId",
  933 + "name",
  934 + "position"
  935 + ]
  936 + },
  937 + "ArticleSearchMe": {
  938 + "type": "object",
  939 + "properties": {
  940 + "id": {
  941 + "type": "integer",
  942 + "format": "int64",
  943 + "description": "id"
  944 + },
  945 + "title": {
  946 + "type": "string",
  947 + "description": "标题"
  948 + },
  949 + "images": {
  950 + "type": "array",
  951 + "items": {
  952 + "type": "string"
  953 + },
  954 + "description": "图片"
  955 + },
  956 + "createdAt": {
  957 + "type": "integer",
  958 + "format": "int64",
  959 + "description": "文章的创建日期"
  960 + },
  961 + "countLove": {
  962 + "type": "integer",
  963 + "format": "int32",
  964 + "description": "点赞数量"
  965 + },
  966 + "CountComment": {
  967 + "type": "integer",
  968 + "format": "int32",
  969 + "description": "评论数量"
  970 + },
  971 + "show": {
  972 + "type": "integer",
  973 + "format": "int32",
  974 + "description": "是否隐藏 [0显示、1不显示]"
  975 + }
  976 + },
  977 + "title": "ArticleSearchMe",
  978 + "required": [
  979 + "id",
  980 + "title",
  981 + "images",
  982 + "createdAt",
  983 + "countLove",
  984 + "CountComment",
  985 + "show"
  986 + ]
  987 + },
  988 + "ArticleSection": {
  989 + "type": "object",
  990 + "properties": {
  991 + "id": {
  992 + "type": "integer",
  993 + "format": "int64",
  994 + "description": "段落id"
  995 + },
  996 + "content": {
  997 + "type": "string",
  998 + "description": " 文本内容"
  999 + },
  1000 + "sortBy": {
  1001 + "type": "integer",
  1002 + "format": "int32",
  1003 + "description": " 排序"
  1004 + },
  1005 + "totalComment": {
  1006 + "type": "integer",
  1007 + "format": "int32",
  1008 + "description": " 评论的数量"
  1009 + }
  1010 + },
  1011 + "title": "ArticleSection",
  1012 + "required": [
  1013 + "id",
  1014 + "content",
  1015 + "sortBy",
  1016 + "totalComment"
  1017 + ]
  1018 + },
  1019 + "Auth": {
  1020 + "type": "object",
  1021 + "properties": {
  1022 + "id": {
  1023 + "type": "integer",
  1024 + "format": "int64",
  1025 + "description": " ID"
  1026 + },
  1027 + "name": {
587 "type": "string", 1028 "type": "string",
588 "description": " 名称" 1029 "description": " 名称"
589 }, 1030 },
590 - "code": {  
591 - "type": "string",  
592 - "description": " 编码(搜索使用,4位字母数字)" 1031 + "code": {
  1032 + "type": "string",
  1033 + "description": " 编码"
  1034 + }
  1035 + },
  1036 + "title": "Auth",
  1037 + "required": [
  1038 + "id",
  1039 + "name",
  1040 + "code"
  1041 + ]
  1042 + },
  1043 + "Author": {
  1044 + "type": "object",
  1045 + "properties": {
  1046 + "id": {
  1047 + "type": "integer",
  1048 + "format": "int64",
  1049 + "description": " 人员id"
  1050 + },
  1051 + "name": {
  1052 + "type": "string",
  1053 + "description": " 人员的名字"
  1054 + },
  1055 + "avatar": {
  1056 + "type": "string",
  1057 + "description": " 人员头像URL"
  1058 + },
  1059 + "group": {
  1060 + "type": "string",
  1061 + "description": " 人员的分组"
  1062 + },
  1063 + "position": {
  1064 + "type": "string",
  1065 + "description": " 职位"
  1066 + },
  1067 + "company": {
  1068 + "type": "string",
  1069 + "description": " 公司"
  1070 + }
  1071 + },
  1072 + "title": "Author",
  1073 + "required": [
  1074 + "id",
  1075 + "name",
  1076 + "avatar",
  1077 + "group",
  1078 + "position",
  1079 + "company"
  1080 + ]
  1081 + },
  1082 + "Comment": {
  1083 + "type": "object",
  1084 + "title": "Comment"
  1085 + },
  1086 + "CommentRequest": {
  1087 + "type": "object",
  1088 + "title": "CommentRequest"
  1089 + },
  1090 + "CommentResposne": {
  1091 + "type": "object",
  1092 + "properties": {
  1093 + "list": {
  1094 + "type": "array",
  1095 + "items": {
  1096 + "$ref": "#/definitions/Comment"
  1097 + }
  1098 + }
  1099 + },
  1100 + "title": "CommentResposne",
  1101 + "required": [
  1102 + "list"
  1103 + ]
  1104 + },
  1105 + "Company": {
  1106 + "type": "object",
  1107 + "properties": {
  1108 + "id": {
  1109 + "type": "integer",
  1110 + "format": "int64",
  1111 + "description": " 唯一标识"
  1112 + },
  1113 + "name": {
  1114 + "type": "string",
  1115 + "description": " 名称"
  1116 + },
  1117 + "code": {
  1118 + "type": "string",
  1119 + "description": " 编码(搜索使用,4位字母数字)"
  1120 + },
  1121 + "logo": {
  1122 + "type": "string",
  1123 + "description": " 公司LOGO"
  1124 + }
  1125 + },
  1126 + "title": "Company",
  1127 + "required": [
  1128 + "id",
  1129 + "name",
  1130 + "code",
  1131 + "logo"
  1132 + ]
  1133 + },
  1134 + "CompanySearchRequest": {
  1135 + "type": "object",
  1136 + "properties": {
  1137 + "page": {
  1138 + "type": "integer",
  1139 + "format": "int32"
  1140 + },
  1141 + "size": {
  1142 + "type": "integer",
  1143 + "format": "int32"
  1144 + },
  1145 + "userId": {
  1146 + "type": "integer",
  1147 + "format": "int64",
  1148 + "description": " 按用户搜索"
  1149 + },
  1150 + "code": {
  1151 + "type": "string",
  1152 + "description": " 按编码搜索"
  1153 + }
  1154 + },
  1155 + "title": "CompanySearchRequest",
  1156 + "required": [
  1157 + "page",
  1158 + "size"
  1159 + ]
  1160 + },
  1161 + "CompanySearchResponse": {
  1162 + "type": "object",
  1163 + "properties": {
  1164 + "list": {
  1165 + "type": "array",
  1166 + "items": {
  1167 + "$ref": "#/definitions/Company"
  1168 + }
  1169 + },
  1170 + "total": {
  1171 + "type": "integer",
  1172 + "format": "int64"
  1173 + }
  1174 + },
  1175 + "title": "CompanySearchResponse",
  1176 + "required": [
  1177 + "list",
  1178 + "total"
  1179 + ]
  1180 + },
  1181 + "Department": {
  1182 + "type": "object",
  1183 + "properties": {
  1184 + "id": {
  1185 + "type": "integer",
  1186 + "format": "int64",
  1187 + "description": " 部门ID"
  1188 + },
  1189 + "companyId": {
  1190 + "type": "integer",
  1191 + "format": "int64",
  1192 + "description": " 公司ID"
  1193 + },
  1194 + "parentId": {
  1195 + "type": "integer",
  1196 + "format": "int64",
  1197 + "description": " 父级ID"
  1198 + },
  1199 + "name": {
  1200 + "type": "string",
  1201 + "description": " 部门名称"
  1202 + }
  1203 + },
  1204 + "title": "Department",
  1205 + "required": [
  1206 + "id",
  1207 + "companyId",
  1208 + "parentId",
  1209 + "name"
  1210 + ]
  1211 + },
  1212 + "FollowRequest": {
  1213 + "type": "object",
  1214 + "properties": {
  1215 + "userId": {
  1216 + "type": "integer",
  1217 + "format": "int64"
  1218 + }
  1219 + },
  1220 + "title": "FollowRequest",
  1221 + "required": [
  1222 + "userId"
  1223 + ]
  1224 + },
  1225 + "Location": {
  1226 + "type": "object",
  1227 + "properties": {
  1228 + "longitude": {
  1229 + "type": "number",
  1230 + "format": "double",
  1231 + "description": "经度"
  1232 + },
  1233 + "latitude": {
  1234 + "type": "number",
  1235 + "format": "double",
  1236 + "description": "纬度"
  1237 + },
  1238 + "descript": {
  1239 + "type": "string",
  1240 + "description": "地点描述"
  1241 + }
  1242 + },
  1243 + "title": "Location"
  1244 + },
  1245 + "MessageBusinessItem": {
  1246 + "type": "object",
  1247 + "properties": {
  1248 + "id": {
  1249 + "type": "integer",
  1250 + "format": "int64"
  1251 + },
  1252 + "type": {
  1253 + "type": "integer",
  1254 + "format": "int32",
  1255 + "description": " 分类 (1回复 2点赞 3被采纳)"
  1256 + },
  1257 + "optType": {
  1258 + "type": "integer",
  1259 + "format": "int32",
  1260 + "description": " 操作类型(1针对文章、1针对评论、2针对圆桌)"
  1261 + },
  1262 + "companyId": {
  1263 + "type": "integer",
  1264 + "format": "int64",
  1265 + "description": " 操作人公司ID"
  1266 + },
  1267 + "userId": {
  1268 + "type": "integer",
  1269 + "format": "int64",
  1270 + "description": " 操作人用户ID"
  1271 + },
  1272 + "recipientId": {
  1273 + "type": "integer",
  1274 + "format": "int64",
  1275 + "description": " 接收者ID"
  1276 + },
  1277 + "articleId": {
  1278 + "type": "integer",
  1279 + "format": "int64",
  1280 + "description": " 文章ID"
  1281 + },
  1282 + "commentId": {
  1283 + "type": "integer",
  1284 + "format": "int64",
  1285 + "description": " 评论ID"
  1286 + },
  1287 + "discussionId": {
  1288 + "type": "integer",
  1289 + "format": "int64",
  1290 + "description": " 圆桌ID"
  1291 + },
  1292 + "discussionOpinionId": {
  1293 + "type": "integer",
  1294 + "format": "int64",
  1295 + "description": " 观点ID"
  1296 + },
  1297 + "content": {
  1298 + "type": "string",
  1299 + "description": " 消息内容"
  1300 + },
  1301 + "createdAt": {
  1302 + "type": "integer",
  1303 + "format": "int64",
  1304 + "description": " 创建时间"
  1305 + },
  1306 + "user": {
  1307 + "$ref": "#/definitions/User",
  1308 + "description": " 操作人"
  1309 + },
  1310 + "article": {
  1311 + "$ref": "#/definitions/SimpleArticle",
  1312 + "description": " 文章"
  1313 + },
  1314 + "comment": {
  1315 + "$ref": "#/definitions/Comment",
  1316 + "description": " 评论(不一定是自己,可能是被人@到)"
  1317 + }
  1318 + },
  1319 + "title": "MessageBusinessItem",
  1320 + "required": [
  1321 + "id",
  1322 + "type",
  1323 + "optType",
  1324 + "companyId",
  1325 + "userId",
  1326 + "recipientId",
  1327 + "articleId",
  1328 + "commentId",
  1329 + "discussionId",
  1330 + "discussionOpinionId",
  1331 + "content",
  1332 + "createdAt",
  1333 + "user",
  1334 + "article",
  1335 + "comment"
  1336 + ]
  1337 + },
  1338 + "MessageBusinessRequest": {
  1339 + "type": "object",
  1340 + "properties": {
  1341 + "type": {
  1342 + "type": "integer",
  1343 + "format": "int32"
  1344 + },
  1345 + "page": {
  1346 + "type": "integer",
  1347 + "format": "int32"
  1348 + },
  1349 + "size": {
  1350 + "type": "integer",
  1351 + "format": "int32"
  1352 + }
  1353 + },
  1354 + "title": "MessageBusinessRequest",
  1355 + "required": [
  1356 + "type",
  1357 + "page",
  1358 + "size"
  1359 + ]
  1360 + },
  1361 + "MessageBusinessResponse": {
  1362 + "type": "object",
  1363 + "properties": {
  1364 + "list": {
  1365 + "type": "array",
  1366 + "items": {
  1367 + "$ref": "#/definitions/MessageBusinessItem"
  1368 + }
  1369 + },
  1370 + "total": {
  1371 + "type": "integer",
  1372 + "format": "int64"
  1373 + }
  1374 + },
  1375 + "title": "MessageBusinessResponse",
  1376 + "required": [
  1377 + "list",
  1378 + "total"
  1379 + ]
  1380 + },
  1381 + "MessageSystemItem": {
  1382 + "type": "object",
  1383 + "properties": {
  1384 + "id": {
  1385 + "type": "integer",
  1386 + "format": "int64",
  1387 + "description": " ID"
  1388 + },
  1389 + "type": {
  1390 + "type": "integer",
  1391 + "format": "int32",
  1392 + "description": " 系统分类"
  1393 + },
  1394 + "title": {
  1395 + "type": "string",
  1396 + "description": " 标题"
  1397 + },
  1398 + "content": {
  1399 + "type": "string",
  1400 + "description": " 内容"
  1401 + },
  1402 + "createdAt": {
  1403 + "type": "integer",
  1404 + "format": "int64",
  1405 + "description": " 创建时间"
  1406 + }
  1407 + },
  1408 + "title": "MessageSystemItem",
  1409 + "required": [
  1410 + "id",
  1411 + "type",
  1412 + "title",
  1413 + "content",
  1414 + "createdAt"
  1415 + ]
  1416 + },
  1417 + "MessageSystemRequest": {
  1418 + "type": "object",
  1419 + "properties": {
  1420 + "page": {
  1421 + "type": "integer",
  1422 + "format": "int32"
  1423 + },
  1424 + "size": {
  1425 + "type": "integer",
  1426 + "format": "int32"
  1427 + }
  1428 + },
  1429 + "title": "MessageSystemRequest",
  1430 + "required": [
  1431 + "page",
  1432 + "size"
  1433 + ]
  1434 + },
  1435 + "MessageSystemResponse": {
  1436 + "type": "object",
  1437 + "properties": {
  1438 + "list": {
  1439 + "type": "array",
  1440 + "items": {
  1441 + "$ref": "#/definitions/MessageSystemItem"
  1442 + }
  1443 + },
  1444 + "total": {
  1445 + "type": "integer",
  1446 + "format": "int64"
  1447 + }
  1448 + },
  1449 + "title": "MessageSystemResponse",
  1450 + "required": [
  1451 + "list",
  1452 + "total"
  1453 + ]
  1454 + },
  1455 + "MiniArticleCreateRequest": {
  1456 + "type": "object",
  1457 + "properties": {
  1458 + "title": {
  1459 + "type": "string",
  1460 + "description": "标题"
  1461 + },
  1462 + "section": {
  1463 + "type": "array",
  1464 + "items": {
  1465 + "type": "string"
  1466 + },
  1467 + "description": "文章的文本内容"
  1468 + },
  1469 + "authorId": {
  1470 + "type": "integer",
  1471 + "format": "int64",
  1472 + "description": "发布人id"
  1473 + },
  1474 + "images": {
  1475 + "type": "array",
  1476 + "items": {
  1477 + "type": "string"
  1478 + },
  1479 + "description": "图片"
  1480 + },
  1481 + "whoRead": {
  1482 + "type": "array",
  1483 + "items": {
  1484 + "type": "integer",
  1485 + "format": "int64"
  1486 + },
  1487 + "description": "谁可查看"
  1488 + },
  1489 + "whoReview": {
  1490 + "type": "array",
  1491 + "items": {
  1492 + "type": "integer",
  1493 + "format": "int64"
  1494 + },
  1495 + "description": "谁可评论"
  1496 + },
  1497 + "location": {
  1498 + "$ref": "#/definitions/Location",
  1499 + "description": "定位坐标"
  1500 + }
  1501 + },
  1502 + "title": "MiniArticleCreateRequest",
  1503 + "required": [
  1504 + "title",
  1505 + "section"
  1506 + ]
  1507 + },
  1508 + "MiniArticleCreateResponse": {
  1509 + "type": "object",
  1510 + "properties": {
  1511 + "id": {
  1512 + "type": "integer",
  1513 + "format": "int64"
  1514 + }
  1515 + },
  1516 + "title": "MiniArticleCreateResponse",
  1517 + "required": [
  1518 + "id"
  1519 + ]
  1520 + },
  1521 + "MiniArticleGetRequest": {
  1522 + "type": "object",
  1523 + "properties": {
  1524 + "id": {
  1525 + "type": "integer",
  1526 + "format": "int64",
  1527 + "description": "id"
  1528 + },
  1529 + "companyId": {
  1530 + "type": "integer",
  1531 + "format": "int64"
  1532 + }
  1533 + },
  1534 + "title": "MiniArticleGetRequest",
  1535 + "required": [
  1536 + "id",
  1537 + "-"
  1538 + ]
  1539 + },
  1540 + "MiniArticleGetResponse": {
  1541 + "type": "object",
  1542 + "properties": {
  1543 + "id": {
  1544 + "type": "integer",
  1545 + "format": "int64",
  1546 + "description": "id"
593 }, 1547 },
594 - "logo": { 1548 + "title": {
595 "type": "string", 1549 "type": "string",
596 - "description": " 公司LOGO" 1550 + "description": "标题"
  1551 + },
  1552 + "authorId": {
  1553 + "type": "integer",
  1554 + "format": "int64",
  1555 + "description": "发布人id"
  1556 + },
  1557 + "author": {
  1558 + "$ref": "#/definitions/Author",
  1559 + "description": "发布人"
  1560 + },
  1561 + "createdAt": {
  1562 + "type": "integer",
  1563 + "format": "int64",
  1564 + "description": "文章的发布时间"
  1565 + },
  1566 + "section": {
  1567 + "type": "array",
  1568 + "items": {
  1569 + "$ref": "#/definitions/ArticleSection"
  1570 + },
  1571 + "description": "文章的文本内容"
  1572 + },
  1573 + "images": {
  1574 + "type": "array",
  1575 + "items": {
  1576 + "type": "string"
  1577 + },
  1578 + "description": "图片"
  1579 + },
  1580 + "whoRead": {
  1581 + "type": "array",
  1582 + "items": {
  1583 + "type": "integer",
  1584 + "format": "int64"
  1585 + },
  1586 + "description": "谁可查看"
  1587 + },
  1588 + "whoReview": {
  1589 + "type": "array",
  1590 + "items": {
  1591 + "type": "integer",
  1592 + "format": "int64"
  1593 + },
  1594 + "description": "谁可评论"
  1595 + },
  1596 + "location": {
  1597 + "$ref": "#/definitions/Location",
  1598 + "description": "定位坐标"
  1599 + },
  1600 + "countLove": {
  1601 + "type": "integer",
  1602 + "format": "int32",
  1603 + "description": " 点赞数量"
  1604 + },
  1605 + "countComment": {
  1606 + "type": "integer",
  1607 + "format": "int32",
  1608 + "description": " 评论数量"
  1609 + },
  1610 + "countRead": {
  1611 + "type": "integer",
  1612 + "format": "int32",
  1613 + "description": " 浏览数量"
  1614 + },
  1615 + "show": {
  1616 + "type": "integer",
  1617 + "format": "int32",
  1618 + "description": " 评论的展示状态(0显示、1不显示)"
597 } 1619 }
598 }, 1620 },
599 - "title": "Company", 1621 + "title": "MiniArticleGetResponse",
600 "required": [ 1622 "required": [
601 "id", 1623 "id",
602 - "name",  
603 - "code",  
604 - "logo" 1624 + "title",
  1625 + "authorId",
  1626 + "author",
  1627 + "createdAt",
  1628 + "section",
  1629 + "images",
  1630 + "whoRead",
  1631 + "whoReview",
  1632 + "location",
  1633 + "countLove",
  1634 + "countComment",
  1635 + "countRead",
  1636 + "show"
605 ] 1637 ]
606 }, 1638 },
607 - "CompanySearchRequest": { 1639 + "MiniArticleSearchMeRequest": {
608 "type": "object", 1640 "type": "object",
609 "properties": { 1641 "properties": {
  1642 + "authorId": {
  1643 + "type": "integer",
  1644 + "format": "int64"
  1645 + },
  1646 + "companyId": {
  1647 + "type": "integer",
  1648 + "format": "int64"
  1649 + },
610 "page": { 1650 "page": {
611 "type": "integer", 1651 "type": "integer",
612 "format": "int32" 1652 "format": "int32"
@@ -614,462 +1654,571 @@ @@ -614,462 +1654,571 @@
614 "size": { 1654 "size": {
615 "type": "integer", 1655 "type": "integer",
616 "format": "int32" 1656 "format": "int32"
617 - },  
618 - "userId": {  
619 - "type": "integer",  
620 - "format": "int64",  
621 - "description": " 按用户搜索"  
622 - },  
623 - "code": {  
624 - "type": "string",  
625 - "description": " 按编码搜索"  
626 } 1657 }
627 }, 1658 },
628 - "title": "CompanySearchRequest", 1659 + "title": "MiniArticleSearchMeRequest",
629 "required": [ 1660 "required": [
  1661 + "-",
630 "page", 1662 "page",
631 "size" 1663 "size"
632 ] 1664 ]
633 }, 1665 },
634 - "CompanySearchResponse": { 1666 + "MiniArticleSearchMeResponse": {
635 "type": "object", 1667 "type": "object",
636 "properties": { 1668 "properties": {
  1669 + "total": {
  1670 + "type": "integer",
  1671 + "format": "int32"
  1672 + },
637 "list": { 1673 "list": {
638 "type": "array", 1674 "type": "array",
639 "items": { 1675 "items": {
640 - "$ref": "#/definitions/Company" 1676 + "$ref": "#/definitions/ArticleSearchMe"
641 } 1677 }
642 - },  
643 - "total": {  
644 - "type": "integer",  
645 - "format": "int64"  
646 } 1678 }
647 }, 1679 },
648 - "title": "CompanySearchResponse", 1680 + "title": "MiniArticleSearchMeResponse",
649 "required": [ 1681 "required": [
650 - "list",  
651 - "total" 1682 + "total",
  1683 + "list"
652 ] 1684 ]
653 }, 1685 },
654 - "Department": { 1686 + "MiniSetUserLikeRequset": {
655 "type": "object", 1687 "type": "object",
656 "properties": { 1688 "properties": {
657 - "id": { 1689 + "articleId": {
658 "type": "integer", 1690 "type": "integer",
659 "format": "int64", 1691 "format": "int64",
660 - "description": " 部门ID" 1692 + "description": "文章id"
661 }, 1693 },
662 - "companyId": { 1694 + "commentId": {
663 "type": "integer", 1695 "type": "integer",
664 "format": "int64", 1696 "format": "int64",
665 - "description": " 公司ID" 1697 + "description": "评论id"
666 }, 1698 },
667 - "parentId": { 1699 + "userId": {
668 "type": "integer", 1700 "type": "integer",
669 "format": "int64", 1701 "format": "int64",
670 - "description": " 父级ID" 1702 + "description": "操作人"
671 }, 1703 },
672 - "name": {  
673 - "type": "string",  
674 - "description": " 部门名称" 1704 + "flag": {
  1705 + "type": "integer",
  1706 + "format": "int32",
  1707 + "description": "点赞标志 1、点赞 2 、取消点赞"
675 } 1708 }
676 }, 1709 },
677 - "title": "Department", 1710 + "title": "MiniSetUserLikeRequset",
678 "required": [ 1711 "required": [
679 - "id",  
680 - "companyId",  
681 - "parentId",  
682 - "name" 1712 + "articleId",
  1713 + "commentId",
  1714 + "-",
  1715 + "flag"
683 ] 1716 ]
684 }, 1717 },
685 - "FollowRequest": { 1718 + "MiniSetUserLikeResponse": {
686 "type": "object", 1719 "type": "object",
687 "properties": { 1720 "properties": {
688 - "userId": { 1721 + "articleId": {
689 "type": "integer", 1722 "type": "integer",
690 - "format": "int64" 1723 + "format": "int64",
  1724 + "description": "文章id"
  1725 + },
  1726 + "commentId": {
  1727 + "type": "integer",
  1728 + "format": "int64",
  1729 + "description": "评论id"
  1730 + },
  1731 + "count": {
  1732 + "type": "integer",
  1733 + "format": "int32",
  1734 + "description": "现有的点赞数量"
691 } 1735 }
692 }, 1736 },
693 - "title": "FollowRequest", 1737 + "title": "MiniSetUserLikeResponse",
694 "required": [ 1738 "required": [
695 - "userId" 1739 + "articleId",
  1740 + "commentId",
  1741 + "count"
696 ] 1742 ]
697 }, 1743 },
698 - "MessageBusinessItem": { 1744 + "MiniUserApplyJoinCompanyRequest": {
699 "type": "object", 1745 "type": "object",
700 "properties": { 1746 "properties": {
701 - "id": {  
702 - "type": "integer",  
703 - "format": "int64"  
704 - },  
705 - "type": {  
706 - "type": "integer",  
707 - "format": "int32",  
708 - "description": " 分类 (1回复 2点赞 3被采纳)"  
709 - },  
710 - "optType": {  
711 - "type": "integer",  
712 - "format": "int32",  
713 - "description": " 操作类型(1针对文章、1针对评论、2针对圆桌)" 1747 + "phone": {
  1748 + "type": "string"
714 }, 1749 },
715 - "companyId": { 1750 + "code": {
  1751 + "type": "string"
  1752 + }
  1753 + },
  1754 + "title": "MiniUserApplyJoinCompanyRequest",
  1755 + "required": [
  1756 + "phone",
  1757 + "code"
  1758 + ]
  1759 + },
  1760 + "MiniUserApplyJoinCompanyResponse": {
  1761 + "type": "object",
  1762 + "title": "MiniUserApplyJoinCompanyResponse"
  1763 + },
  1764 + "MiniUserAuditRequest": {
  1765 + "type": "object",
  1766 + "properties": {
  1767 + "userId": {
716 "type": "integer", 1768 "type": "integer",
717 "format": "int64", 1769 "format": "int64",
718 - "description": " 操作人公司ID" 1770 + "description": " 用户ID"
719 }, 1771 },
720 - "userId": { 1772 + "status": {
721 "type": "integer", 1773 "type": "integer",
722 - "format": "int64",  
723 - "description": " 操作人用户ID" 1774 + "format": "int32",
  1775 + "description": " 审核状态 1:审核通过 2:拒绝"
  1776 + }
  1777 + },
  1778 + "title": "MiniUserAuditRequest",
  1779 + "required": [
  1780 + "userId",
  1781 + "status"
  1782 + ]
  1783 + },
  1784 + "MiniUserDepartmentUsersRequest": {
  1785 + "type": "object",
  1786 + "title": "MiniUserDepartmentUsersRequest"
  1787 + },
  1788 + "MiniUserDepartmentUsersResponse": {
  1789 + "type": "object",
  1790 + "properties": {
  1791 + "departments": {
  1792 + "type": "array",
  1793 + "items": {
  1794 + "$ref": "#/definitions/Department"
  1795 + }
724 }, 1796 },
725 - "recipientId": { 1797 + "users": {
  1798 + "type": "array",
  1799 + "items": {
  1800 + "$ref": "#/definitions/UserItem"
  1801 + }
  1802 + }
  1803 + },
  1804 + "title": "MiniUserDepartmentUsersResponse",
  1805 + "required": [
  1806 + "departments",
  1807 + "users"
  1808 + ]
  1809 + },
  1810 + "MiniUserFollowedSearchRequest": {
  1811 + "type": "object",
  1812 + "properties": {
  1813 + "page": {
726 "type": "integer", 1814 "type": "integer",
727 - "format": "int64",  
728 - "description": " 接收者ID" 1815 + "format": "int32"
729 }, 1816 },
730 - "articleId": { 1817 + "size": {
731 "type": "integer", 1818 "type": "integer",
732 - "format": "int64",  
733 - "description": " 文章ID" 1819 + "format": "int32"
  1820 + }
  1821 + },
  1822 + "title": "MiniUserFollowedSearchRequest"
  1823 + },
  1824 + "MiniUserFollowedSearchResponse": {
  1825 + "type": "object",
  1826 + "properties": {
  1827 + "users": {
  1828 + "type": "array",
  1829 + "items": {
  1830 + "$ref": "#/definitions/UserFollowItem"
  1831 + }
734 }, 1832 },
735 - "commentId": { 1833 + "total": {
736 "type": "integer", 1834 "type": "integer",
737 - "format": "int64",  
738 - "description": " 评论ID" 1835 + "format": "int64"
  1836 + }
  1837 + },
  1838 + "title": "MiniUserFollowedSearchResponse",
  1839 + "required": [
  1840 + "users",
  1841 + "total"
  1842 + ]
  1843 + },
  1844 + "MiniUserInfoRequest": {
  1845 + "type": "object",
  1846 + "title": "MiniUserInfoRequest"
  1847 + },
  1848 + "MiniUserInfoResponse": {
  1849 + "type": "object",
  1850 + "properties": {
  1851 + "user": {
  1852 + "$ref": "#/definitions/UserItem",
  1853 + "description": " 用户信息"
739 }, 1854 },
740 - "discussionId": { 1855 + "totalArticle": {
741 "type": "integer", 1856 "type": "integer",
742 "format": "int64", 1857 "format": "int64",
743 - "description": " 圆桌ID" 1858 + "description": " 累计信息发布"
744 }, 1859 },
745 - "discussionOpinionId": { 1860 + "totalLoved": {
746 "type": "integer", 1861 "type": "integer",
747 "format": "int64", 1862 "format": "int64",
748 - "description": " 观点ID"  
749 - },  
750 - "content": {  
751 - "type": "string",  
752 - "description": " 消息内容" 1863 + "description": " 累计收到的赞"
753 }, 1864 },
754 - "createdAt": { 1865 + "totalAccepted": {
755 "type": "integer", 1866 "type": "integer",
756 "format": "int64", 1867 "format": "int64",
757 - "description": " 创建时间"  
758 - },  
759 - "user": {  
760 - "$ref": "#/definitions/User",  
761 - "description": " 操作人"  
762 - },  
763 - "article": {  
764 - "$ref": "#/definitions/SimpleArticle",  
765 - "description": " 文章" 1868 + "description": " 累计被采纳"
766 }, 1869 },
767 - "comment": {  
768 - "$ref": "#/definitions/Comment",  
769 - "description": " 评论(不一定是自己,可能是被人@到)" 1870 + "accounts": {
  1871 + "type": "array",
  1872 + "items": {
  1873 + "$ref": "#/definitions/Account"
  1874 + },
  1875 + "description": " 公司账号"
770 } 1876 }
771 }, 1877 },
772 - "title": "MessageBusinessItem", 1878 + "title": "MiniUserInfoResponse",
773 "required": [ 1879 "required": [
774 - "id",  
775 - "type",  
776 - "optType",  
777 - "companyId",  
778 - "userId",  
779 - "recipientId",  
780 - "articleId",  
781 - "commentId",  
782 - "discussionId",  
783 - "discussionOpinionId",  
784 - "content",  
785 - "createdAt",  
786 "user", 1880 "user",
787 - "article",  
788 - "comment" 1881 + "totalArticle",
  1882 + "totalLoved",
  1883 + "totalAccepted",
  1884 + "accounts"
789 ] 1885 ]
790 }, 1886 },
791 - "MessageBusinessRequest": { 1887 + "MiniUserLikeArticleRequest": {
792 "type": "object", 1888 "type": "object",
793 "properties": { 1889 "properties": {
794 - "type": { 1890 + "articleId": {
795 "type": "integer", 1891 "type": "integer",
796 - "format": "int32" 1892 + "format": "int64",
  1893 + "description": " 文章id"
  1894 + },
  1895 + "companyId": {
  1896 + "type": "integer",
  1897 + "format": "int64",
  1898 + "description": "公司id"
797 }, 1899 },
798 "page": { 1900 "page": {
799 "type": "integer", 1901 "type": "integer",
800 - "format": "int32" 1902 + "format": "int32",
  1903 + "description": "分页,第几页"
801 }, 1904 },
802 "size": { 1905 "size": {
803 "type": "integer", 1906 "type": "integer",
804 - "format": "int32" 1907 + "format": "int32",
  1908 + "description": "分页,每页几条"
805 } 1909 }
806 }, 1910 },
807 - "title": "MessageBusinessRequest", 1911 + "title": "MiniUserLikeArticleRequest",
808 "required": [ 1912 "required": [
809 - "type", 1913 + "articleId",
  1914 + "-",
810 "page", 1915 "page",
811 "size" 1916 "size"
812 ] 1917 ]
813 }, 1918 },
814 - "MessageBusinessResponse": { 1919 + "MiniUserLikeArticleResponse": {
815 "type": "object", 1920 "type": "object",
816 "properties": { 1921 "properties": {
  1922 + "total": {
  1923 + "type": "integer",
  1924 + "format": "int64",
  1925 + "description": "总数"
  1926 + },
817 "list": { 1927 "list": {
818 "type": "array", 1928 "type": "array",
819 "items": { 1929 "items": {
820 - "$ref": "#/definitions/MessageBusinessItem"  
821 - }  
822 - },  
823 - "total": {  
824 - "type": "integer",  
825 - "format": "int64" 1930 + "$ref": "#/definitions/WhichUserLikeArticle"
  1931 + },
  1932 + "description": "列表"
826 } 1933 }
827 }, 1934 },
828 - "title": "MessageBusinessResponse", 1935 + "title": "MiniUserLikeArticleResponse",
829 "required": [ 1936 "required": [
830 - "list",  
831 - "total" 1937 + "total",
  1938 + "list"
832 ] 1939 ]
833 }, 1940 },
834 - "MessageSystemItem": { 1941 + "MiniUserLoginRequest": {
835 "type": "object", 1942 "type": "object",
836 "properties": { 1943 "properties": {
837 - "id": {  
838 - "type": "integer",  
839 - "format": "int64",  
840 - "description": " ID" 1944 + "loginType": {
  1945 + "type": "string",
  1946 + "description": " 登录类型 wechat-login whchat-phone-login phone-password-login phone-smscode-login"
841 }, 1947 },
842 - "type": {  
843 - "type": "integer",  
844 - "format": "int32",  
845 - "description": " 系统分类" 1948 + "wechatAuthcode": {
  1949 + "type": "string",
  1950 + "description": " 微信登录 授权码"
846 }, 1951 },
847 - "title": { 1952 + "wechatEncryptedData": {
848 "type": "string", 1953 "type": "string",
849 - "description": " 标题" 1954 + "description": " 微信登录 加密数据"
850 }, 1955 },
851 - "content": { 1956 + "wechatIV": {
852 "type": "string", 1957 "type": "string",
853 - "description": " 内容" 1958 + "description": " 微信登录 加密算法初始向量"
854 }, 1959 },
855 - "createdAt": { 1960 + "phone": {
  1961 + "type": "string",
  1962 + "description": " 手机号"
  1963 + },
  1964 + "password": {
  1965 + "type": "string",
  1966 + "description": " 密码"
  1967 + },
  1968 + "smsCode": {
  1969 + "type": "string",
  1970 + "description": " 短信验证码"
  1971 + }
  1972 + },
  1973 + "title": "MiniUserLoginRequest",
  1974 + "required": [
  1975 + "loginType"
  1976 + ]
  1977 + },
  1978 + "MiniUserLoginResponse": {
  1979 + "type": "object",
  1980 + "properties": {
  1981 + "token": {
  1982 + "type": "string",
  1983 + "description": " x-token"
  1984 + },
  1985 + "phone": {
  1986 + "type": "string",
  1987 + "description": " 手机号"
  1988 + },
  1989 + "message": {
  1990 + "type": "string",
  1991 + "description": " 失败消息(审核中,注册成功等待审核)"
  1992 + },
  1993 + "success": {
  1994 + "type": "boolean",
  1995 + "format": "boolean",
  1996 + "description": " 成功标识"
  1997 + }
  1998 + },
  1999 + "title": "MiniUserLoginResponse",
  2000 + "required": [
  2001 + "token",
  2002 + "phone",
  2003 + "message",
  2004 + "success"
  2005 + ]
  2006 + },
  2007 + "MiniUserSwitchAccountRequest": {
  2008 + "type": "object",
  2009 + "properties": {
  2010 + "companyId": {
856 "type": "integer", 2011 "type": "integer",
857 - "format": "int64",  
858 - "description": " 创建时间" 2012 + "format": "int64"
859 } 2013 }
860 }, 2014 },
861 - "title": "MessageSystemItem", 2015 + "title": "MiniUserSwitchAccountRequest",
862 "required": [ 2016 "required": [
863 - "id",  
864 - "type",  
865 - "title",  
866 - "content",  
867 - "createdAt" 2017 + "companyId"
868 ] 2018 ]
869 }, 2019 },
870 - "MessageSystemRequest": { 2020 + "RoleDeleteRequest": {
871 "type": "object", 2021 "type": "object",
872 "properties": { 2022 "properties": {
873 - "page": { 2023 + "id": {
874 "type": "integer", 2024 "type": "integer",
875 - "format": "int32"  
876 - },  
877 - "size": { 2025 + "format": "int64"
  2026 + }
  2027 + },
  2028 + "title": "RoleDeleteRequest",
  2029 + "required": [
  2030 + "id"
  2031 + ]
  2032 + },
  2033 + "RoleDeleteResponse": {
  2034 + "type": "object",
  2035 + "title": "RoleDeleteResponse"
  2036 + },
  2037 + "RoleGetRequest": {
  2038 + "type": "object",
  2039 + "properties": {
  2040 + "id": {
878 "type": "integer", 2041 "type": "integer",
879 - "format": "int32" 2042 + "format": "int64"
880 } 2043 }
881 }, 2044 },
882 - "title": "MessageSystemRequest", 2045 + "title": "RoleGetRequest",
883 "required": [ 2046 "required": [
884 - "page",  
885 - "size" 2047 + "id"
886 ] 2048 ]
887 }, 2049 },
888 - "MessageSystemResponse": { 2050 + "RoleGetResponse": {
889 "type": "object", 2051 "type": "object",
890 "properties": { 2052 "properties": {
891 - "list": { 2053 + "role": {
  2054 + "$ref": "#/definitions/RoleItem"
  2055 + },
  2056 + "authList": {
892 "type": "array", 2057 "type": "array",
893 "items": { 2058 "items": {
894 - "$ref": "#/definitions/MessageSystemItem" 2059 + "$ref": "#/definitions/Auth"
895 } 2060 }
896 - },  
897 - "total": {  
898 - "type": "integer",  
899 - "format": "int64"  
900 } 2061 }
901 }, 2062 },
902 - "title": "MessageSystemResponse", 2063 + "title": "RoleGetResponse",
903 "required": [ 2064 "required": [
904 - "list",  
905 - "total" 2065 + "role",
  2066 + "authList"
906 ] 2067 ]
907 }, 2068 },
908 - "MiniUserApplyJoinCompanyRequest": { 2069 + "RoleItem": {
909 "type": "object", 2070 "type": "object",
910 "properties": { 2071 "properties": {
911 - "phone": {  
912 - "type": "string" 2072 + "id": {
  2073 + "type": "integer",
  2074 + "format": "int64",
  2075 + "description": " 角色ID"
913 }, 2076 },
914 - "code": {  
915 - "type": "string" 2077 + "companyId": {
  2078 + "type": "integer",
  2079 + "format": "int64",
  2080 + "description": " 公司ID"
  2081 + },
  2082 + "name": {
  2083 + "type": "string",
  2084 + "description": " 角色名称"
  2085 + },
  2086 + "authIds": {
  2087 + "type": "array",
  2088 + "items": {
  2089 + "type": "integer",
  2090 + "format": "int64"
  2091 + },
  2092 + "description": " 角色权限列表"
  2093 + },
  2094 + "authsDesc": {
  2095 + "type": "string",
  2096 + "description": " 权限列表描述"
  2097 + },
  2098 + "usersDesc": {
  2099 + "type": "string",
  2100 + "description": " 用户列表描述"
  2101 + },
  2102 + "remark": {
  2103 + "type": "string",
  2104 + "description": " 备注"
  2105 + },
  2106 + "users": {
  2107 + "type": "array",
  2108 + "items": {
  2109 + "$ref": "#/definitions/RoleUser"
  2110 + },
  2111 + "description": " 绑定的用户"
  2112 + },
  2113 + "updatedAt": {
  2114 + "type": "integer",
  2115 + "format": "int64",
  2116 + "description": " 更新时间"
916 } 2117 }
917 }, 2118 },
918 - "title": "MiniUserApplyJoinCompanyRequest", 2119 + "title": "RoleItem",
919 "required": [ 2120 "required": [
920 - "phone",  
921 - "code" 2121 + "name",
  2122 + "authIds",
  2123 + "authsDesc",
  2124 + "usersDesc",
  2125 + "remark",
  2126 + "updatedAt"
  2127 + ]
  2128 + },
  2129 + "RoleSaveRequest": {
  2130 + "type": "object",
  2131 + "properties": {
  2132 + "role": {
  2133 + "$ref": "#/definitions/RoleItem"
  2134 + }
  2135 + },
  2136 + "title": "RoleSaveRequest",
  2137 + "required": [
  2138 + "role"
922 ] 2139 ]
923 }, 2140 },
924 - "MiniUserApplyJoinCompanyResponse": { 2141 + "RoleSaveResponse": {
925 "type": "object", 2142 "type": "object",
926 - "title": "MiniUserApplyJoinCompanyResponse" 2143 + "title": "RoleSaveResponse"
927 }, 2144 },
928 - "MiniUserAuditRequest": { 2145 + "RoleSearchRequest": {
929 "type": "object", 2146 "type": "object",
930 "properties": { 2147 "properties": {
931 - "userId": { 2148 + "page": {
932 "type": "integer", 2149 "type": "integer",
933 - "format": "int64",  
934 - "description": " 用户ID" 2150 + "format": "int32"
935 }, 2151 },
936 - "status": { 2152 + "size": {
937 "type": "integer", 2153 "type": "integer",
938 - "format": "int32",  
939 - "description": " 审核状态 1:审核通过 2:拒绝" 2154 + "format": "int32"
  2155 + },
  2156 + "style": {
  2157 + "type": "string",
  2158 + "description": " simple:只返回角色ID名称 full:所有字段都返回"
940 } 2159 }
941 }, 2160 },
942 - "title": "MiniUserAuditRequest", 2161 + "title": "RoleSearchRequest",
943 "required": [ 2162 "required": [
944 - "userId",  
945 - "status" 2163 + "style"
946 ] 2164 ]
947 }, 2165 },
948 - "MiniUserDepartmentUsersRequest": {  
949 - "type": "object",  
950 - "title": "MiniUserDepartmentUsersRequest"  
951 - },  
952 - "MiniUserDepartmentUsersResponse": { 2166 + "RoleSearchResponse": {
953 "type": "object", 2167 "type": "object",
954 "properties": { 2168 "properties": {
955 - "departments": { 2169 + "list": {
956 "type": "array", 2170 "type": "array",
957 "items": { 2171 "items": {
958 - "$ref": "#/definitions/Department" 2172 + "$ref": "#/definitions/RoleItem"
959 } 2173 }
960 }, 2174 },
961 - "users": {  
962 - "type": "array",  
963 - "items": {  
964 - "$ref": "#/definitions/UserItem"  
965 - } 2175 + "total": {
  2176 + "type": "integer",
  2177 + "format": "int64"
966 } 2178 }
967 }, 2179 },
968 - "title": "MiniUserDepartmentUsersResponse", 2180 + "title": "RoleSearchResponse",
969 "required": [ 2181 "required": [
970 - "departments",  
971 - "users" 2182 + "list",
  2183 + "total"
972 ] 2184 ]
973 }, 2185 },
974 - "MiniUserInfoRequest": {  
975 - "type": "object",  
976 - "title": "MiniUserInfoRequest"  
977 - },  
978 - "MiniUserInfoResponse": { 2186 + "RoleUpdateRequest": {
979 "type": "object", 2187 "type": "object",
980 "properties": { 2188 "properties": {
981 - "user": {  
982 - "$ref": "#/definitions/UserItem",  
983 - "description": " 用户信息"  
984 - },  
985 - "totalArticle": {  
986 - "type": "integer",  
987 - "format": "int64",  
988 - "description": " 累计信息发布"  
989 - },  
990 - "totalLoved": { 2189 + "id": {
991 "type": "integer", 2190 "type": "integer",
992 - "format": "int64",  
993 - "description": " 累计收到的赞" 2191 + "format": "int64"
994 }, 2192 },
995 - "totalAccepted": {  
996 - "type": "integer",  
997 - "format": "int64",  
998 - "description": " 累计被采纳" 2193 + "role": {
  2194 + "$ref": "#/definitions/RoleItem"
999 } 2195 }
1000 }, 2196 },
1001 - "title": "MiniUserInfoResponse", 2197 + "title": "RoleUpdateRequest",
1002 "required": [ 2198 "required": [
1003 - "user",  
1004 - "totalArticle",  
1005 - "totalLoved",  
1006 - "totalAccepted" 2199 + "id",
  2200 + "role"
1007 ] 2201 ]
1008 }, 2202 },
1009 - "MiniUserLoginRequest": { 2203 + "RoleUpdateResponse": {
1010 "type": "object", 2204 "type": "object",
1011 - "properties": {  
1012 - "loginType": {  
1013 - "type": "string",  
1014 - "description": " 登录类型 wechat-login whchat-phone-login phone-password-login phone-smscode-login"  
1015 - },  
1016 - "wechatAuthcode": {  
1017 - "type": "string",  
1018 - "description": " 微信登录 授权码"  
1019 - },  
1020 - "wechatEncryptedData": {  
1021 - "type": "string",  
1022 - "description": " 微信登录 加密数据"  
1023 - },  
1024 - "wechatIV": {  
1025 - "type": "string",  
1026 - "description": " 微信登录 加密算法初始向量"  
1027 - },  
1028 - "phone": {  
1029 - "type": "string",  
1030 - "description": " 手机号"  
1031 - },  
1032 - "password": {  
1033 - "type": "string",  
1034 - "description": " 密码"  
1035 - },  
1036 - "smsCode": {  
1037 - "type": "string",  
1038 - "description": " 短信验证码"  
1039 - }  
1040 - },  
1041 - "title": "MiniUserLoginRequest",  
1042 - "required": [  
1043 - "loginType"  
1044 - ] 2205 + "title": "RoleUpdateResponse"
1045 }, 2206 },
1046 - "MiniUserLoginResponse": { 2207 + "RoleUser": {
1047 "type": "object", 2208 "type": "object",
1048 "properties": { 2209 "properties": {
1049 - "token": {  
1050 - "type": "string",  
1051 - "description": " x-token"  
1052 - },  
1053 - "phone": {  
1054 - "type": "string",  
1055 - "description": " 手机号"  
1056 - },  
1057 - "message": {  
1058 - "type": "string",  
1059 - "description": " 失败消息(审核中,注册成功等待审核)" 2210 + "id": {
  2211 + "type": "integer",
  2212 + "format": "int64"
1060 }, 2213 },
1061 - "success": {  
1062 - "type": "boolean",  
1063 - "format": "boolean",  
1064 - "description": " 成功标识" 2214 + "name": {
  2215 + "type": "string"
1065 } 2216 }
1066 }, 2217 },
1067 - "title": "MiniUserLoginResponse", 2218 + "title": "RoleUser",
1068 "required": [ 2219 "required": [
1069 - "token",  
1070 - "phone",  
1071 - "message",  
1072 - "success" 2220 + "id",
  2221 + "name"
1073 ] 2222 ]
1074 }, 2223 },
1075 "SimpleArticle": { 2224 "SimpleArticle": {
@@ -1130,8 +2279,7 @@ @@ -1130,8 +2279,7 @@
1130 "companyId", 2279 "companyId",
1131 "image", 2280 "image",
1132 "name", 2281 "name",
1133 - "group",  
1134 - "remark" 2282 + "group"
1135 ] 2283 ]
1136 }, 2284 },
1137 "TagCreateResponse": { 2285 "TagCreateResponse": {
@@ -1153,11 +2301,16 @@ @@ -1153,11 +2301,16 @@
1153 "id": { 2301 "id": {
1154 "type": "integer", 2302 "type": "integer",
1155 "format": "int64" 2303 "format": "int64"
  2304 + },
  2305 + "companyId": {
  2306 + "type": "integer",
  2307 + "format": "int64"
1156 } 2308 }
1157 }, 2309 },
1158 "title": "TagDeleteRequest", 2310 "title": "TagDeleteRequest",
1159 "required": [ 2311 "required": [
1160 - "id" 2312 + "id",
  2313 + "-"
1161 ] 2314 ]
1162 }, 2315 },
1163 "TagDeleteResponse": { 2316 "TagDeleteResponse": {
@@ -1203,11 +2356,10 @@ @@ -1203,11 +2356,10 @@
1203 "title": "TagEditRequest", 2356 "title": "TagEditRequest",
1204 "required": [ 2357 "required": [
1205 "id", 2358 "id",
1206 - "companyId", 2359 + "-",
1207 "image", 2360 "image",
1208 "name", 2361 "name",
1209 - "group",  
1210 - "remark" 2362 + "group"
1211 ] 2363 ]
1212 }, 2364 },
1213 "TagEditResponse": { 2365 "TagEditResponse": {
@@ -1229,11 +2381,16 @@ @@ -1229,11 +2381,16 @@
1229 "id": { 2381 "id": {
1230 "type": "integer", 2382 "type": "integer",
1231 "format": "int64" 2383 "format": "int64"
  2384 + },
  2385 + "companyId": {
  2386 + "type": "integer",
  2387 + "format": "int64"
1232 } 2388 }
1233 }, 2389 },
1234 "title": "TagGetRequest", 2390 "title": "TagGetRequest",
1235 "required": [ 2391 "required": [
1236 - "id" 2392 + "id",
  2393 + "-"
1237 ] 2394 ]
1238 }, 2395 },
1239 "TagGetResponse": { 2396 "TagGetResponse": {
@@ -1315,12 +2472,26 @@ @@ -1315,12 +2472,26 @@
1315 "size": { 2472 "size": {
1316 "type": "integer", 2473 "type": "integer",
1317 "format": "int32" 2474 "format": "int32"
  2475 + },
  2476 + "companyId": {
  2477 + "type": "integer",
  2478 + "format": "int64"
  2479 + },
  2480 + "tagName": {
  2481 + "type": "string"
  2482 + },
  2483 + "group": {
  2484 + "type": "string"
  2485 + },
  2486 + "remark": {
  2487 + "type": "string"
1318 } 2488 }
1319 }, 2489 },
1320 "title": "TagListRequest", 2490 "title": "TagListRequest",
1321 "required": [ 2491 "required": [
1322 "page", 2492 "page",
1323 - "size" 2493 + "size",
  2494 + "-"
1324 ] 2495 ]
1325 }, 2496 },
1326 "TagListResponse": { 2497 "TagListResponse": {
@@ -1328,7 +2499,7 @@ @@ -1328,7 +2499,7 @@
1328 "properties": { 2499 "properties": {
1329 "total": { 2500 "total": {
1330 "type": "integer", 2501 "type": "integer",
1331 - "format": "int32" 2502 + "format": "int64"
1332 }, 2503 },
1333 "list": { 2504 "list": {
1334 "type": "array", 2505 "type": "array",
@@ -1382,7 +2553,7 @@ @@ -1382,7 +2553,7 @@
1382 "position" 2553 "position"
1383 ] 2554 ]
1384 }, 2555 },
1385 - "UserItem": { 2556 + "UserFollowItem": {
1386 "type": "object", 2557 "type": "object",
1387 "properties": { 2558 "properties": {
1388 "id": { 2559 "id": {
@@ -1390,23 +2561,60 @@ @@ -1390,23 +2561,60 @@
1390 "format": "int64", 2561 "format": "int64",
1391 "description": " 用户ID" 2562 "description": " 用户ID"
1392 }, 2563 },
1393 - "companyId": { 2564 + "name": {
  2565 + "type": "string",
  2566 + "description": " 名称"
  2567 + },
  2568 + "companyName": {
  2569 + "type": "string",
  2570 + "description": " 公司名称"
  2571 + },
  2572 + "avatar": {
  2573 + "type": "string",
  2574 + "description": " 头像"
  2575 + },
  2576 + "position": {
  2577 + "type": "string",
  2578 + "description": " 职位"
  2579 + },
  2580 + "followed": {
  2581 + "type": "boolean",
  2582 + "format": "boolean",
  2583 + "description": " 关注"
  2584 + },
  2585 + "mutualFollowed": {
  2586 + "type": "boolean",
  2587 + "format": "boolean",
  2588 + "description": " 互相关注标识"
  2589 + }
  2590 + },
  2591 + "title": "UserFollowItem",
  2592 + "required": [
  2593 + "id",
  2594 + "name",
  2595 + "companyName",
  2596 + "avatar",
  2597 + "position",
  2598 + "followed",
  2599 + "mutualFollowed"
  2600 + ]
  2601 + },
  2602 + "UserItem": {
  2603 + "type": "object",
  2604 + "properties": {
  2605 + "id": {
1394 "type": "integer", 2606 "type": "integer",
1395 "format": "int64", 2607 "format": "int64",
1396 - "description": " 公司ID" 2608 + "description": " 用户ID"
1397 }, 2609 },
1398 - "departmentId": { 2610 + "companyId": {
1399 "type": "integer", 2611 "type": "integer",
1400 "format": "int64", 2612 "format": "int64",
1401 - "description": " 部门ID" 2613 + "description": " 公司ID"
1402 }, 2614 },
1403 - "roleId": {  
1404 - "type": "array",  
1405 - "items": {  
1406 - "type": "integer",  
1407 - "format": "int64"  
1408 - },  
1409 - "description": " 角色" 2615 + "companyName": {
  2616 + "type": "string",
  2617 + "description": " 公司名称"
1410 }, 2618 },
1411 "flag": { 2619 "flag": {
1412 "type": "integer", 2620 "type": "integer",
@@ -1435,8 +2643,7 @@ @@ -1435,8 +2643,7 @@
1435 "description": " 启用状态 1:启用 2:禁用" 2643 "description": " 启用状态 1:启用 2:禁用"
1436 }, 2644 },
1437 "auditStatus": { 2645 "auditStatus": {
1438 - "type": "integer",  
1439 - "format": "int32", 2646 + "$ref": "#/definitions/int",
1440 "description": " 审核状态 0:待审核 1:审核通过 2:拒绝" 2647 "description": " 审核状态 0:待审核 1:审核通过 2:拒绝"
1441 }, 2648 },
1442 "followers": { 2649 "followers": {
@@ -1454,14 +2661,25 @@ @@ -1454,14 +2661,25 @@
1454 "format": "int64" 2661 "format": "int64"
1455 }, 2662 },
1456 "description": " 我关注的人 (冗余)" 2663 "description": " 我关注的人 (冗余)"
  2664 + },
  2665 + "departments": {
  2666 + "type": "array",
  2667 + "items": {
  2668 + "type": "integer",
  2669 + "format": "int64"
  2670 + },
  2671 + "description": " 所属部门"
  2672 + },
  2673 + "accountFrom": {
  2674 + "type": "string",
  2675 + "description": " 账号来源 后台新增、扫码注册"
1457 } 2676 }
1458 }, 2677 },
1459 "title": "UserItem", 2678 "title": "UserItem",
1460 "required": [ 2679 "required": [
1461 "id", 2680 "id",
1462 "companyId", 2681 "companyId",
1463 - "departmentId",  
1464 - "roleId", 2682 + "companyName",
1465 "flag", 2683 "flag",
1466 "name", 2684 "name",
1467 "avatar", 2685 "avatar",
@@ -1470,7 +2688,9 @@ @@ -1470,7 +2688,9 @@
1470 "enable", 2688 "enable",
1471 "auditStatus", 2689 "auditStatus",
1472 "followers", 2690 "followers",
1473 - "following" 2691 + "following",
  2692 + "departments",
  2693 + "accountFrom"
1474 ] 2694 ]
1475 }, 2695 },
1476 "UserSearchRequest": { 2696 "UserSearchRequest": {
@@ -1510,6 +2730,42 @@ @@ -1510,6 +2730,42 @@
1510 "list", 2730 "list",
1511 "total" 2731 "total"
1512 ] 2732 ]
  2733 + },
  2734 + "WhichUserLikeArticle": {
  2735 + "type": "object",
  2736 + "properties": {
  2737 + "articleId": {
  2738 + "type": "integer",
  2739 + "format": "int64",
  2740 + "description": " 文章id"
  2741 + },
  2742 + "userId": {
  2743 + "type": "integer",
  2744 + "format": "int64",
  2745 + "description": " 人员id"
  2746 + },
  2747 + "name": {
  2748 + "type": "string",
  2749 + "description": " 人员名称"
  2750 + },
  2751 + "avatar": {
  2752 + "type": "string",
  2753 + "description": " 人员头像"
  2754 + },
  2755 + "createdAt": {
  2756 + "type": "integer",
  2757 + "format": "int64",
  2758 + "description": " 点赞记录的时间"
  2759 + }
  2760 + },
  2761 + "title": "WhichUserLikeArticle",
  2762 + "required": [
  2763 + "articleId",
  2764 + "userId",
  2765 + "name",
  2766 + "avatar",
  2767 + "createdAt"
  2768 + ]
1513 } 2769 }
1514 }, 2770 },
1515 "securityDefinitions": { 2771 "securityDefinitions": {
  1 +syntax = "v1"
  2 +
  3 +info(
  4 + title: "天联鹰蜓"
  5 + desc: "天联鹰蜓"
  6 + author: "email"
  7 + email: "email"
  8 + version: "v1"
  9 +)
  10 +
  11 +@server(
  12 + prefix: v1
  13 + group: role
  14 + jwt: SystemAuth
  15 +)
  16 +service Core {
  17 + @handler systemGetRole
  18 + get /system/role/:id (RoleGetRequest) returns (RoleGetResponse)
  19 + @handler systemSaveRole
  20 + post /system/role (RoleSaveRequest) returns (RoleSaveResponse)
  21 + @handler systemDeleteRole
  22 + delete /system/role/:id (RoleDeleteRequest) returns (RoleDeleteResponse)
  23 + @handler systemUpdateRole
  24 + put /system/role/:id (RoleUpdateRequest) returns (RoleUpdateResponse)
  25 + @handler systemSearchRole
  26 + post /system/role/search (RoleSearchRequest) returns (RoleSearchResponse)
  27 +}
  28 +
  29 +type (
  30 + RoleGetRequest {
  31 + Id int64 `path:"id"`
  32 + }
  33 + RoleGetResponse struct{
  34 + Role RoleItem `json:"role"`
  35 + AuthList []Auth `json:"authList"`
  36 + }
  37 +
  38 + RoleSaveRequest struct{
  39 + Role RoleItem `json:"role"`
  40 + }
  41 + RoleSaveResponse struct{}
  42 +
  43 + RoleDeleteRequest struct{
  44 + Id int64 `path:"id"`
  45 + }
  46 + RoleDeleteResponse struct{}
  47 +
  48 + RoleUpdateRequest struct{
  49 + Id int64 `path:"id"`
  50 + Role RoleItem `json:"role"`
  51 + }
  52 + RoleUpdateResponse struct{}
  53 +
  54 + RoleSearchRequest struct{
  55 + Page int `json:"page,optional"`
  56 + Size int `json:"size,optional"`
  57 + Style string `json:"style,options=[simple,,full]"` // simple:只返回角色ID名称 full:所有字段都返回
  58 + }
  59 + RoleSearchResponse{
  60 + List []RoleItem `json:"list"`
  61 + Total int64 `json:"total"`
  62 + }
  63 + RoleItem struct{
  64 + Id int64 `json:"id,optional"` // 角色ID
  65 + CompanyId int64 `json:"companyId,optional,omitempty"` // 公司ID
  66 + Name string `json:"name"` // 角色名称
  67 + AuthIds []int64 `json:"authIds,optional,omitempty"` // 角色权限列表
  68 + AuthsDesc string `json:"authsDesc,optional,omitempty"` // 权限列表描述
  69 + UsersDesc string `json:"usersDesc,optional,omitempty"` // 用户列表描述
  70 + Remark string `json:"remark,optional,omitempty"` // 备注
  71 + Users []RoleUser `json:"users,optional,omitempty"` // 绑定的用户
  72 + UpdatedAt int64 `json:"updatedAt,optional,omitempty"` // 更新时间
  73 + }
  74 + RoleUser {
  75 + Id int64 `json:"id"`
  76 + Name string `json:"name"`
  77 + }
  78 + Auth {
  79 + Id int64 `json:"id"` // ID
  80 + Name string `json:"name"` // 名称
  81 + Code string `json:"code"` // 编码
  82 + }
  83 +)
@@ -27,6 +27,9 @@ service Core { @@ -27,6 +27,9 @@ service Core {
27 jwt: MiniAuth 27 jwt: MiniAuth
28 ) 28 )
29 service Core { 29 service Core {
  30 + @doc "切换账号"
  31 + @handler miniUserSwitchAccount
  32 + post /mini/user/switch-account (MiniUserSwitchAccountRequest) returns (MiniUserLoginResponse)
30 @doc "用户信息" 33 @doc "用户信息"
31 @handler miniUserInfo 34 @handler miniUserInfo
32 post /mini/user/info (MiniUserInfoRequest) returns (MiniUserInfoResponse) 35 post /mini/user/info (MiniUserInfoRequest) returns (MiniUserInfoResponse)
@@ -72,6 +75,9 @@ type( @@ -72,6 +75,9 @@ type(
72 Message string `json:"message"` // 失败消息(审核中,注册成功等待审核) 75 Message string `json:"message"` // 失败消息(审核中,注册成功等待审核)
73 Success bool `json:"success"` // 成功标识 76 Success bool `json:"success"` // 成功标识
74 } 77 }
  78 + MiniUserSwitchAccountRequest{
  79 + CompanyId int64 `json:"companyId"`
  80 + }
75 81
76 MiniUserInfoRequest { 82 MiniUserInfoRequest {
77 //MyStatisticsFlag bool `json:"myStatisticsFlag"` // true:返回统计信息 false;统计信息不返回 83 //MyStatisticsFlag bool `json:"myStatisticsFlag"` // true:返回统计信息 false;统计信息不返回
@@ -81,6 +87,8 @@ type( @@ -81,6 +87,8 @@ type(
81 TotalArticle int64 `json:"totalArticle"` // 累计信息发布 87 TotalArticle int64 `json:"totalArticle"` // 累计信息发布
82 TotalLoved int64 `json:"totalLoved"` // 累计收到的赞 88 TotalLoved int64 `json:"totalLoved"` // 累计收到的赞
83 TotalAccepted int64 `json:"totalAccepted"` // 累计被采纳 89 TotalAccepted int64 `json:"totalAccepted"` // 累计被采纳
  90 + Accounts []Account `json:"accounts"` // 公司账号
  91 + Auths []Auth `json:"auths"` // 权限列表
84 } 92 }
85 MiniUserApplyJoinCompanyRequest{ 93 MiniUserApplyJoinCompanyRequest{
86 Phone string `json:"phone"` 94 Phone string `json:"phone"`
@@ -126,6 +134,14 @@ type( @@ -126,6 +134,14 @@ type(
126 Departments []int64 `json:"departments,omitempty"` // 所属部门 134 Departments []int64 `json:"departments,omitempty"` // 所属部门
127 AccountFrom string `json:"accountFrom,omitempty"` // 账号来源 后台新增、扫码注册 135 AccountFrom string `json:"accountFrom,omitempty"` // 账号来源 后台新增、扫码注册
128 } 136 }
  137 + Account {
  138 + CompanyId int64 `json:"companyId"` // 公司ID
  139 + CompanyName string `json:"companyName"` // 公司名称
  140 + Logo string `json:"logo"` // 公司图标
  141 + UserId int64 `json:"userId"` // 用户ID
  142 + Name string `json:"name"` // 名称
  143 + Position string `json:"position"`// 职位
  144 + }
129 Department struct { 145 Department struct {
130 Id int64 `json:"id,omitempty"` // 部门ID 146 Id int64 `json:"id,omitempty"` // 部门ID
131 CompanyId int64 `json:"companyId,omitempty"` // 公司ID 147 CompanyId int64 `json:"companyId,omitempty"` // 公司ID
  1 +package role
  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/role"
  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 SystemDeleteRoleHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
  14 + return func(w http.ResponseWriter, r *http.Request) {
  15 + var req types.RoleDeleteRequest
  16 + if err := httpx.Parse(r, &req); err != nil {
  17 + httpx.ErrorCtx(r.Context(), w, err)
  18 + return
  19 + }
  20 +
  21 + l := role.NewSystemDeleteRoleLogic(r.Context(), svcCtx)
  22 + resp, err := l.SystemDeleteRole(&req)
  23 + result.HttpResult(r, w, resp, err)
  24 + }
  25 +}
  1 +package role
  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/role"
  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 SystemGetRoleHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
  14 + return func(w http.ResponseWriter, r *http.Request) {
  15 + var req types.RoleGetRequest
  16 + if err := httpx.Parse(r, &req); err != nil {
  17 + httpx.ErrorCtx(r.Context(), w, err)
  18 + return
  19 + }
  20 +
  21 + l := role.NewSystemGetRoleLogic(r.Context(), svcCtx)
  22 + resp, err := l.SystemGetRole(&req)
  23 + result.HttpResult(r, w, resp, err)
  24 + }
  25 +}
  1 +package role
  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/role"
  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 SystemSaveRoleHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
  14 + return func(w http.ResponseWriter, r *http.Request) {
  15 + var req types.RoleSaveRequest
  16 + if err := httpx.Parse(r, &req); err != nil {
  17 + httpx.ErrorCtx(r.Context(), w, err)
  18 + return
  19 + }
  20 +
  21 + l := role.NewSystemSaveRoleLogic(r.Context(), svcCtx)
  22 + resp, err := l.SystemSaveRole(&req)
  23 + result.HttpResult(r, w, resp, err)
  24 + }
  25 +}
  1 +package role
  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/role"
  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 SystemSearchRoleHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
  14 + return func(w http.ResponseWriter, r *http.Request) {
  15 + var req types.RoleSearchRequest
  16 + if err := httpx.Parse(r, &req); err != nil {
  17 + httpx.ErrorCtx(r.Context(), w, err)
  18 + return
  19 + }
  20 +
  21 + l := role.NewSystemSearchRoleLogic(r.Context(), svcCtx)
  22 + resp, err := l.SystemSearchRole(&req)
  23 + result.HttpResult(r, w, resp, err)
  24 + }
  25 +}
  1 +package role
  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/role"
  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 SystemUpdateRoleHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
  14 + return func(w http.ResponseWriter, r *http.Request) {
  15 + var req types.RoleUpdateRequest
  16 + if err := httpx.Parse(r, &req); err != nil {
  17 + httpx.ErrorCtx(r.Context(), w, err)
  18 + return
  19 + }
  20 +
  21 + l := role.NewSystemUpdateRoleLogic(r.Context(), svcCtx)
  22 + resp, err := l.SystemUpdateRole(&req)
  23 + result.HttpResult(r, w, resp, err)
  24 + }
  25 +}
@@ -8,6 +8,7 @@ import ( @@ -8,6 +8,7 @@ import (
8 comment "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/handler/comment" 8 comment "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/handler/comment"
9 company "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/handler/company" 9 company "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/handler/company"
10 message "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/handler/message" 10 message "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/handler/message"
  11 + role "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/handler/role"
11 tags "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/handler/tags" 12 tags "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/handler/tags"
12 user "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/handler/user" 13 user "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/handler/user"
13 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc" 14 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc"
@@ -109,6 +110,11 @@ func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) { @@ -109,6 +110,11 @@ func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) {
109 []rest.Route{ 110 []rest.Route{
110 { 111 {
111 Method: http.MethodPost, 112 Method: http.MethodPost,
  113 + Path: "/mini/user/switch-account",
  114 + Handler: user.MiniUserSwitchAccountHandler(serverCtx),
  115 + },
  116 + {
  117 + Method: http.MethodPost,
112 Path: "/mini/user/info", 118 Path: "/mini/user/info",
113 Handler: user.MiniUserInfoHandler(serverCtx), 119 Handler: user.MiniUserInfoHandler(serverCtx),
114 }, 120 },
@@ -228,4 +234,36 @@ func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) { @@ -228,4 +234,36 @@ func RegisterHandlers(server *rest.Server, serverCtx *svc.ServiceContext) {
228 rest.WithJwt(serverCtx.Config.MiniAuth.AccessSecret), 234 rest.WithJwt(serverCtx.Config.MiniAuth.AccessSecret),
229 rest.WithPrefix("/v1/system"), 235 rest.WithPrefix("/v1/system"),
230 ) 236 )
  237 +
  238 + server.AddRoutes(
  239 + []rest.Route{
  240 + {
  241 + Method: http.MethodGet,
  242 + Path: "/system/role/:id",
  243 + Handler: role.SystemGetRoleHandler(serverCtx),
  244 + },
  245 + {
  246 + Method: http.MethodPost,
  247 + Path: "/system/role",
  248 + Handler: role.SystemSaveRoleHandler(serverCtx),
  249 + },
  250 + {
  251 + Method: http.MethodDelete,
  252 + Path: "/system/role/:id",
  253 + Handler: role.SystemDeleteRoleHandler(serverCtx),
  254 + },
  255 + {
  256 + Method: http.MethodPut,
  257 + Path: "/system/role/:id",
  258 + Handler: role.SystemUpdateRoleHandler(serverCtx),
  259 + },
  260 + {
  261 + Method: http.MethodPost,
  262 + Path: "/system/role/search",
  263 + Handler: role.SystemSearchRoleHandler(serverCtx),
  264 + },
  265 + },
  266 + rest.WithJwt(serverCtx.Config.SystemAuth.AccessSecret),
  267 + rest.WithPrefix("/v1"),
  268 + )
231 } 269 }
  1 +package user
  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/user"
  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 MiniUserSwitchAccountHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
  14 + return func(w http.ResponseWriter, r *http.Request) {
  15 + var req types.MiniUserSwitchAccountRequest
  16 + if err := httpx.Parse(r, &req); err != nil {
  17 + httpx.ErrorCtx(r.Context(), w, err)
  18 + return
  19 + }
  20 +
  21 + l := user.NewMiniUserSwitchAccountLogic(r.Context(), svcCtx)
  22 + resp, err := l.MiniUserSwitchAccount(&req)
  23 + result.HttpResult(r, w, resp, err)
  24 + }
  25 +}
  1 +package role
  2 +
  3 +import (
  4 + "context"
  5 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/db/transaction"
  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 SystemDeleteRoleLogic struct {
  16 + logx.Logger
  17 + ctx context.Context
  18 + svcCtx *svc.ServiceContext
  19 +}
  20 +
  21 +func NewSystemDeleteRoleLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SystemDeleteRoleLogic {
  22 + return &SystemDeleteRoleLogic{
  23 + Logger: logx.WithContext(ctx),
  24 + ctx: ctx,
  25 + svcCtx: svcCtx,
  26 + }
  27 +}
  28 +
  29 +func (l *SystemDeleteRoleLogic) SystemDeleteRole(req *types.RoleDeleteRequest) (resp *types.RoleDeleteResponse, err error) {
  30 + var (
  31 + conn = l.svcCtx.DefaultDBConn()
  32 + role *domain.Role
  33 + userRemoveRoleList []*domain.User
  34 + )
  35 + if role, err = l.svcCtx.RoleRepository.FindOne(l.ctx, conn, req.Id); err != nil {
  36 + return nil, xerr.NewErrMsgErr("角色不存在", err)
  37 + }
  38 + for _, item := range role.Users {
  39 + var user *domain.User
  40 + if user, err = l.svcCtx.UserRepository.FindOne(l.ctx, conn, item.Id); err != nil {
  41 + return nil, xerr.NewErrMsgErr("用户存在", err)
  42 + }
  43 + userRemoveRoleList = append(userRemoveRoleList, user)
  44 + }
  45 + if err = transaction.UseTrans(l.ctx, l.svcCtx.DB, func(ctx context.Context, conn transaction.Conn) error {
  46 + if role, err = l.svcCtx.RoleRepository.Delete(l.ctx, conn, role); err != nil {
  47 + return err
  48 + }
  49 + for _, user := range userRemoveRoleList {
  50 + user.RemoveRole(role.Id)
  51 + if user, err = l.svcCtx.UserRepository.UpdateWithVersion(ctx, conn, user); err != nil {
  52 + return err
  53 + }
  54 + }
  55 + return nil
  56 + }, true); err != nil {
  57 + return nil, xerr.NewErrMsgErr("删除角色失败", err)
  58 + }
  59 +
  60 + resp = &types.RoleDeleteResponse{}
  61 + return
  62 +}
  1 +package role
  2 +
  3 +import (
  4 + "context"
  5 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain"
  6 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr"
  7 +
  8 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc"
  9 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types"
  10 +
  11 + "github.com/zeromicro/go-zero/core/logx"
  12 +)
  13 +
  14 +type SystemGetRoleLogic struct {
  15 + logx.Logger
  16 + ctx context.Context
  17 + svcCtx *svc.ServiceContext
  18 +}
  19 +
  20 +func NewSystemGetRoleLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SystemGetRoleLogic {
  21 + return &SystemGetRoleLogic{
  22 + Logger: logx.WithContext(ctx),
  23 + ctx: ctx,
  24 + svcCtx: svcCtx,
  25 + }
  26 +}
  27 +
  28 +func (l *SystemGetRoleLogic) SystemGetRole(req *types.RoleGetRequest) (resp *types.RoleGetResponse, err error) {
  29 + var (
  30 + conn = l.svcCtx.DefaultDBConn()
  31 + role *domain.Role
  32 + )
  33 + if role, err = l.svcCtx.RoleRepository.FindOne(l.ctx, conn, req.Id); err != nil {
  34 + return nil, xerr.NewErrMsgErr("角色不存在", err)
  35 + }
  36 + resp = &types.RoleGetResponse{
  37 + Role: NewTypesRole(role),
  38 + }
  39 + for _, auth := range domain.Auths {
  40 + resp.AuthList = append(resp.AuthList, types.Auth{
  41 + Id: auth.Id,
  42 + Name: auth.Name,
  43 + Code: auth.Code,
  44 + })
  45 + }
  46 + return
  47 +}
  1 +package role
  2 +
  3 +import (
  4 + "context"
  5 + "fmt"
  6 + "github.com/samber/lo"
  7 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/db/transaction"
  8 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain"
  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 SystemSaveRoleLogic struct {
  19 + logx.Logger
  20 + ctx context.Context
  21 + svcCtx *svc.ServiceContext
  22 +}
  23 +
  24 +func NewSystemSaveRoleLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SystemSaveRoleLogic {
  25 + return &SystemSaveRoleLogic{
  26 + Logger: logx.WithContext(ctx),
  27 + ctx: ctx,
  28 + svcCtx: svcCtx,
  29 + }
  30 +}
  31 +
  32 +func (l *SystemSaveRoleLogic) SystemSaveRole(req *types.RoleSaveRequest) (resp *types.RoleSaveResponse, err error) {
  33 + var (
  34 + conn = l.svcCtx.DefaultDBConn()
  35 + userAddRoleList []*domain.User
  36 + )
  37 + role := NewDomainRole(l.ctx, req.Role)
  38 + for _, authId := range req.Role.AuthIds {
  39 + if auth := role.GetAuth(authId); auth == nil {
  40 + return nil, xerr.NewErrMsg(fmt.Sprintf("unknown auth %d ", authId))
  41 + }
  42 + }
  43 + for _, item := range req.Role.Users {
  44 + var user *domain.User
  45 + if user, err = l.svcCtx.UserRepository.FindOne(l.ctx, conn, item.Id); err != nil {
  46 + return nil, xerr.NewErrMsgErr("用户存在", err)
  47 + }
  48 + userAddRoleList = append(userAddRoleList, user)
  49 + }
  50 + if err = transaction.UseTrans(l.ctx, l.svcCtx.DB, func(ctx context.Context, conn transaction.Conn) error {
  51 + if role, err = l.svcCtx.RoleRepository.Insert(ctx, conn, role); err != nil {
  52 + return err
  53 + }
  54 + for _, user := range userAddRoleList {
  55 + user.AddRole(role.Id)
  56 + if user, err = l.svcCtx.UserRepository.UpdateWithVersion(ctx, conn, user); err != nil {
  57 + return err
  58 + }
  59 + }
  60 + return nil
  61 + }, true); err != nil {
  62 + return nil, xerr.NewErrMsgErr("添加角色失败", err)
  63 + }
  64 + resp = &types.RoleSaveResponse{}
  65 + return
  66 +}
  67 +
  68 +func NewDomainRole(ctx context.Context, item types.RoleItem) *domain.Role {
  69 + var (
  70 + role *domain.Role
  71 + users []domain.User = make([]domain.User, 0)
  72 + userToken = contextdata.GetUserTokenFromCtx(ctx)
  73 + )
  74 + lo.ForEach(item.Users, func(item types.RoleUser, index int) {
  75 + users = append(users, domain.User{
  76 + Id: item.Id,
  77 + Name: item.Name,
  78 + })
  79 + })
  80 + role = &domain.Role{
  81 + CompanyId: userToken.CompanyId,
  82 + Name: item.Name,
  83 + Auths: item.AuthIds,
  84 + Remark: item.Remark,
  85 + Users: users,
  86 + }
  87 + return role
  88 +}
  89 +
  90 +func NewTypesRole(item *domain.Role) types.RoleItem {
  91 + var (
  92 + role types.RoleItem
  93 + users []types.RoleUser = make([]types.RoleUser, 0)
  94 + )
  95 + lo.ForEach(item.Users, func(item domain.User, index int) {
  96 + users = append(users, types.RoleUser{
  97 + Id: item.Id,
  98 + Name: item.Name,
  99 + })
  100 + })
  101 + role = types.RoleItem{
  102 + Id: item.Id,
  103 + CompanyId: item.CompanyId,
  104 + Name: item.Name,
  105 + AuthIds: item.Auths,
  106 + Remark: item.Remark,
  107 + Users: users,
  108 + UpdatedAt: item.UpdatedAt,
  109 + }
  110 + return role
  111 +}
  1 +package role
  2 +
  3 +import (
  4 + "context"
  5 + "fmt"
  6 + "github.com/samber/lo"
  7 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain"
  8 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata"
  9 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr"
  10 + "strings"
  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 SystemSearchRoleLogic struct {
  19 + logx.Logger
  20 + ctx context.Context
  21 + svcCtx *svc.ServiceContext
  22 +}
  23 +
  24 +func NewSystemSearchRoleLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SystemSearchRoleLogic {
  25 + return &SystemSearchRoleLogic{
  26 + Logger: logx.WithContext(ctx),
  27 + ctx: ctx,
  28 + svcCtx: svcCtx,
  29 + }
  30 +}
  31 +
  32 +func (l *SystemSearchRoleLogic) SystemSearchRole(req *types.RoleSearchRequest) (resp *types.RoleSearchResponse, err error) {
  33 + var (
  34 + conn = l.svcCtx.DefaultDBConn()
  35 + userToken = contextdata.GetUserTokenFromCtx(l.ctx)
  36 + roles []*domain.Role
  37 + total int64
  38 + )
  39 + queryOptions := domain.IndexCompanyId(userToken.CompanyId)()
  40 + if req.Page != 0 && req.Size != 0 {
  41 + queryOptions.WithOffsetLimit(req.Page, req.Size)
  42 + }
  43 + total, roles, err = l.svcCtx.RoleRepository.Find(l.ctx, conn, queryOptions)
  44 + if err != nil {
  45 + return nil, xerr.NewErrMsgErr("搜索角色异常", err)
  46 + }
  47 + resp = &types.RoleSearchResponse{
  48 + Total: total,
  49 + List: make([]types.RoleItem, 0),
  50 + }
  51 + if req.Style == "simple" {
  52 + lo.ForEach(roles, func(item *domain.Role, index int) {
  53 + resp.List = append(resp.List, types.RoleItem{
  54 + Id: item.Id,
  55 + Name: item.Name,
  56 + })
  57 + })
  58 + return
  59 + }
  60 + lo.ForEach(roles, func(item *domain.Role, index int) {
  61 + role := NewTypesRole(item)
  62 + role.UsersDesc = usersDesc(item)
  63 + role.AuthsDesc = authsDesc(item)
  64 + resp.List = append(resp.List, role)
  65 + })
  66 + return
  67 +}
  68 +
  69 +func usersDesc(item *domain.Role) string {
  70 + users := lo.Slice(item.Users, 0, 3)
  71 + var (
  72 + nameList = make([]string, 0)
  73 + desc string = " "
  74 + )
  75 + lo.ForEach(users, func(item domain.User, index int) {
  76 + nameList = append(nameList, item.Name)
  77 + })
  78 + if len(users) == 0 {
  79 + return desc
  80 + }
  81 + desc = fmt.Sprintf("%s%s", strings.Join(nameList, "、"),
  82 + lo.Ternary(len(item.Users) > 3, fmt.Sprintf("...共%d人", len(item.Users)), ""),
  83 + )
  84 + return desc
  85 +}
  86 +
  87 +func authsDesc(role *domain.Role) string {
  88 + var (
  89 + nameList = make([]string, 0)
  90 + desc string = " "
  91 + )
  92 + lo.ForEach(role.Auths, func(item int64, index int) {
  93 + if auth := role.GetAuth(item); auth != nil {
  94 + nameList = append(nameList, auth.Name)
  95 + }
  96 + })
  97 + if len(nameList) == 0 {
  98 + return desc
  99 + }
  100 + desc = strings.Join(nameList, "、")
  101 + return desc
  102 +}
  1 +package role
  2 +
  3 +import (
  4 + "context"
  5 + "fmt"
  6 + "github.com/samber/lo"
  7 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/db/transaction"
  8 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain"
  9 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr"
  10 +
  11 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc"
  12 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types"
  13 +
  14 + "github.com/zeromicro/go-zero/core/logx"
  15 +)
  16 +
  17 +type SystemUpdateRoleLogic struct {
  18 + logx.Logger
  19 + ctx context.Context
  20 + svcCtx *svc.ServiceContext
  21 +}
  22 +
  23 +func NewSystemUpdateRoleLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SystemUpdateRoleLogic {
  24 + return &SystemUpdateRoleLogic{
  25 + Logger: logx.WithContext(ctx),
  26 + ctx: ctx,
  27 + svcCtx: svcCtx,
  28 + }
  29 +}
  30 +
  31 +func (l *SystemUpdateRoleLogic) SystemUpdateRole(req *types.RoleUpdateRequest) (resp *types.RoleUpdateResponse, err error) {
  32 + var (
  33 + conn = l.svcCtx.DefaultDBConn()
  34 + role *domain.Role
  35 + beforeUserIds []int64
  36 + afterUserIds []int64
  37 +
  38 + userRemoveRoleList []*domain.User
  39 + userAddRoleList []*domain.User
  40 + )
  41 + if role, err = l.svcCtx.RoleRepository.FindOne(l.ctx, conn, req.Id); err != nil {
  42 + return nil, xerr.NewErrMsgErr("角色不存在", err)
  43 + }
  44 + for _, authId := range req.Role.AuthIds {
  45 + if auth := role.GetAuth(authId); auth == nil {
  46 + return nil, xerr.NewErrMsg(fmt.Sprintf("unknown auth %d ", authId))
  47 + }
  48 + }
  49 + lo.ForEach(role.Users, func(item domain.User, index int) {
  50 + beforeUserIds = append(beforeUserIds, item.Id)
  51 + })
  52 + tempRole := NewDomainRole(l.ctx, req.Role)
  53 + lo.ForEach(tempRole.Users, func(item domain.User, index int) {
  54 + afterUserIds = append(afterUserIds, item.Id)
  55 + })
  56 + removeList, addList := lo.Difference(beforeUserIds, afterUserIds)
  57 + for _, id := range removeList {
  58 + var user *domain.User
  59 + if user, err = l.svcCtx.UserRepository.FindOne(l.ctx, conn, id); err != nil {
  60 + return nil, xerr.NewErrMsgErr("更新角色失败", err)
  61 + }
  62 + userRemoveRoleList = append(userRemoveRoleList, user)
  63 + }
  64 + for _, id := range addList {
  65 + var user *domain.User
  66 + if user, err = l.svcCtx.UserRepository.FindOne(l.ctx, conn, id); err != nil {
  67 + return nil, xerr.NewErrMsgErr("更新角色失败", err)
  68 + }
  69 + userAddRoleList = append(userAddRoleList, user)
  70 + }
  71 + if err = transaction.UseTrans(l.ctx, l.svcCtx.DB, func(ctx context.Context, conn transaction.Conn) error {
  72 + role.Name = tempRole.Name
  73 + role.Auths = tempRole.Auths
  74 + role.Remark = tempRole.Remark
  75 + role.Users = tempRole.Users
  76 + if role, err = l.svcCtx.RoleRepository.UpdateWithVersion(ctx, conn, role); err != nil {
  77 + return err
  78 + }
  79 +
  80 + for _, user := range userRemoveRoleList {
  81 + user.RemoveRole(role.Id)
  82 + if user, err = l.svcCtx.UserRepository.UpdateWithVersion(ctx, conn, user); err != nil {
  83 + return err
  84 + }
  85 + }
  86 +
  87 + for _, user := range userAddRoleList {
  88 + user.AddRole(role.Id)
  89 + if user, err = l.svcCtx.UserRepository.UpdateWithVersion(ctx, conn, user); err != nil {
  90 + return err
  91 + }
  92 + }
  93 + return nil
  94 + }, true); err != nil {
  95 + return nil, xerr.NewErrMsgErr("更新角色失败", err)
  96 + }
  97 + resp = &types.RoleUpdateResponse{}
  98 + return
  99 +}
@@ -2,9 +2,13 @@ package user @@ -2,9 +2,13 @@ package user
2 2
3 import ( 3 import (
4 "context" 4 "context"
5 - 5 + "github.com/samber/lo"
  6 + "github.com/zeromicro/go-zero/core/collection"
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/svc"
7 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types" 8 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types"
  9 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain"
  10 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/contextdata"
  11 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr"
8 12
9 "github.com/zeromicro/go-zero/core/logx" 13 "github.com/zeromicro/go-zero/core/logx"
10 ) 14 )
@@ -23,8 +27,49 @@ func NewMiniUserDepartmentUsersLogic(ctx context.Context, svcCtx *svc.ServiceCon @@ -23,8 +27,49 @@ func NewMiniUserDepartmentUsersLogic(ctx context.Context, svcCtx *svc.ServiceCon
23 } 27 }
24 } 28 }
25 29
26 -func (l *MiniUserDepartmentUsersLogic) MiniUserDepartmentUsers(req *types.MiniUserDepartmentUsersRequest) (resp *types.MiniUserInfoResponse, err error) {  
27 - // todo: add your logic here and delete this line 30 +func (l *MiniUserDepartmentUsersLogic) MiniUserDepartmentUsers(req *types.MiniUserDepartmentUsersRequest) (resp interface{}, err error) {
  31 + var (
  32 + conn = l.svcCtx.DefaultDBConn()
  33 + userToken = contextdata.GetUserTokenFromCtx(l.ctx)
  34 + users []*domain.User
  35 + departments []*domain.Department
  36 + )
  37 + resp = map[string]interface{}{
  38 + "list": make([]DepartmentUser, 0),
  39 + }
  40 + _, departments, err = l.svcCtx.DepartmentRepository.Find(l.ctx, conn, domain.IndexCompanyId(userToken.CompanyId)().WithFindOnly())
  41 + if err != nil {
  42 + return nil, xerr.NewErrMsgErr("查找部门用户失败", err)
  43 + }
  44 + _, users, err = l.svcCtx.UserRepository.FindDepartmentUsers(l.ctx, conn, userToken.CompanyId, domain.NewQueryOptions().WithFindOnly())
  45 + if err != nil {
  46 + return nil, xerr.NewErrMsgErr("查找部门用户失败", err)
  47 + }
  48 + lo.ForEach(departments, func(item *domain.Department, index int) {
  49 + group := DepartmentUser{
  50 + Id: item.Id,
  51 + Name: item.Name,
  52 + Users: make([]*domain.User, 0),
  53 + }
  54 + groupUserSet := collection.NewSet()
  55 + for _, user := range users {
  56 + if len(user.Departments) == 0 {
  57 + continue
  58 + }
  59 + if lo.Contains(user.Departments, item.Id) && !groupUserSet.Contains(user.Id) {
  60 + group.Users = append(group.Users, &domain.User{
  61 + Id: user.Id,
  62 + Name: user.Name,
  63 + })
  64 + }
  65 + }
  66 + })
28 67
29 return 68 return
30 } 69 }
  70 +
  71 +type DepartmentUser struct {
  72 + Id int64 `json:"id"` // 分组ID
  73 + Name string `json:"name"` // 分组名称
  74 + Users []*domain.User `json:"users"` // 用户
  75 +}
@@ -2,6 +2,7 @@ package user @@ -2,6 +2,7 @@ package user
2 2
3 import ( 3 import (
4 "context" 4 "context"
  5 + "github.com/zeromicro/go-zero/core/collection"
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 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr" 8 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr"
@@ -28,18 +29,68 @@ func NewMiniUserInfoLogic(ctx context.Context, svcCtx *svc.ServiceContext) *Mini @@ -28,18 +29,68 @@ func NewMiniUserInfoLogic(ctx context.Context, svcCtx *svc.ServiceContext) *Mini
28 29
29 func (l *MiniUserInfoLogic) MiniUserInfo(req *types.MiniUserInfoRequest) (resp *types.MiniUserInfoResponse, err error) { 30 func (l *MiniUserInfoLogic) MiniUserInfo(req *types.MiniUserInfoRequest) (resp *types.MiniUserInfoResponse, err error) {
30 var ( 31 var (
31 - userToken = contextdata.GetUserTokenFromCtx(l.ctx)  
32 - user *domain.User  
33 - conn = l.svcCtx.DefaultDBConn() 32 + userToken = contextdata.GetUserTokenFromCtx(l.ctx)
  33 + user *domain.User
  34 + conn = l.svcCtx.DefaultDBConn()
  35 + accounts []*domain.User
  36 + companyMap = make(map[int64]*domain.Company)
  37 + roles []*domain.Role
34 ) 38 )
35 if user, err = l.svcCtx.UserRepository.FindOne(l.ctx, conn, userToken.UserId); err != nil { 39 if user, err = l.svcCtx.UserRepository.FindOne(l.ctx, conn, userToken.UserId); err != nil {
36 return nil, xerr.NewErrMsgErr("用户不存在", err) 40 return nil, xerr.NewErrMsgErr("用户不存在", err)
37 } 41 }
  42 + if _, roles, err = l.svcCtx.RoleRepository.Find(l.ctx, conn, domain.IndexCompanyId(user.CompanyId)().MustWithKV("ids", user.Roles)); err != nil {
  43 + return nil, xerr.NewErrMsgErr("角色不存在", err)
  44 + }
38 resp = &types.MiniUserInfoResponse{ 45 resp = &types.MiniUserInfoResponse{
39 User: &types.UserItem{ 46 User: &types.UserItem{
40 Id: user.Id, 47 Id: user.Id,
41 Name: user.Name, 48 Name: user.Name,
42 }, 49 },
  50 + Accounts: make([]types.Account, 0),
  51 + Auths: make([]types.Auth, 0),
  52 + }
  53 + _, accounts, err = l.svcCtx.UserRepository.Find(l.ctx, conn, domain.NewQueryOptions().MustWithKV("phone", user.Phone).MustWithKV("auditStatus", []int{domain.UserAuditStatusPassed}))
  54 + if err != nil {
  55 + return nil, xerr.NewErrMsgErr("用户不存在", err)
  56 + }
  57 + // 拥有的账号
  58 + for _, account := range accounts {
  59 + if account.Enable != domain.UserEnable {
  60 + continue
  61 + }
  62 + var (
  63 + companyName = ""
  64 + logo = ""
  65 + )
  66 + if company, _ := domain.LazyLoad(companyMap, l.ctx, conn, account.CompanyId, l.svcCtx.CompanyRepository.FindOne); company != nil {
  67 + companyName = company.Name
  68 + logo = company.Logo
  69 + }
  70 + resp.Accounts = append(resp.Accounts, types.Account{
  71 + CompanyId: account.CompanyId,
  72 + CompanyName: companyName,
  73 + Logo: logo,
  74 + UserId: account.Id,
  75 + Name: user.Name,
  76 + Position: user.Position,
  77 + })
  78 + }
  79 + // 拥有的权限
  80 + authSet := collection.NewSet()
  81 + for _, role := range roles {
  82 + for _, auth := range role.Auths {
  83 + if !authSet.Contains(auth) {
  84 + authSet.Add(auth)
  85 + if item := role.GetAuth(auth); item != nil {
  86 + resp.Auths = append(resp.Auths, types.Auth{
  87 + Id: item.Id,
  88 + Name: item.Name,
  89 + Code: item.Code,
  90 + })
  91 + }
  92 + }
  93 + }
43 } 94 }
44 return 95 return
45 } 96 }
  1 +package user
  2 +
  3 +import (
  4 + "context"
  5 + "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/tool"
  8 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/pkg/xerr"
  9 +
  10 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/svc"
  11 + "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/api/internal/types"
  12 +
  13 + "github.com/zeromicro/go-zero/core/logx"
  14 +)
  15 +
  16 +type MiniUserSwitchAccountLogic struct {
  17 + logx.Logger
  18 + ctx context.Context
  19 + svcCtx *svc.ServiceContext
  20 +}
  21 +
  22 +func NewMiniUserSwitchAccountLogic(ctx context.Context, svcCtx *svc.ServiceContext) *MiniUserSwitchAccountLogic {
  23 + return &MiniUserSwitchAccountLogic{
  24 + Logger: logx.WithContext(ctx),
  25 + ctx: ctx,
  26 + svcCtx: svcCtx,
  27 + }
  28 +}
  29 +
  30 +func (l *MiniUserSwitchAccountLogic) MiniUserSwitchAccount(req *types.MiniUserSwitchAccountRequest) (resp *types.MiniUserLoginResponse, err error) {
  31 + var (
  32 + conn = l.svcCtx.DefaultDBConn()
  33 + userToken = contextdata.GetUserTokenFromCtx(l.ctx)
  34 + token string
  35 + currentUser *domain.User
  36 + switchToUser *domain.User
  37 + )
  38 + if currentUser, err = l.svcCtx.UserRepository.FindOne(l.ctx, conn, userToken.UserId); err != nil {
  39 + return nil, xerr.NewErrMsgErr("当前账号异常", err)
  40 + }
  41 + if switchToUser, err = l.svcCtx.UserRepository.FindOneByCompanyIdAndPhone(l.ctx, conn, req.CompanyId, currentUser.Phone, []int{domain.UserAuditStatusPassed}); err != nil {
  42 + return nil, xerr.NewErrMsgErr("账号不可用", err)
  43 + }
  44 + if switchToUser.Enable != domain.UserEnable {
  45 + return nil, xerr.NewErrMsgErr("账号不可用", err)
  46 + }
  47 + var userJwtToken = tool.UserToken{}
  48 + if switchToUser != nil {
  49 + userJwtToken.UserId = switchToUser.Id
  50 + userJwtToken.CompanyId = switchToUser.CompanyId
  51 + userJwtToken.ClientType = "mini"
  52 + }
  53 + token, err = userJwtToken.GenerateToken(l.svcCtx.Config.MiniAuth.AccessSecret, l.svcCtx.Config.MiniAuth.AccessExpire)
  54 + if err != nil {
  55 + return nil, xerr.NewErrMsgErr("切换账号失败", err)
  56 + }
  57 + resp = &types.MiniUserLoginResponse{
  58 + Token: token,
  59 + Phone: "",
  60 + Success: true,
  61 + }
  62 + if switchToUser == nil {
  63 + resp.Success = false
  64 + }
  65 + return
  66 +}
@@ -162,6 +162,10 @@ type MiniUserLoginResponse struct { @@ -162,6 +162,10 @@ type MiniUserLoginResponse struct {
162 Success bool `json:"success"` // 成功标识 162 Success bool `json:"success"` // 成功标识
163 } 163 }
164 164
  165 +type MiniUserSwitchAccountRequest struct {
  166 + CompanyId int64 `json:"companyId"`
  167 +}
  168 +
165 type MiniUserInfoRequest struct { 169 type MiniUserInfoRequest struct {
166 } 170 }
167 171
@@ -170,6 +174,8 @@ type MiniUserInfoResponse struct { @@ -170,6 +174,8 @@ type MiniUserInfoResponse struct {
170 TotalArticle int64 `json:"totalArticle"` // 累计信息发布 174 TotalArticle int64 `json:"totalArticle"` // 累计信息发布
171 TotalLoved int64 `json:"totalLoved"` // 累计收到的赞 175 TotalLoved int64 `json:"totalLoved"` // 累计收到的赞
172 TotalAccepted int64 `json:"totalAccepted"` // 累计被采纳 176 TotalAccepted int64 `json:"totalAccepted"` // 累计被采纳
  177 + Accounts []Account `json:"accounts"` // 公司账号
  178 + Auths []Auth `json:"auths"` // 权限列表
173 } 179 }
174 180
175 type MiniUserApplyJoinCompanyRequest struct { 181 type MiniUserApplyJoinCompanyRequest struct {
@@ -220,6 +226,15 @@ type UserItem struct { @@ -220,6 +226,15 @@ type UserItem struct {
220 AccountFrom string `json:"accountFrom,omitempty"` // 账号来源 后台新增、扫码注册 226 AccountFrom string `json:"accountFrom,omitempty"` // 账号来源 后台新增、扫码注册
221 } 227 }
222 228
  229 +type Account struct {
  230 + CompanyId int64 `json:"companyId"` // 公司ID
  231 + CompanyName string `json:"companyName"` // 公司名称
  232 + Logo string `json:"logo"` // 公司图标
  233 + UserId int64 `json:"userId"` // 用户ID
  234 + Name string `json:"name"` // 名称
  235 + Position string `json:"position"` // 职位
  236 +}
  237 +
223 type Department struct { 238 type Department struct {
224 Id int64 `json:"id,omitempty"` // 部门ID 239 Id int64 `json:"id,omitempty"` // 部门ID
225 CompanyId int64 `json:"companyId,omitempty"` // 公司ID 240 CompanyId int64 `json:"companyId,omitempty"` // 公司ID
@@ -465,3 +480,68 @@ type SystemArticleSearch struct { @@ -465,3 +480,68 @@ type SystemArticleSearch struct {
465 Tags []string `json:"tags"` //标签 480 Tags []string `json:"tags"` //标签
466 TargetUser int `json:"targetUser"` //分发方式 [0分发给所有人、1分发给指定的人] 481 TargetUser int `json:"targetUser"` //分发方式 [0分发给所有人、1分发给指定的人]
467 } 482 }
  483 +
  484 +type RoleGetRequest struct {
  485 + Id int64 `path:"id"`
  486 +}
  487 +
  488 +type RoleGetResponse struct {
  489 + Role RoleItem `json:"role"`
  490 + AuthList []Auth `json:"authList"`
  491 +}
  492 +
  493 +type RoleSaveRequest struct {
  494 + Role RoleItem `json:"role"`
  495 +}
  496 +
  497 +type RoleSaveResponse struct {
  498 +}
  499 +
  500 +type RoleDeleteRequest struct {
  501 + Id int64 `path:"id"`
  502 +}
  503 +
  504 +type RoleDeleteResponse struct {
  505 +}
  506 +
  507 +type RoleUpdateRequest struct {
  508 + Id int64 `path:"id"`
  509 + Role RoleItem `json:"role"`
  510 +}
  511 +
  512 +type RoleUpdateResponse struct {
  513 +}
  514 +
  515 +type RoleSearchRequest struct {
  516 + Page int `json:"page,optional"`
  517 + Size int `json:"size,optional"`
  518 + Style string `json:"style,options=[simple,,full]"` // simple:只返回角色ID名称 full:所有字段都返回
  519 +}
  520 +
  521 +type RoleSearchResponse struct {
  522 + List []RoleItem `json:"list"`
  523 + Total int64 `json:"total"`
  524 +}
  525 +
  526 +type RoleItem struct {
  527 + Id int64 `json:"id,optional"` // 角色ID
  528 + CompanyId int64 `json:"companyId,optional,omitempty"` // 公司ID
  529 + Name string `json:"name"` // 角色名称
  530 + AuthIds []int64 `json:"authIds,optional,omitempty"` // 角色权限列表
  531 + AuthsDesc string `json:"authsDesc,optional,omitempty"` // 权限列表描述
  532 + UsersDesc string `json:"usersDesc,optional,omitempty"` // 用户列表描述
  533 + Remark string `json:"remark,optional,omitempty"` // 备注
  534 + Users []RoleUser `json:"users,optional,omitempty"` // 绑定的用户
  535 + UpdatedAt int64 `json:"updatedAt,optional,omitempty"` // 更新时间
  536 +}
  537 +
  538 +type RoleUser struct {
  539 + Id int64 `json:"id"`
  540 + Name string `json:"name"`
  541 +}
  542 +
  543 +type Auth struct {
  544 + Id int64 `json:"id"` // ID
  545 + Name string `json:"name"` // 名称
  546 + Code string `json:"code"` // 编码
  547 +}
@@ -20,6 +20,7 @@ func Migrate(db *gorm.DB) { @@ -20,6 +20,7 @@ func Migrate(db *gorm.DB) {
20 &models.UserFollow{}, 20 &models.UserFollow{},
21 &models.MessageSystem{}, 21 &models.MessageSystem{},
22 &models.MessageBusiness{}, 22 &models.MessageBusiness{},
  23 + &models.Department{},
23 } 24 }
24 25
25 db.AutoMigrate(modelsList...) 26 db.AutoMigrate(modelsList...)
@@ -4,15 +4,20 @@ import ( @@ -4,15 +4,20 @@ import (
4 "fmt" 4 "fmt"
5 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain" 5 "gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain"
6 "gorm.io/gorm" 6 "gorm.io/gorm"
  7 + "gorm.io/plugin/soft_delete"
7 ) 8 )
8 9
9 type Department struct { 10 type Department struct {
10 - Id int64 // 唯一标识  
11 -  
12 - CreatedAt int64 `json:"createdAt,omitempty"`  
13 - UpdatedAt int64 `json:"updatedAt,omitempty"`  
14 - DeletedAt int64 `json:"deletedAt,omitempty"`  
15 - Version int `json:"version,omitempty"` 11 + Id int64 // 唯一标识
  12 + CompanyId int64 `json:"companyId,omitempty"` // 公司ID
  13 + ParentId int64 `json:"parentId,omitempty"` // 父级ID
  14 + Name string `json:"name,omitempty"` // 部门名称
  15 +
  16 + CreatedAt int64 `json:"createdAt,omitempty"`
  17 + UpdatedAt int64 `json:"updatedAt,omitempty"`
  18 + DeletedAt int64 `json:"deletedAt,omitempty"`
  19 + Version int `json:"version,omitempty"`
  20 + IsDel soft_delete.DeletedAt `gorm:"softDelete:flag,DeletedAtField:DeletedAt"`
16 } 21 }
17 22
18 func (m *Department) TableName() string { 23 func (m *Department) TableName() string {
@@ -9,11 +9,12 @@ import ( @@ -9,11 +9,12 @@ import (
9 ) 9 )
10 10
11 type Role struct { 11 type Role struct {
12 - Id int64 // 唯一标识  
13 - Name string `json:"name"` // 角色名称  
14 - Auths []int64 `gorm:"type:jsonb;serializer:json"` // 角色权限列表  
15 - Remark string `json:"remark"` // 备注  
16 - Users []int64 `gorm:"type:jsonb;serializer:json"` // 绑定的用户 12 + Id int64 // 唯一标识
  13 + CompanyId int64
  14 + Name string `json:"name"` // 角色名称
  15 + Auths []int64 `gorm:"type:jsonb;serializer:json"` // 角色权限列表
  16 + Remark string `json:"remark"` // 备注
  17 + Users []domain.User `gorm:"type:jsonb;serializer:json"` // 绑定的用户
17 18
18 CreatedAt int64 19 CreatedAt int64
19 UpdatedAt int64 20 UpdatedAt int64
@@ -120,6 +120,9 @@ func (repository *DepartmentRepository) Find(ctx context.Context, conn transacti @@ -120,6 +120,9 @@ func (repository *DepartmentRepository) Find(ctx context.Context, conn transacti
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["companyId"]; ok {
  124 + tx.Where("company_id = ?", v)
  125 + }
123 if total, tx = transaction.PaginationAndCount(ctx, tx, queryOptions, &ms); tx.Error != nil { 126 if total, tx = transaction.PaginationAndCount(ctx, tx, queryOptions, &ms); tx.Error != nil {
124 return dms, tx.Error 127 return dms, tx.Error
125 } 128 }
@@ -120,12 +120,17 @@ func (repository *RoleRepository) Find(ctx context.Context, conn transaction.Con @@ -120,12 +120,17 @@ func (repository *RoleRepository) Find(ctx context.Context, conn transaction.Con
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["companyId"]; ok {
  124 + tx.Where("company_id = ?", v)
  125 + }
  126 + if v, ok := queryOptions["ids"]; ok {
  127 + tx.Where("id in (?)", v)
  128 + }
123 if total, tx = transaction.PaginationAndCount(ctx, tx, queryOptions, &ms); tx.Error != nil { 129 if total, tx = transaction.PaginationAndCount(ctx, tx, queryOptions, &ms); tx.Error != nil {
124 return dms, tx.Error 130 return dms, tx.Error
125 } 131 }
126 return dms, nil 132 return dms, nil
127 } 133 }
128 -  
129 if _, err := repository.Query(queryFunc); err != nil { 134 if _, err := repository.Query(queryFunc); err != nil {
130 return 0, nil, err 135 return 0, nil, err
131 } 136 }
@@ -141,7 +141,7 @@ func (repository *UserRepository) Find(ctx context.Context, conn transaction.Con @@ -141,7 +141,7 @@ func (repository *UserRepository) Find(ctx context.Context, conn transaction.Con
141 total int64 141 total int64
142 ) 142 )
143 queryFunc := func() (interface{}, error) { 143 queryFunc := func() (interface{}, error) {
144 - tx = tx.Model(&ms).Order("id desc") 144 + tx = tx.Model(&ms).Order("id asc")
145 if v, ok := queryOptions["companyId"]; ok { 145 if v, ok := queryOptions["companyId"]; ok {
146 tx.Where("company_id = ?", v) 146 tx.Where("company_id = ?", v)
147 } 147 }
@@ -174,6 +174,39 @@ func (repository *UserRepository) Find(ctx context.Context, conn transaction.Con @@ -174,6 +174,39 @@ func (repository *UserRepository) Find(ctx context.Context, conn transaction.Con
174 return total, dms, nil 174 return total, dms, nil
175 } 175 }
176 176
  177 +func (repository *UserRepository) FindDepartmentUsers(ctx context.Context, conn transaction.Conn, companyId int64, queryOptions map[string]interface{}) (int64, []*domain.User, error) {
  178 + var (
  179 + tx = conn.DB()
  180 + ms []*models.User
  181 + dms = make([]*domain.User, 0)
  182 + total int64
  183 + )
  184 + queryFunc := func() (interface{}, error) {
  185 + tx = tx.Model(&ms).Order("id desc")
  186 + tx.Select("id", "name", "departments")
  187 + tx.Where("company_id = ?", companyId)
  188 + tx.Where("audit_status in (?)", domain.UserAuditStatusPassed)
  189 + tx.Where("enable = ?", domain.UserEnable)
  190 + if total, tx = transaction.PaginationAndCount(ctx, tx, queryOptions, &ms); tx.Error != nil {
  191 + return dms, tx.Error
  192 + }
  193 + return dms, nil
  194 + }
  195 +
  196 + if _, err := repository.Query(queryFunc); err != nil {
  197 + return 0, nil, err
  198 + }
  199 +
  200 + for _, item := range ms {
  201 + if dm, err := repository.ModelToDomainModel(item); err != nil {
  202 + return 0, dms, err
  203 + } else {
  204 + dms = append(dms, dm)
  205 + }
  206 + }
  207 + return total, dms, nil
  208 +}
  209 +
177 func (repository *UserRepository) ModelToDomainModel(from *models.User) (*domain.User, error) { 210 func (repository *UserRepository) ModelToDomainModel(from *models.User) (*domain.User, error) {
178 to := &domain.User{} 211 to := &domain.User{}
179 err := copier.Copy(to, from) 212 err := copier.Copy(to, from)
@@ -76,3 +76,15 @@ func LazyLoad[K comparable, T any](source map[K]T, ctx context.Context, conn tra @@ -76,3 +76,15 @@ func LazyLoad[K comparable, T any](source map[K]T, ctx context.Context, conn tra
76 return v, nil 76 return v, nil
77 } 77 }
78 } 78 }
  79 +
  80 +/*************** 索引函数 ****************/
  81 +func IndexCompanyId(companyId int64) IndexQueryOptionFunc {
  82 + return func() QueryOptions {
  83 + return NewQueryOptions().WithKV("companyId", companyId)
  84 + }
  85 +}
  86 +func IndexUserId(userId int64) IndexQueryOptionFunc {
  87 + return func() QueryOptions {
  88 + return NewQueryOptions().WithKV("userId", userId)
  89 + }
  90 +}
@@ -6,11 +6,12 @@ import ( @@ -6,11 +6,12 @@ import (
6 ) 6 )
7 7
8 type Role struct { 8 type Role struct {
9 - Id int64 `json:"id"` // 角色ID  
10 - Name string `json:"name"` // 角色名称  
11 - Auths []int64 `json:"auths"` // 角色权限列表  
12 - Remark string `json:"remark"` // 备注  
13 - Users []int64 `json:"users"` // 绑定的用户 9 + Id int64 `json:"id"` // 角色ID
  10 + CompanyId int64 `json:"companyId"` // 公司ID
  11 + Name string `json:"name"` // 角色名称
  12 + Auths []int64 `json:"auths"` // 角色权限列表
  13 + Remark string `json:"remark"` // 备注
  14 + Users []User `json:"users"` // 绑定的用户
14 15
15 CreatedAt int64 `json:"createdAt,omitempty"` 16 CreatedAt int64 `json:"createdAt,omitempty"`
16 UpdatedAt int64 `json:"updatedAt,omitempty"` 17 UpdatedAt int64 `json:"updatedAt,omitempty"`
@@ -33,3 +34,35 @@ func (m *Role) Identify() interface{} { @@ -33,3 +34,35 @@ func (m *Role) Identify() interface{} {
33 } 34 }
34 return m.Id 35 return m.Id
35 } 36 }
  37 +
  38 +func (m *Role) GetAuth(id int64) *Auth {
  39 + for _, auth := range Auths {
  40 + if auth.Id == id {
  41 + return &auth
  42 + }
  43 + }
  44 + return nil
  45 +}
  46 +
  47 +type Auth struct {
  48 + Id int64 `json:"id,omitempty"` // 菜单ID
  49 + ParentId int64 `json:"parentId"` // 父级ID
  50 + Name string `json:"name,omitempty"` // 菜单名称
  51 + Code string `json:"code,omitempty"` // 菜单编码
  52 +}
  53 +
  54 +var Auths = []Auth{
  55 + NewAuth(1001, "邀请注册", "MINI_INVITE-REGISTRATION", 0),
  56 + NewAuth(1002, "帖子定性", "SYSTEM_POST-JUDGMENT", 0),
  57 + //NewAuth(1003, "圆桌判定", "SYSTEM_STUDENT-MANAGE", 0),
  58 + //NewAuth(1004, "圆桌运营", "SYSTEM_FEEDBACK-MANAGE", 0),
  59 +}
  60 +
  61 +func NewAuth(id int64, name, code string, pid int64) Auth {
  62 + return Auth{
  63 + Id: id,
  64 + Name: name,
  65 + Code: code,
  66 + ParentId: pid,
  67 + }
  68 +}
@@ -37,6 +37,7 @@ type UserRepository interface { @@ -37,6 +37,7 @@ type UserRepository interface {
37 FindOne(ctx context.Context, conn transaction.Conn, id int64) (*User, error) 37 FindOne(ctx context.Context, conn transaction.Conn, id int64) (*User, error)
38 FindOneByCompanyIdAndPhone(ctx context.Context, conn transaction.Conn, companyId int64, phone string, status []int) (*User, error) 38 FindOneByCompanyIdAndPhone(ctx context.Context, conn transaction.Conn, companyId int64, phone string, status []int) (*User, error)
39 Find(ctx context.Context, conn transaction.Conn, queryOptions map[string]interface{}) (int64, []*User, error) 39 Find(ctx context.Context, conn transaction.Conn, queryOptions map[string]interface{}) (int64, []*User, error)
  40 + FindDepartmentUsers(ctx context.Context, conn transaction.Conn, companyId int64, queryOptions map[string]interface{}) (int64, []*User, error)
40 } 41 }
41 42
42 func (m *User) Identify() interface{} { 43 func (m *User) Identify() interface{} {
@@ -85,6 +86,7 @@ func (m *User) Audit(status int) error { @@ -85,6 +86,7 @@ func (m *User) Audit(status int) error {
85 return nil 86 return nil
86 } 87 }
87 88
  89 +// Follow 关注
88 func (m *User) Follow(targetUser *User) error { 90 func (m *User) Follow(targetUser *User) error {
89 if lo.Contains(m.Following, targetUser.Id) { 91 if lo.Contains(m.Following, targetUser.Id) {
90 return fmt.Errorf("已关注用户%v", targetUser.Name) 92 return fmt.Errorf("已关注用户%v", targetUser.Name)
@@ -96,12 +98,29 @@ func (m *User) Follow(targetUser *User) error { @@ -96,12 +98,29 @@ func (m *User) Follow(targetUser *User) error {
96 return nil 98 return nil
97 } 99 }
98 100
  101 +// Unfollow 取消关注
99 func (m *User) Unfollow(targetUser *User) error { 102 func (m *User) Unfollow(targetUser *User) error {
100 m.Following = lo.Without(m.Following, targetUser.Id) 103 m.Following = lo.Without(m.Following, targetUser.Id)
101 targetUser.Follower = lo.Without(targetUser.Follower, m.Id) 104 targetUser.Follower = lo.Without(targetUser.Follower, m.Id)
102 return nil 105 return nil
103 } 106 }
104 107
  108 +// AddRole 添加角色
  109 +func (m *User) AddRole(roleId int64) {
  110 + if lo.Contains(m.Roles, roleId) {
  111 + return
  112 + }
  113 + m.Roles = append(m.Roles, roleId)
  114 +}
  115 +
  116 +// RemoveRole 移除角色
  117 +func (m *User) RemoveRole(roleId int64) {
  118 + if !lo.Contains(m.Roles, roleId) {
  119 + return
  120 + }
  121 + m.Roles = lo.Without(m.Roles, roleId)
  122 +}
  123 +
105 type ( 124 type (
106 LoginCreator interface { 125 LoginCreator interface {
107 WechatLogin(r WechatLoginRequest) (*LoginInfo, error) 126 WechatLogin(r WechatLoginRequest) (*LoginInfo, error)