create-young-proj 0.0.1 → 0.1.1
Sign up to get free protection for your applications and to get access to all the features.
- package/LICENSE +21 -21
- package/README.md +13 -2
- package/dist/index.mjs +18 -18
- package/index.mjs +3 -3
- package/package.json +10 -12
- package/template-admin-server/.editorconfig +11 -0
- package/template-admin-server/.nvmrc +1 -0
- package/template-admin-server/.vscode/extensions.json +6 -0
- package/template-admin-server/.vscode/settings.json +4 -0
- package/template-admin-server/README.md +73 -0
- package/template-admin-server/_gitignore +15 -0
- package/template-admin-server/boot.mjs +11 -0
- package/template-admin-server/package.json +60 -0
- package/template-admin-server/rome.json +22 -0
- package/template-admin-server/src/config/config.default.ts +56 -0
- package/template-admin-server/src/configuration.ts +47 -0
- package/template-admin-server/src/controller/admin.controller.ts +397 -0
- package/template-admin-server/src/controller/api.controller.ts +98 -0
- package/template-admin-server/src/controller/base.controller.ts +70 -0
- package/template-admin-server/src/controller/dto/api.ts +47 -0
- package/template-admin-server/src/controller/dto/index.ts +36 -0
- package/template-admin-server/src/controller/dto/menu.ts +41 -0
- package/template-admin-server/src/controller/dto/role.ts +41 -0
- package/template-admin-server/src/controller/dto/user.ts +52 -0
- package/template-admin-server/src/controller/menu.controller.ts +138 -0
- package/template-admin-server/src/controller/role.controller.ts +116 -0
- package/template-admin-server/src/controller/user.controller.ts +108 -0
- package/template-admin-server/src/entities/Api.ts +29 -0
- package/template-admin-server/src/entities/BaseCreate.ts +30 -0
- package/template-admin-server/src/entities/Menu.ts +39 -0
- package/template-admin-server/src/entities/Role.ts +36 -0
- package/template-admin-server/src/entities/User.ts +35 -0
- package/template-admin-server/src/entities/index.ts +10 -0
- package/template-admin-server/src/filter/default.filter.ts +22 -0
- package/template-admin-server/src/filter/notfound.filter.ts +23 -0
- package/template-admin-server/src/middleware/helper.middleware.ts +28 -0
- package/template-admin-server/src/middleware/index.ts +9 -0
- package/template-admin-server/src/middleware/jwt.middleware.ts +32 -0
- package/template-admin-server/src/middleware/report.middleware.ts +26 -0
- package/template-admin-server/src/service/api.service.ts +174 -0
- package/template-admin-server/src/service/basic.ts +118 -0
- package/template-admin-server/src/service/index.ts +10 -0
- package/template-admin-server/src/service/menu.service.ts +139 -0
- package/template-admin-server/src/service/role.service.ts +286 -0
- package/template-admin-server/src/service/user.service.ts +124 -0
- package/template-admin-server/src/strategy/jwt.strategy.ts +26 -0
- package/template-admin-server/src/types/index.ts +42 -0
- package/template-admin-server/src/types/types.d.ts +31 -0
- package/template-admin-server/tsconfig.json +24 -0
- package/template-vue-admin/.vscode/extensions.json +10 -0
- package/template-vue-admin/.vscode/list-add.code-snippets +108 -0
- package/template-vue-admin/.vscode/list-export.code-snippets +72 -0
- package/template-vue-admin/.vscode/list.code-snippets +61 -0
- package/template-vue-admin/.vscode/settings.json +7 -0
- package/template-vue-admin/Dockerfile +42 -0
- package/template-vue-admin/README.md +75 -0
- package/template-vue-admin/_env +8 -0
- package/template-vue-admin/_gitignore +30 -0
- package/template-vue-admin/boot.mjs +16 -0
- package/template-vue-admin/build/custom-plugin.ts +30 -0
- package/template-vue-admin/build/index.ts +7 -0
- package/template-vue-admin/build/plugins.ts +59 -0
- package/template-vue-admin/config/.devrc +2 -0
- package/template-vue-admin/config/.onlinerc +2 -0
- package/template-vue-admin/config/.testrc +2 -0
- package/template-vue-admin/index.html +21 -0
- package/template-vue-admin/nitro.config.ts +19 -0
- package/template-vue-admin/package.json +50 -0
- package/template-vue-admin/plugins/env.ts +26 -0
- package/template-vue-admin/public/vite.svg +1 -0
- package/template-vue-admin/rome.json +26 -0
- package/template-vue-admin/routes/api/[...all].ts +49 -0
- package/template-vue-admin/routes/get/env.ts +18 -0
- package/template-vue-admin/src/App.vue +14 -0
- package/template-vue-admin/src/apis/delete.ts +36 -0
- package/template-vue-admin/src/apis/get.ts +84 -0
- package/template-vue-admin/src/apis/index.ts +10 -0
- package/template-vue-admin/src/apis/patch.ts +79 -0
- package/template-vue-admin/src/apis/post.ts +77 -0
- package/template-vue-admin/src/assets/img/login_background.jpg +0 -0
- package/template-vue-admin/src/auto-components.d.ts +36 -0
- package/template-vue-admin/src/auto-imports.d.ts +282 -0
- package/template-vue-admin/src/layouts/blank.vue +9 -0
- package/template-vue-admin/src/layouts/default/components/Link.vue +23 -0
- package/template-vue-admin/src/layouts/default/components/Logo.vue +20 -0
- package/template-vue-admin/src/layouts/default/components/Menu.vue +54 -0
- package/template-vue-admin/src/layouts/default/components/NavSearch.vue +52 -0
- package/template-vue-admin/src/layouts/default/components/ScrollPane.vue +79 -0
- package/template-vue-admin/src/layouts/default/components/TagsView.vue +137 -0
- package/template-vue-admin/src/layouts/default/components/TopMenu.vue +21 -0
- package/template-vue-admin/src/layouts/default/components/UserCenter.vue +50 -0
- package/template-vue-admin/src/layouts/default/index.vue +95 -0
- package/template-vue-admin/src/main.ts +44 -0
- package/template-vue-admin/src/modules/1-router.ts +66 -0
- package/template-vue-admin/src/modules/2-pinia.ts +10 -0
- package/template-vue-admin/src/modules/3-net.ts +75 -0
- package/template-vue-admin/src/modules/4-auth.ts +126 -0
- package/template-vue-admin/src/shims.d.ts +12 -0
- package/template-vue-admin/src/stores/index.ts +9 -0
- package/template-vue-admin/src/stores/local/index.ts +23 -0
- package/template-vue-admin/src/stores/session/index.ts +63 -0
- package/template-vue-admin/src/stores/tags.ts +109 -0
- package/template-vue-admin/src/typings/global.d.ts +70 -0
- package/template-vue-admin/src/typings/index.ts +50 -0
- package/template-vue-admin/src/views/403.vue +32 -0
- package/template-vue-admin/src/views/[...all_404].vue +556 -0
- package/template-vue-admin/src/views/base/login.vue +193 -0
- package/template-vue-admin/src/views/dashboard/[name].vue +23 -0
- package/template-vue-admin/src/views/index.vue +19 -0
- package/template-vue-admin/src/views/system/api.vue +161 -0
- package/template-vue-admin/src/views/system/hooks/useRole.ts +286 -0
- package/template-vue-admin/src/views/system/menuList.vue +195 -0
- package/template-vue-admin/src/views/system/role.vue +132 -0
- package/template-vue-admin/src/views/system/user.vue +193 -0
- package/template-vue-admin/src/vite-env.d.ts +52 -0
- package/template-vue-admin/tsconfig.json +21 -0
- package/template-vue-admin/tsconfig.node.json +9 -0
- package/template-vue-admin/unocss.config.ts +47 -0
- package/template-vue-admin/vite.config.ts +32 -0
- package/template-vue-thin/package.json +14 -13
- package/template-vue-thin/vite.config.ts +1 -6
@@ -0,0 +1,47 @@
|
|
1
|
+
/*
|
2
|
+
* @Author: zhangyang
|
3
|
+
* @Date: 2022-12-28 16:13:54
|
4
|
+
* @LastEditTime: 2022-12-28 17:43:26
|
5
|
+
* @Description:
|
6
|
+
*/
|
7
|
+
import { Rule, RuleType } from '@midwayjs/validate';
|
8
|
+
import { QueryDTO } from '.';
|
9
|
+
|
10
|
+
export class ApiQueryDTO extends QueryDTO {
|
11
|
+
@Rule(RuleType.string().optional().allow(''))
|
12
|
+
path: string;
|
13
|
+
}
|
14
|
+
|
15
|
+
export class ApiCreateDTO {
|
16
|
+
@Rule(RuleType.string().required())
|
17
|
+
category: string;
|
18
|
+
|
19
|
+
@Rule(RuleType.string().required())
|
20
|
+
desc: string;
|
21
|
+
|
22
|
+
@Rule(RuleType.string().required())
|
23
|
+
method: string;
|
24
|
+
|
25
|
+
@Rule(RuleType.string().required())
|
26
|
+
path: string;
|
27
|
+
|
28
|
+
@Rule(RuleType.array<number>().default([]))
|
29
|
+
roleIds: number[];
|
30
|
+
}
|
31
|
+
|
32
|
+
export class ApiUpdateDTO {
|
33
|
+
@Rule(RuleType.string().optional().allow(''))
|
34
|
+
category: string;
|
35
|
+
|
36
|
+
@Rule(RuleType.string().optional().allow(''))
|
37
|
+
desc: string;
|
38
|
+
|
39
|
+
@Rule(RuleType.string().optional().allow(''))
|
40
|
+
method: string;
|
41
|
+
|
42
|
+
@Rule(RuleType.string().optional().allow(''))
|
43
|
+
path: string;
|
44
|
+
|
45
|
+
@Rule(RuleType.array<number>().default([]))
|
46
|
+
roleIds: number[];
|
47
|
+
}
|
@@ -0,0 +1,36 @@
|
|
1
|
+
/*
|
2
|
+
* @Author: zhangyang
|
3
|
+
* @Date: 2022-12-27 14:56:04
|
4
|
+
* @LastEditTime: 2023-01-06 17:17:09
|
5
|
+
* @Description:
|
6
|
+
*/
|
7
|
+
import { Rule, RuleType } from '@midwayjs/validate';
|
8
|
+
export class QueryDTO {
|
9
|
+
@Rule(RuleType.number().default(1))
|
10
|
+
pageNum: number;
|
11
|
+
|
12
|
+
@Rule(RuleType.number().default(10))
|
13
|
+
pageSize: number;
|
14
|
+
|
15
|
+
@Rule(RuleType.number().optional().default(0))
|
16
|
+
total: number;
|
17
|
+
|
18
|
+
@Rule(RuleType.number().optional().allow(''))
|
19
|
+
status: number;
|
20
|
+
|
21
|
+
@Rule(RuleType.boolean().default(false))
|
22
|
+
noPagination: boolean;
|
23
|
+
}
|
24
|
+
|
25
|
+
export class DiffDTO {
|
26
|
+
@Rule(RuleType.array<number>().default([]))
|
27
|
+
create: number[];
|
28
|
+
|
29
|
+
@Rule(RuleType.array<number>().default([]))
|
30
|
+
delete: number[];
|
31
|
+
}
|
32
|
+
|
33
|
+
export * from './user';
|
34
|
+
export * from './role';
|
35
|
+
export * from './api';
|
36
|
+
export * from './menu';
|
@@ -0,0 +1,41 @@
|
|
1
|
+
/*
|
2
|
+
* @Author: zhangyang
|
3
|
+
* @Date: 2022-12-29 11:13:21
|
4
|
+
* @LastEditTime: 2022-12-29 11:53:07
|
5
|
+
* @Description:
|
6
|
+
*/
|
7
|
+
import { Rule, RuleType } from '@midwayjs/validate';
|
8
|
+
|
9
|
+
export class MenuCreateDTO {
|
10
|
+
@Rule(RuleType.number().optional().default(0))
|
11
|
+
parentId: number;
|
12
|
+
|
13
|
+
@Rule(RuleType.string().required())
|
14
|
+
name: string;
|
15
|
+
|
16
|
+
@Rule(RuleType.string().required())
|
17
|
+
title: string;
|
18
|
+
|
19
|
+
@Rule(RuleType.string().optional().allow(''))
|
20
|
+
icon: string;
|
21
|
+
|
22
|
+
@Rule(RuleType.number().optional().default(0))
|
23
|
+
sort: number;
|
24
|
+
|
25
|
+
@Rule(RuleType.string().required().allow(''))
|
26
|
+
component: string;
|
27
|
+
}
|
28
|
+
|
29
|
+
export class MenuUpdateDTO extends MenuCreateDTO {
|
30
|
+
@Rule(RuleType.number().optional().allow(''))
|
31
|
+
parentId: number;
|
32
|
+
|
33
|
+
@Rule(RuleType.number().optional().allow(''))
|
34
|
+
visible: number;
|
35
|
+
|
36
|
+
@Rule(RuleType.number().optional().allow(''))
|
37
|
+
sort: number;
|
38
|
+
|
39
|
+
@Rule(RuleType.number().optional().allow(''))
|
40
|
+
status: number;
|
41
|
+
}
|
@@ -0,0 +1,41 @@
|
|
1
|
+
/*
|
2
|
+
* @Author: zhangyang
|
3
|
+
* @Date: 2022-12-28 16:13:54
|
4
|
+
* @LastEditTime: 2022-12-28 16:44:28
|
5
|
+
* @Description:
|
6
|
+
*/
|
7
|
+
import { Rule, RuleType } from '@midwayjs/validate';
|
8
|
+
import { QueryDTO } from '.';
|
9
|
+
|
10
|
+
export class RoleQueryDTO extends QueryDTO {
|
11
|
+
@Rule(RuleType.string().optional().allow(''))
|
12
|
+
name: string;
|
13
|
+
|
14
|
+
@Rule(RuleType.string().optional().allow(''))
|
15
|
+
keyword: string;
|
16
|
+
}
|
17
|
+
|
18
|
+
export class RoleCreateDTO {
|
19
|
+
@Rule(RuleType.string().required())
|
20
|
+
name: string;
|
21
|
+
|
22
|
+
@Rule(RuleType.string().required())
|
23
|
+
keyword: string;
|
24
|
+
|
25
|
+
@Rule(RuleType.string().optional().allow(''))
|
26
|
+
desc: string;
|
27
|
+
|
28
|
+
@Rule(RuleType.number().default(1).optional().allow(''))
|
29
|
+
status: number;
|
30
|
+
|
31
|
+
@Rule(RuleType.number().default(0).optional().allow(''))
|
32
|
+
sort: number;
|
33
|
+
}
|
34
|
+
|
35
|
+
export class RoleUpdateDTO extends RoleCreateDTO {
|
36
|
+
@Rule(RuleType.string().optional().allow(''))
|
37
|
+
name: string;
|
38
|
+
|
39
|
+
@Rule(RuleType.string().optional().allow(''))
|
40
|
+
keyword: string;
|
41
|
+
}
|
@@ -0,0 +1,52 @@
|
|
1
|
+
/*
|
2
|
+
* @Author: zhangyang
|
3
|
+
* @Date: 2022-12-27 14:53:51
|
4
|
+
* @LastEditTime: 2023-01-09 14:15:20
|
5
|
+
* @Description:
|
6
|
+
*/
|
7
|
+
import { OmitDto, Rule, RuleType } from '@midwayjs/validate';
|
8
|
+
import { QueryDTO } from '.';
|
9
|
+
|
10
|
+
export class UserLoginDTO {
|
11
|
+
@Rule(RuleType.string().required())
|
12
|
+
username: string;
|
13
|
+
|
14
|
+
@Rule(RuleType.string().required())
|
15
|
+
password: string;
|
16
|
+
}
|
17
|
+
|
18
|
+
export class UserCreateDTO {
|
19
|
+
@Rule(RuleType.number().required())
|
20
|
+
roleId: number;
|
21
|
+
|
22
|
+
@Rule(RuleType.string().required())
|
23
|
+
username: string;
|
24
|
+
|
25
|
+
@Rule(RuleType.string().optional().allow(''))
|
26
|
+
nickname: string;
|
27
|
+
|
28
|
+
@Rule(RuleType.string().required())
|
29
|
+
initPassword: string;
|
30
|
+
|
31
|
+
@Rule(RuleType.string().length(11).required())
|
32
|
+
mobile: string;
|
33
|
+
}
|
34
|
+
|
35
|
+
export class UserUpdateDTO extends OmitDto(UserCreateDTO, ['initPassword']) {
|
36
|
+
@Rule(RuleType.number().optional().allow(''))
|
37
|
+
roleId: number;
|
38
|
+
|
39
|
+
@Rule(RuleType.string().optional().allow(''))
|
40
|
+
newPassword: string;
|
41
|
+
|
42
|
+
@Rule(RuleType.number().optional().allow(''))
|
43
|
+
status: number;
|
44
|
+
}
|
45
|
+
|
46
|
+
export class UserQueryDTO extends QueryDTO {
|
47
|
+
@Rule(RuleType.string().optional().allow(''))
|
48
|
+
username: string;
|
49
|
+
|
50
|
+
@Rule(RuleType.string().optional().allow(''))
|
51
|
+
mobile: string;
|
52
|
+
}
|
@@ -0,0 +1,138 @@
|
|
1
|
+
/*
|
2
|
+
* @Author: zhangyang
|
3
|
+
* @Date: 2022-12-29 11:10:38
|
4
|
+
* @LastEditTime: 2023-01-06 16:53:43
|
5
|
+
* @Description:
|
6
|
+
*/
|
7
|
+
import { Inject, Controller, Get, Post, Body, Patch, Del, Param } from '@midwayjs/decorator';
|
8
|
+
import { Context } from '@midwayjs/koa';
|
9
|
+
import { Validate } from '@midwayjs/validate';
|
10
|
+
import { MenuService, RoleService, UserService } from '../service';
|
11
|
+
import * as dayjs from 'dayjs';
|
12
|
+
import { MenuCreateDTO, MenuUpdateDTO } from './dto';
|
13
|
+
import { CacheManager } from '@midwayjs/cache';
|
14
|
+
import { Menu } from '../entities/index';
|
15
|
+
|
16
|
+
@Controller('/menu')
|
17
|
+
export class MenuController {
|
18
|
+
@Inject()
|
19
|
+
ctx: Context;
|
20
|
+
|
21
|
+
@Inject()
|
22
|
+
cacheManager: CacheManager;
|
23
|
+
|
24
|
+
@Inject()
|
25
|
+
menuService: MenuService;
|
26
|
+
|
27
|
+
@Inject()
|
28
|
+
userService: UserService;
|
29
|
+
|
30
|
+
@Inject()
|
31
|
+
roleService: RoleService;
|
32
|
+
|
33
|
+
@Get('/list')
|
34
|
+
@Validate()
|
35
|
+
async getMenuTree() {
|
36
|
+
const data = await this.menuService.getAllTree();
|
37
|
+
return this.ctx.helper.success({ data });
|
38
|
+
}
|
39
|
+
|
40
|
+
@Post('/create')
|
41
|
+
@Validate()
|
42
|
+
async createMenu(@Body() form: MenuCreateDTO) {
|
43
|
+
const { parentId: pid = 0, name = '', title = '', icon = 'store', sort = 0, component } = form;
|
44
|
+
|
45
|
+
if (component && !component.startsWith('/')) {
|
46
|
+
return this.ctx.helper.fail({ msg: '路径不合法' });
|
47
|
+
}
|
48
|
+
|
49
|
+
const { username, nickname } = this.ctx.state.user;
|
50
|
+
|
51
|
+
try {
|
52
|
+
await this.menuService.create({
|
53
|
+
name,
|
54
|
+
title,
|
55
|
+
icon,
|
56
|
+
sort,
|
57
|
+
component,
|
58
|
+
pid: Number(pid),
|
59
|
+
creator: nickname || username,
|
60
|
+
});
|
61
|
+
return this.ctx.helper.success();
|
62
|
+
} catch (error) {
|
63
|
+
return this.ctx.helper.fail({ msg: (error as Error).message });
|
64
|
+
}
|
65
|
+
}
|
66
|
+
|
67
|
+
@Get('/tree')
|
68
|
+
async getSelfMenuTree() {
|
69
|
+
const { username } = this.ctx.state.user;
|
70
|
+
const cacheKey = `${username}.menu.tree`;
|
71
|
+
|
72
|
+
const menus = await this.cacheManager.cache.get<Menu[]>(cacheKey);
|
73
|
+
if (menus) {
|
74
|
+
return this.ctx.helper.success({ data: menus });
|
75
|
+
}
|
76
|
+
|
77
|
+
const user = await this.userService.findOne({ username });
|
78
|
+
if (user) {
|
79
|
+
// @ts-expect-error
|
80
|
+
const id = user.roleId;
|
81
|
+
const role = await this.roleService.findOne({ id });
|
82
|
+
if (role) {
|
83
|
+
const menus = await this.roleService.getAccessMenusTree(role.id);
|
84
|
+
// 设置 1 分钟缓存
|
85
|
+
await this.cacheManager.set(cacheKey, menus, { ttl: 60 });
|
86
|
+
return this.ctx.helper.success({ data: menus });
|
87
|
+
} else {
|
88
|
+
return this.ctx.helper.fail({ msg: '角色不存在!' });
|
89
|
+
}
|
90
|
+
} else {
|
91
|
+
return this.ctx.helper.fail({ msg: '用户不存在!' });
|
92
|
+
}
|
93
|
+
}
|
94
|
+
|
95
|
+
@Patch('/update/:menuId')
|
96
|
+
async update(@Param('menuId') id: string, @Body() form: MenuUpdateDTO) {
|
97
|
+
const { parentId: pid, name, title, icon, sort, status, component, visible } = form;
|
98
|
+
|
99
|
+
try {
|
100
|
+
await this.menuService.update(Number(id), {
|
101
|
+
name,
|
102
|
+
title,
|
103
|
+
icon,
|
104
|
+
sort,
|
105
|
+
status,
|
106
|
+
component,
|
107
|
+
pid,
|
108
|
+
visible,
|
109
|
+
updateAt: dayjs(Date.now()).format('YYYY-MM-DD HH:mm:ss'),
|
110
|
+
});
|
111
|
+
return this.ctx.helper.success();
|
112
|
+
} catch (error) {
|
113
|
+
return this.ctx.helper.fail({ msg: (error as Error).message });
|
114
|
+
}
|
115
|
+
}
|
116
|
+
|
117
|
+
@Del('/delete/batch')
|
118
|
+
async del(@Body('ids') ids: string) {
|
119
|
+
try {
|
120
|
+
await this.menuService.deleteBatch(ids.split(',').map((i: string) => Number(i)));
|
121
|
+
return this.ctx.helper.success();
|
122
|
+
} catch (error) {
|
123
|
+
return this.ctx.helper.fail({ msg: (error as Error).message });
|
124
|
+
}
|
125
|
+
}
|
126
|
+
|
127
|
+
@Get('/all/:roleId')
|
128
|
+
async getRoleAccessMenus(@Param('roleId') roleId: number) {
|
129
|
+
const apis = await this.roleService.getAccessMenus(roleId);
|
130
|
+
const list = await this.menuService.getAllTree();
|
131
|
+
return this.ctx.helper.success({
|
132
|
+
data: {
|
133
|
+
accessIds: apis.map((i) => Number(i.id)),
|
134
|
+
list,
|
135
|
+
},
|
136
|
+
});
|
137
|
+
}
|
138
|
+
}
|
@@ -0,0 +1,116 @@
|
|
1
|
+
/*
|
2
|
+
* @Author: zhangyang
|
3
|
+
* @Date: 2022-12-27 11:23:39
|
4
|
+
* @LastEditTime: 2022-12-28 17:32:48
|
5
|
+
* @Description:
|
6
|
+
*/
|
7
|
+
import { Inject, Controller, Get, Query, Post, Body, Patch, Del, Param } from '@midwayjs/decorator';
|
8
|
+
import { Context } from '@midwayjs/koa';
|
9
|
+
import { Validate } from '@midwayjs/validate';
|
10
|
+
import { RoleService } from '../service';
|
11
|
+
import { DiffDTO, RoleCreateDTO, RoleQueryDTO, RoleUpdateDTO } from './dto';
|
12
|
+
import * as dayjs from 'dayjs';
|
13
|
+
|
14
|
+
@Controller('/role')
|
15
|
+
export class RoleController {
|
16
|
+
@Inject()
|
17
|
+
ctx: Context;
|
18
|
+
|
19
|
+
@Inject()
|
20
|
+
roleService: RoleService;
|
21
|
+
|
22
|
+
@Get('/list')
|
23
|
+
@Validate()
|
24
|
+
async getRoleList(@Query() query: RoleQueryDTO) {
|
25
|
+
const data = await this.roleService.findAll(query);
|
26
|
+
return this.ctx.helper.success({ data });
|
27
|
+
}
|
28
|
+
|
29
|
+
@Post('/create')
|
30
|
+
@Validate()
|
31
|
+
async createRole(@Body() form: RoleCreateDTO) {
|
32
|
+
const { name = '', keyword = '', desc = '', sort = 0, status = 1 } = form;
|
33
|
+
|
34
|
+
try {
|
35
|
+
const { username, nickname } = this.ctx.state.user;
|
36
|
+
await this.roleService.create({
|
37
|
+
name,
|
38
|
+
sort,
|
39
|
+
creator: nickname || username,
|
40
|
+
keyword,
|
41
|
+
status,
|
42
|
+
desc,
|
43
|
+
});
|
44
|
+
return this.ctx.helper.success();
|
45
|
+
} catch (error) {
|
46
|
+
return this.ctx.helper.fail({ msg: (error as Error).message });
|
47
|
+
}
|
48
|
+
}
|
49
|
+
|
50
|
+
@Patch('/update/:roleId')
|
51
|
+
async update(@Param('roleId') id: string, @Body() form: RoleUpdateDTO) {
|
52
|
+
const { name, keyword, desc, sort, status } = form;
|
53
|
+
|
54
|
+
try {
|
55
|
+
await this.roleService.update(Number(id), {
|
56
|
+
name,
|
57
|
+
keyword,
|
58
|
+
desc,
|
59
|
+
sort,
|
60
|
+
status,
|
61
|
+
updateAt: dayjs(Date.now()).format('YYYY-MM-DD HH:mm:ss'),
|
62
|
+
});
|
63
|
+
return this.ctx.helper.success();
|
64
|
+
} catch (error) {
|
65
|
+
return this.ctx.helper.fail({ msg: (error as Error).message });
|
66
|
+
}
|
67
|
+
}
|
68
|
+
|
69
|
+
@Patch('/menus/update/:roleId')
|
70
|
+
@Validate()
|
71
|
+
async changeRoleMenus(@Param('roleId') roleId: number, @Body() form: DiffDTO) {
|
72
|
+
const { create: add = [], delete: del = [] } = form;
|
73
|
+
try {
|
74
|
+
await this.roleService.addMenus(roleId, add);
|
75
|
+
await this.roleService.delMenus(roleId, del);
|
76
|
+
return this.ctx.helper.success({
|
77
|
+
data: {
|
78
|
+
roleId,
|
79
|
+
add,
|
80
|
+
del,
|
81
|
+
},
|
82
|
+
});
|
83
|
+
} catch (error) {
|
84
|
+
return this.ctx.helper.fail({ msg: (error as Error).message });
|
85
|
+
}
|
86
|
+
}
|
87
|
+
|
88
|
+
@Patch('/apis/update/:roleId')
|
89
|
+
@Validate()
|
90
|
+
async changeRoleApis(@Param('roleId') roleId: number, @Body() form: DiffDTO) {
|
91
|
+
const { create: add = [], delete: del = [] } = form;
|
92
|
+
try {
|
93
|
+
await this.roleService.addApis(roleId, add);
|
94
|
+
await this.roleService.delApis(roleId, del);
|
95
|
+
return this.ctx.helper.success({
|
96
|
+
data: {
|
97
|
+
roleId,
|
98
|
+
add,
|
99
|
+
del,
|
100
|
+
},
|
101
|
+
});
|
102
|
+
} catch (error) {
|
103
|
+
return this.ctx.helper.fail({ msg: (error as Error).message });
|
104
|
+
}
|
105
|
+
}
|
106
|
+
|
107
|
+
@Del('/delete/batch')
|
108
|
+
async del(@Body('ids') ids: string) {
|
109
|
+
try {
|
110
|
+
await this.roleService.deleteBatch(ids.split(',').map((i: string) => Number(i)));
|
111
|
+
return this.ctx.helper.success();
|
112
|
+
} catch (error) {
|
113
|
+
return this.ctx.helper.fail({ msg: (error as Error).message });
|
114
|
+
}
|
115
|
+
}
|
116
|
+
}
|
@@ -0,0 +1,108 @@
|
|
1
|
+
/*
|
2
|
+
* @Author: zhangyang
|
3
|
+
* @Date: 2022-12-27 11:23:39
|
4
|
+
* @LastEditTime: 2022-12-28 16:31:12
|
5
|
+
* @Description:
|
6
|
+
*/
|
7
|
+
import { Inject, Controller, Get, Query, Post, Body, Patch, Param, Del } from '@midwayjs/decorator';
|
8
|
+
import { Context } from '@midwayjs/koa';
|
9
|
+
import { Validate } from '@midwayjs/validate';
|
10
|
+
import * as dayjs from 'dayjs';
|
11
|
+
import * as md5 from 'md5';
|
12
|
+
import { type CreateUserItem, UserService } from '../service';
|
13
|
+
import { UserCreateDTO, UserQueryDTO, UserUpdateDTO } from './dto';
|
14
|
+
|
15
|
+
@Controller('/user')
|
16
|
+
export class UserController {
|
17
|
+
@Inject()
|
18
|
+
ctx: Context;
|
19
|
+
|
20
|
+
@Inject()
|
21
|
+
userService: UserService;
|
22
|
+
|
23
|
+
@Get('/list')
|
24
|
+
@Validate()
|
25
|
+
async getUserList(@Query() query: UserQueryDTO) {
|
26
|
+
const data = await this.userService.findAll(query);
|
27
|
+
return this.ctx.helper.success({ data });
|
28
|
+
}
|
29
|
+
|
30
|
+
@Post('/info')
|
31
|
+
async getUserInfo() {
|
32
|
+
const { username } = this.ctx.state.user;
|
33
|
+
|
34
|
+
const user = await this.userService.findOne({ username });
|
35
|
+
if (user) {
|
36
|
+
const data: CreateUserItem = {
|
37
|
+
...user,
|
38
|
+
};
|
39
|
+
delete data.password;
|
40
|
+
delete data.createdAt;
|
41
|
+
delete data.updateAt;
|
42
|
+
delete data.creator;
|
43
|
+
delete data.status;
|
44
|
+
delete data.sort;
|
45
|
+
// @ts-expect-error
|
46
|
+
delete data.roleId;
|
47
|
+
|
48
|
+
return this.ctx.helper.success({ data });
|
49
|
+
} else {
|
50
|
+
return this.ctx.helper.fail({ msg: '用户不存在!' });
|
51
|
+
}
|
52
|
+
}
|
53
|
+
|
54
|
+
@Post('/create')
|
55
|
+
@Validate()
|
56
|
+
async createUser(@Body() form: UserCreateDTO) {
|
57
|
+
const { roleId: rid, username, nickname = '', initPassword: pwd, mobile = '' } = form;
|
58
|
+
|
59
|
+
const key = this.ctx.app.getConfig('keys');
|
60
|
+
|
61
|
+
try {
|
62
|
+
const { username: u, nickname: n } = this.ctx.state.user;
|
63
|
+
await this.userService.create({
|
64
|
+
username,
|
65
|
+
nickname,
|
66
|
+
creator: n || u,
|
67
|
+
password: md5(`${key}${pwd}`),
|
68
|
+
mobile,
|
69
|
+
rid,
|
70
|
+
});
|
71
|
+
return this.ctx.helper.success();
|
72
|
+
} catch (error) {
|
73
|
+
return this.ctx.helper.fail({ msg: (error as Error).message });
|
74
|
+
}
|
75
|
+
}
|
76
|
+
|
77
|
+
@Patch('/update/:userId')
|
78
|
+
async update(@Param('userId') id: string, @Body() form: UserUpdateDTO) {
|
79
|
+
const { username, nickname, mobile, roleId: rid, status, newPassword } = form;
|
80
|
+
|
81
|
+
const key = this.ctx.app.getConfig('keys');
|
82
|
+
|
83
|
+
try {
|
84
|
+
await this.userService.update(Number(id), {
|
85
|
+
username,
|
86
|
+
nickname,
|
87
|
+
mobile,
|
88
|
+
rid,
|
89
|
+
status,
|
90
|
+
password: newPassword ? md5(`${key}${newPassword}`) : undefined,
|
91
|
+
updateAt: dayjs(Date.now()).format('YYYY-MM-DD HH:mm:ss'),
|
92
|
+
});
|
93
|
+
return this.ctx.helper.success();
|
94
|
+
} catch (error) {
|
95
|
+
return this.ctx.helper.fail({ msg: (error as Error).message });
|
96
|
+
}
|
97
|
+
}
|
98
|
+
|
99
|
+
@Del('/delete/batch')
|
100
|
+
async del(@Body('ids') ids: string) {
|
101
|
+
try {
|
102
|
+
await this.userService.deleteBatch(ids.split(',').map((i: string) => Number(i)));
|
103
|
+
return this.ctx.helper.success();
|
104
|
+
} catch (error) {
|
105
|
+
return this.ctx.helper.fail({ msg: (error as Error).message });
|
106
|
+
}
|
107
|
+
}
|
108
|
+
}
|
@@ -0,0 +1,29 @@
|
|
1
|
+
/*
|
2
|
+
* @Author: zhangyang
|
3
|
+
* @Date: 2022-12-26 14:02:31
|
4
|
+
* @LastEditTime: 2022-12-28 17:57:36
|
5
|
+
* @Description:
|
6
|
+
*/
|
7
|
+
import { Column, Entity, ManyToMany } from 'typeorm';
|
8
|
+
import { BaseCreate } from './BaseCreate';
|
9
|
+
import { Role } from './Role';
|
10
|
+
|
11
|
+
@Entity({
|
12
|
+
engine: 'InnoDB',
|
13
|
+
})
|
14
|
+
export class Api extends BaseCreate {
|
15
|
+
@Column({ length: '20' })
|
16
|
+
category!: string;
|
17
|
+
|
18
|
+
@Column({ length: '30', unique: true })
|
19
|
+
path!: string;
|
20
|
+
|
21
|
+
@Column({ length: '10' })
|
22
|
+
method!: string;
|
23
|
+
|
24
|
+
@Column({ length: '20', default: '' })
|
25
|
+
desc?: string;
|
26
|
+
|
27
|
+
@ManyToMany(() => Role, role => role.apis)
|
28
|
+
roles?: Role[];
|
29
|
+
}
|
@@ -0,0 +1,30 @@
|
|
1
|
+
/*
|
2
|
+
* @Author: zhangyang
|
3
|
+
* @Date: 2022-12-26 14:05:04
|
4
|
+
* @LastEditTime: 2023-01-06 17:16:52
|
5
|
+
* @Description:
|
6
|
+
*/
|
7
|
+
import { Column, PrimaryGeneratedColumn } from 'typeorm';
|
8
|
+
|
9
|
+
/**
|
10
|
+
* 基础表结构
|
11
|
+
*/
|
12
|
+
export abstract class BaseCreate {
|
13
|
+
@PrimaryGeneratedColumn({ type: 'bigint' })
|
14
|
+
id!: number;
|
15
|
+
|
16
|
+
@Column({ update: false, type: 'datetime', default: () => 'NOW()' })
|
17
|
+
createdAt?: string;
|
18
|
+
|
19
|
+
@Column({ type: 'datetime', default: () => 'NOW()' })
|
20
|
+
updateAt?: string;
|
21
|
+
|
22
|
+
@Column({ length: '20', default: '' })
|
23
|
+
creator?: string;
|
24
|
+
|
25
|
+
@Column({ type: 'tinyint', default: 1 })
|
26
|
+
status?: number | '';
|
27
|
+
|
28
|
+
@Column({ default: 0 })
|
29
|
+
sort?: number;
|
30
|
+
}
|
@@ -0,0 +1,39 @@
|
|
1
|
+
/*
|
2
|
+
* @Author: zhangyang
|
3
|
+
* @Date: 2022-12-26 14:12:16
|
4
|
+
* @LastEditTime: 2022-12-27 11:43:21
|
5
|
+
* @Description:
|
6
|
+
*/
|
7
|
+
import { Column, Entity, ManyToMany, Tree, TreeChildren, TreeParent } from 'typeorm';
|
8
|
+
import { BaseCreate } from './BaseCreate';
|
9
|
+
import { Role } from './Role';
|
10
|
+
|
11
|
+
@Entity({
|
12
|
+
engine: 'InnoDB',
|
13
|
+
})
|
14
|
+
@Tree('closure-table')
|
15
|
+
export class Menu extends BaseCreate {
|
16
|
+
@Column({ length: '20' })
|
17
|
+
name!: string;
|
18
|
+
|
19
|
+
@Column({ length: '20' })
|
20
|
+
title!: string;
|
21
|
+
|
22
|
+
@Column({ length: '30' })
|
23
|
+
component!: string;
|
24
|
+
|
25
|
+
@Column({ default: '' })
|
26
|
+
icon?: string;
|
27
|
+
|
28
|
+
@Column({ type: 'tinyint', default: 1 })
|
29
|
+
visible?: number;
|
30
|
+
|
31
|
+
@TreeParent()
|
32
|
+
parentId?: Menu;
|
33
|
+
|
34
|
+
@TreeChildren()
|
35
|
+
children?: Menu[];
|
36
|
+
|
37
|
+
@ManyToMany(() => Role, role => role.menus)
|
38
|
+
roles?: Role[];
|
39
|
+
}
|