create-young-proj 0.0.1 → 0.1.0
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/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 +122 -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 +77 -0
- package/template-vue-thin/package.json +14 -13
- package/template-vue-thin/vite.config.ts +1 -6
@@ -0,0 +1,22 @@
|
|
1
|
+
{
|
2
|
+
"formatter": {
|
3
|
+
"ignore": [
|
4
|
+
"dist/*",
|
5
|
+
"*.html",
|
6
|
+
"yarn.lock",
|
7
|
+
"*.json",
|
8
|
+
"*.md"
|
9
|
+
],
|
10
|
+
"indentStyle": "space",
|
11
|
+
"indentSize": 2,
|
12
|
+
"lineWidth": 100
|
13
|
+
},
|
14
|
+
"javascript": {
|
15
|
+
"formatter": {
|
16
|
+
"quoteStyle": "single"
|
17
|
+
}
|
18
|
+
},
|
19
|
+
"linter": {
|
20
|
+
"enabled": false
|
21
|
+
}
|
22
|
+
}
|
@@ -0,0 +1,56 @@
|
|
1
|
+
/*
|
2
|
+
* @Author: zhangyang
|
3
|
+
* @Date: 2022-12-27 10:56:45
|
4
|
+
* @LastEditTime: 2023-01-09 15:14:11
|
5
|
+
* @Description:
|
6
|
+
*/
|
7
|
+
import { MidwayAppInfo, MidwayConfig } from '@midwayjs/core';
|
8
|
+
import * as Entities from '../entities';
|
9
|
+
|
10
|
+
export default (appInfo: MidwayAppInfo): MidwayConfig => {
|
11
|
+
const SERCRET_KEY = 'bluesyoung_web';
|
12
|
+
return {
|
13
|
+
// 用于对 cookie 进行签名
|
14
|
+
keys: SERCRET_KEY,
|
15
|
+
koa: {
|
16
|
+
port: +process.env.LISTEN_PORT || 7001,
|
17
|
+
globalPrefix: '/api',
|
18
|
+
},
|
19
|
+
typeorm: {
|
20
|
+
dataSource: {
|
21
|
+
default: {
|
22
|
+
type: 'mysql',
|
23
|
+
// 以下为 MySQL 配置
|
24
|
+
username: 'root',
|
25
|
+
password: 'root',
|
26
|
+
port: 3306,
|
27
|
+
database: 'dev_music',
|
28
|
+
charset: 'utf8mb4',
|
29
|
+
// 生产环境,不同步数据库表结构
|
30
|
+
synchronize: process.env.NODE_ENV !== 'production',
|
31
|
+
logging: false,
|
32
|
+
entities: Object.values(Entities),
|
33
|
+
},
|
34
|
+
},
|
35
|
+
},
|
36
|
+
jwt: {
|
37
|
+
secret: SERCRET_KEY,
|
38
|
+
/**
|
39
|
+
* 过期时间,秒
|
40
|
+
*/
|
41
|
+
expiresIn: 60 * 60 * 24,
|
42
|
+
},
|
43
|
+
passport: {
|
44
|
+
/**
|
45
|
+
* 不序列化到 session
|
46
|
+
*/
|
47
|
+
session: false,
|
48
|
+
},
|
49
|
+
validate: {
|
50
|
+
validationOptions: {
|
51
|
+
// 允许传递未定义的参数
|
52
|
+
allowUnknown: true,
|
53
|
+
},
|
54
|
+
},
|
55
|
+
};
|
56
|
+
};
|
@@ -0,0 +1,47 @@
|
|
1
|
+
/*
|
2
|
+
* @Author: zhangyang
|
3
|
+
* @Date: 2022-12-27 11:02:18
|
4
|
+
* @LastEditTime: 2023-01-09 15:05:25
|
5
|
+
* @Description:
|
6
|
+
*/
|
7
|
+
import { Configuration, App } from '@midwayjs/decorator';
|
8
|
+
import * as koa from '@midwayjs/koa';
|
9
|
+
import * as validate from '@midwayjs/validate';
|
10
|
+
import * as info from '@midwayjs/info';
|
11
|
+
import * as orm from '@midwayjs/typeorm';
|
12
|
+
import * as passport from '@midwayjs/passport';
|
13
|
+
import * as jwt from '@midwayjs/jwt';
|
14
|
+
import * as cache from '@midwayjs/cache';
|
15
|
+
import { join } from 'path';
|
16
|
+
// import { DefaultErrorFilter } from './filter/default.filter';
|
17
|
+
// import { NotFoundFilter } from './filter/notfound.filter';
|
18
|
+
import { ReportMiddleware, HelperMiddleware, JwtPassportMiddleware } from './middleware';
|
19
|
+
|
20
|
+
@Configuration({
|
21
|
+
imports: [
|
22
|
+
koa,
|
23
|
+
orm,
|
24
|
+
jwt,
|
25
|
+
passport,
|
26
|
+
validate,
|
27
|
+
{
|
28
|
+
// 环境探测,类似于 php-info,仅 dev 模式启用
|
29
|
+
// 访问 /_info 可以查看
|
30
|
+
component: info,
|
31
|
+
enabledEnvironment: ['local'],
|
32
|
+
},
|
33
|
+
cache
|
34
|
+
],
|
35
|
+
importConfigs: [join(__dirname, './config')],
|
36
|
+
})
|
37
|
+
export class ContainerLifeCycle {
|
38
|
+
@App()
|
39
|
+
app: koa.Application;
|
40
|
+
|
41
|
+
async onReady() {
|
42
|
+
// add middleware
|
43
|
+
this.app.useMiddleware([ReportMiddleware, HelperMiddleware, JwtPassportMiddleware]);
|
44
|
+
// add filter
|
45
|
+
// this.app.useFilter([NotFoundFilter, DefaultErrorFilter]);
|
46
|
+
}
|
47
|
+
}
|
@@ -0,0 +1,397 @@
|
|
1
|
+
/*
|
2
|
+
* @Author: zhangyang
|
3
|
+
* @Date: 2022-12-27 15:15:30
|
4
|
+
* @LastEditTime: 2023-01-09 15:29:49
|
5
|
+
* @Description:
|
6
|
+
*/
|
7
|
+
import { Controller, Inject, Post } from '@midwayjs/decorator';
|
8
|
+
import { Context } from '@midwayjs/koa';
|
9
|
+
import * as md5 from 'md5';
|
10
|
+
import {
|
11
|
+
UserService,
|
12
|
+
ApiService,
|
13
|
+
RoleService,
|
14
|
+
MenuService,
|
15
|
+
CreateMenuItem,
|
16
|
+
CreateApiItem,
|
17
|
+
CreateRoleItem,
|
18
|
+
CreateUserItem,
|
19
|
+
} from '../service';
|
20
|
+
|
21
|
+
const creator = '系统自动创建';
|
22
|
+
const initMenu = async (ctx: Context, service: MenuService) => {
|
23
|
+
const defaultMenus: CreateMenuItem[] = [
|
24
|
+
{
|
25
|
+
id: 1,
|
26
|
+
name: 'dashboardRoot',
|
27
|
+
title: '首页根目录',
|
28
|
+
component: '',
|
29
|
+
creator,
|
30
|
+
icon: 'dashboard',
|
31
|
+
visible: 0,
|
32
|
+
},
|
33
|
+
{
|
34
|
+
id: 2,
|
35
|
+
name: 'systemRoot',
|
36
|
+
title: '系统设置根目录',
|
37
|
+
component: '',
|
38
|
+
creator,
|
39
|
+
icon: 'component',
|
40
|
+
},
|
41
|
+
{
|
42
|
+
id: 3,
|
43
|
+
name: 'system',
|
44
|
+
title: '系统设置',
|
45
|
+
component: '',
|
46
|
+
creator,
|
47
|
+
icon: 'component',
|
48
|
+
pid: 2,
|
49
|
+
},
|
50
|
+
{
|
51
|
+
id: 4,
|
52
|
+
name: 'dashboard',
|
53
|
+
title: '首页',
|
54
|
+
component: '/dashboard/index',
|
55
|
+
creator,
|
56
|
+
icon: 'dashboard',
|
57
|
+
pid: 1,
|
58
|
+
visible: 0,
|
59
|
+
},
|
60
|
+
{
|
61
|
+
id: 5,
|
62
|
+
name: 'menu',
|
63
|
+
title: '菜单管理',
|
64
|
+
component: '/system/menuList',
|
65
|
+
creator,
|
66
|
+
icon: 'tree-table',
|
67
|
+
pid: 3,
|
68
|
+
},
|
69
|
+
{
|
70
|
+
id: 6,
|
71
|
+
name: 'role',
|
72
|
+
title: '角色管理',
|
73
|
+
component: '/system/role',
|
74
|
+
creator,
|
75
|
+
icon: 'peoples',
|
76
|
+
pid: 3,
|
77
|
+
},
|
78
|
+
{
|
79
|
+
id: 7,
|
80
|
+
name: 'user',
|
81
|
+
title: '用户管理',
|
82
|
+
component: '/system/user',
|
83
|
+
creator,
|
84
|
+
icon: 'user',
|
85
|
+
pid: 3,
|
86
|
+
},
|
87
|
+
{
|
88
|
+
id: 8,
|
89
|
+
name: 'api',
|
90
|
+
title: '接口管理',
|
91
|
+
component: '/system/api',
|
92
|
+
creator,
|
93
|
+
icon: 'tree',
|
94
|
+
pid: 3,
|
95
|
+
},
|
96
|
+
];
|
97
|
+
|
98
|
+
await service.createBatch(defaultMenus);
|
99
|
+
ctx.logger.info('菜单初始化成功!');
|
100
|
+
};
|
101
|
+
|
102
|
+
const initApi = async (ctx: Context, service: ApiService) => {
|
103
|
+
const defaultApis: CreateApiItem[] = [
|
104
|
+
{
|
105
|
+
id: 1,
|
106
|
+
creator,
|
107
|
+
category: 'base',
|
108
|
+
path: '/base/login',
|
109
|
+
method: 'POST',
|
110
|
+
desc: '登录',
|
111
|
+
},
|
112
|
+
{
|
113
|
+
id: 2,
|
114
|
+
creator,
|
115
|
+
category: 'base',
|
116
|
+
path: '/base/logout',
|
117
|
+
method: 'POST',
|
118
|
+
desc: '退出登录',
|
119
|
+
},
|
120
|
+
{
|
121
|
+
id: 3,
|
122
|
+
creator,
|
123
|
+
category: 'user',
|
124
|
+
path: '/user/info',
|
125
|
+
method: 'POST',
|
126
|
+
desc: '获取当前用户信息',
|
127
|
+
},
|
128
|
+
{
|
129
|
+
id: 4,
|
130
|
+
creator,
|
131
|
+
category: 'user',
|
132
|
+
path: '/user/list',
|
133
|
+
method: 'GET',
|
134
|
+
desc: '获取用户列表',
|
135
|
+
},
|
136
|
+
{
|
137
|
+
id: 5,
|
138
|
+
creator,
|
139
|
+
category: 'user',
|
140
|
+
path: '/user/changePwd',
|
141
|
+
method: 'PUT',
|
142
|
+
desc: '修改登录密码',
|
143
|
+
},
|
144
|
+
{
|
145
|
+
id: 6,
|
146
|
+
creator,
|
147
|
+
category: 'user',
|
148
|
+
path: '/user/create',
|
149
|
+
method: 'POST',
|
150
|
+
desc: '创建用户',
|
151
|
+
},
|
152
|
+
{
|
153
|
+
id: 7,
|
154
|
+
creator,
|
155
|
+
category: 'user',
|
156
|
+
path: '/user/update/:userId',
|
157
|
+
method: 'PATCH',
|
158
|
+
desc: '修改用户信息',
|
159
|
+
},
|
160
|
+
{
|
161
|
+
id: 8,
|
162
|
+
creator,
|
163
|
+
category: 'user',
|
164
|
+
path: '/user/delete/batch',
|
165
|
+
method: 'DELETE',
|
166
|
+
desc: '批量删除用户',
|
167
|
+
},
|
168
|
+
{
|
169
|
+
id: 9,
|
170
|
+
creator,
|
171
|
+
category: 'menu',
|
172
|
+
path: '/menu/tree',
|
173
|
+
method: 'GET',
|
174
|
+
desc: '获取当前用户菜单',
|
175
|
+
},
|
176
|
+
{
|
177
|
+
id: 10,
|
178
|
+
creator,
|
179
|
+
category: 'menu',
|
180
|
+
path: '/menu/list',
|
181
|
+
method: 'GET',
|
182
|
+
desc: '获取菜单列表',
|
183
|
+
},
|
184
|
+
{
|
185
|
+
id: 11,
|
186
|
+
creator,
|
187
|
+
category: 'menu',
|
188
|
+
path: '/menu/all/:roleId',
|
189
|
+
method: 'GET',
|
190
|
+
desc: '获取指定角色的菜单列表',
|
191
|
+
},
|
192
|
+
{
|
193
|
+
id: 12,
|
194
|
+
creator,
|
195
|
+
category: 'menu',
|
196
|
+
path: '/menu/create',
|
197
|
+
method: 'POST',
|
198
|
+
desc: '创建菜单',
|
199
|
+
},
|
200
|
+
{
|
201
|
+
id: 13,
|
202
|
+
creator,
|
203
|
+
category: 'menu',
|
204
|
+
path: '/menu/update/:menuId',
|
205
|
+
method: 'PATCH',
|
206
|
+
desc: '修改菜单信息',
|
207
|
+
},
|
208
|
+
{
|
209
|
+
id: 14,
|
210
|
+
creator,
|
211
|
+
category: 'menu',
|
212
|
+
path: '/menu/delete/batch',
|
213
|
+
method: 'DELETE',
|
214
|
+
desc: '批量删除菜单',
|
215
|
+
},
|
216
|
+
{
|
217
|
+
id: 15,
|
218
|
+
creator,
|
219
|
+
category: 'role',
|
220
|
+
path: '/role/list',
|
221
|
+
method: 'GET',
|
222
|
+
desc: '获取角色列表',
|
223
|
+
},
|
224
|
+
{
|
225
|
+
id: 16,
|
226
|
+
creator,
|
227
|
+
category: 'role',
|
228
|
+
path: '/role/create',
|
229
|
+
method: 'POST',
|
230
|
+
desc: '创建角色',
|
231
|
+
},
|
232
|
+
{
|
233
|
+
id: 17,
|
234
|
+
creator,
|
235
|
+
category: 'role',
|
236
|
+
path: '/role/update/:roleId',
|
237
|
+
method: 'PATCH',
|
238
|
+
desc: '修改角色信息',
|
239
|
+
},
|
240
|
+
{
|
241
|
+
id: 18,
|
242
|
+
creator,
|
243
|
+
category: 'role',
|
244
|
+
path: '/role/menus/update/:roleId',
|
245
|
+
method: 'PATCH',
|
246
|
+
desc: '修改角色的菜单列表',
|
247
|
+
},
|
248
|
+
{
|
249
|
+
id: 19,
|
250
|
+
creator,
|
251
|
+
category: 'role',
|
252
|
+
path: '/role/apis/update/:roleId',
|
253
|
+
method: 'PATCH',
|
254
|
+
desc: '修改角色的接口列表',
|
255
|
+
},
|
256
|
+
{
|
257
|
+
id: 20,
|
258
|
+
creator,
|
259
|
+
category: 'role',
|
260
|
+
path: '/role/delete/batch',
|
261
|
+
method: 'DELETE',
|
262
|
+
desc: '批量删除角色',
|
263
|
+
},
|
264
|
+
{
|
265
|
+
id: 21,
|
266
|
+
creator,
|
267
|
+
category: 'api',
|
268
|
+
path: '/api/list',
|
269
|
+
method: 'GET',
|
270
|
+
desc: '获取接口列表',
|
271
|
+
},
|
272
|
+
{
|
273
|
+
id: 22,
|
274
|
+
creator,
|
275
|
+
category: 'api',
|
276
|
+
path: '/api/all/category/:roleId',
|
277
|
+
method: 'GET',
|
278
|
+
desc: '获取指定角色的接口列表(以类分组)',
|
279
|
+
},
|
280
|
+
{
|
281
|
+
id: 23,
|
282
|
+
creator,
|
283
|
+
category: 'api',
|
284
|
+
path: '/api/create',
|
285
|
+
method: 'POST',
|
286
|
+
desc: '创建接口',
|
287
|
+
},
|
288
|
+
{
|
289
|
+
id: 24,
|
290
|
+
creator,
|
291
|
+
category: 'api',
|
292
|
+
path: '/api/update/:apiId',
|
293
|
+
method: 'PATCH',
|
294
|
+
desc: '修改接口信息',
|
295
|
+
},
|
296
|
+
{
|
297
|
+
id: 25,
|
298
|
+
creator,
|
299
|
+
category: 'api',
|
300
|
+
path: '/api/delete/batch',
|
301
|
+
method: 'DELETE',
|
302
|
+
desc: '批量删除接口',
|
303
|
+
},
|
304
|
+
];
|
305
|
+
|
306
|
+
await service.createBatch(defaultApis);
|
307
|
+
ctx.logger.info('接口初始化成功!');
|
308
|
+
};
|
309
|
+
|
310
|
+
const initRole = async (ctx: Context, service: RoleService) => {
|
311
|
+
const defaultRoles: CreateRoleItem[] = [
|
312
|
+
{
|
313
|
+
id: 1,
|
314
|
+
creator,
|
315
|
+
name: '超级管理员',
|
316
|
+
keyword: 'super',
|
317
|
+
desc: '超管',
|
318
|
+
aid: new Array(25).fill(0).map((_, i) => i + 1),
|
319
|
+
mid: new Array(8).fill(0).map((_, i) => i + 1),
|
320
|
+
},
|
321
|
+
{
|
322
|
+
id: 2,
|
323
|
+
creator,
|
324
|
+
name: '游客',
|
325
|
+
keyword: 'guest',
|
326
|
+
desc: '游客',
|
327
|
+
aid: [1, 2, 3, 5, 9],
|
328
|
+
mid: [1, 4],
|
329
|
+
},
|
330
|
+
];
|
331
|
+
|
332
|
+
await service.createBatch(defaultRoles);
|
333
|
+
ctx.logger.info('角色初始化成功!');
|
334
|
+
};
|
335
|
+
|
336
|
+
const initUser = async (ctx: Context, service: UserService) => {
|
337
|
+
const key = ctx.app.getConfig('keys');
|
338
|
+
const defaultRoles: CreateUserItem[] = [
|
339
|
+
{
|
340
|
+
id: 1,
|
341
|
+
creator,
|
342
|
+
username: 'super',
|
343
|
+
mobile: '15111111111',
|
344
|
+
nickname: '超级管理员',
|
345
|
+
avatar: 'https://avatars.dicebear.com/api/bottts/1.svg',
|
346
|
+
password: md5(`${key}123456`),
|
347
|
+
rid: 1,
|
348
|
+
},
|
349
|
+
{
|
350
|
+
id: 2,
|
351
|
+
creator,
|
352
|
+
username: 'guest',
|
353
|
+
mobile: '13111111111',
|
354
|
+
nickname: '游客',
|
355
|
+
avatar: 'https://avatars.dicebear.com/api/bottts/2.svg',
|
356
|
+
password: md5(`${key}111111`),
|
357
|
+
rid: 2,
|
358
|
+
},
|
359
|
+
];
|
360
|
+
|
361
|
+
await service.createBatch(defaultRoles);
|
362
|
+
ctx.logger.info('用户初始化成功!');
|
363
|
+
};
|
364
|
+
|
365
|
+
@Controller('/admin')
|
366
|
+
export class AdminController {
|
367
|
+
@Inject()
|
368
|
+
ctx: Context;
|
369
|
+
|
370
|
+
@Inject()
|
371
|
+
userService: UserService;
|
372
|
+
|
373
|
+
@Inject()
|
374
|
+
apiService: ApiService;
|
375
|
+
|
376
|
+
@Inject()
|
377
|
+
roleService: RoleService;
|
378
|
+
|
379
|
+
@Inject()
|
380
|
+
menuService: MenuService;
|
381
|
+
|
382
|
+
/**
|
383
|
+
* 后台表插入基础初始数据
|
384
|
+
* @warning 存在安全风险,仅供开发使用
|
385
|
+
*/
|
386
|
+
@Post('/init')
|
387
|
+
async init() {
|
388
|
+
const ctx = this.ctx;
|
389
|
+
|
390
|
+
await initMenu(ctx, this.menuService);
|
391
|
+
await initApi(ctx, this.apiService);
|
392
|
+
await initRole(ctx, this.roleService);
|
393
|
+
await initUser(ctx, this.userService);
|
394
|
+
|
395
|
+
return ctx.helper.success();
|
396
|
+
}
|
397
|
+
}
|
@@ -0,0 +1,98 @@
|
|
1
|
+
/*
|
2
|
+
* @Author: zhangyang
|
3
|
+
* @Date: 2022-12-27 11:23:39
|
4
|
+
* @LastEditTime: 2022-12-29 11:12:18
|
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 { ApiService, RoleService } from '../service';
|
11
|
+
import * as dayjs from 'dayjs';
|
12
|
+
import { ApiCreateDTO, ApiQueryDTO, ApiUpdateDTO } from './dto';
|
13
|
+
|
14
|
+
@Controller('/api')
|
15
|
+
export class ApiController {
|
16
|
+
@Inject()
|
17
|
+
ctx: Context;
|
18
|
+
|
19
|
+
@Inject()
|
20
|
+
apiService: ApiService;
|
21
|
+
|
22
|
+
@Inject()
|
23
|
+
roleService: RoleService;
|
24
|
+
|
25
|
+
@Get('/list')
|
26
|
+
@Validate()
|
27
|
+
async getApiList(@Query() query: ApiQueryDTO) {
|
28
|
+
const data = await this.apiService.findAll(query);
|
29
|
+
return this.ctx.helper.success({ data });
|
30
|
+
}
|
31
|
+
|
32
|
+
@Post('/create')
|
33
|
+
@Validate()
|
34
|
+
async createApi(@Body() form: ApiCreateDTO) {
|
35
|
+
const { category = '', desc = '', method = '', path = '', roleIds: rids } = form;
|
36
|
+
|
37
|
+
if (path && !path.startsWith('/')) {
|
38
|
+
return this.ctx.helper.fail({ msg: '路径不合法' });
|
39
|
+
}
|
40
|
+
|
41
|
+
const { username: u, nickname: n } = this.ctx.state.user;
|
42
|
+
|
43
|
+
try {
|
44
|
+
await this.apiService.create({
|
45
|
+
category,
|
46
|
+
desc,
|
47
|
+
method,
|
48
|
+
path,
|
49
|
+
rids,
|
50
|
+
creator: n || u,
|
51
|
+
});
|
52
|
+
return this.ctx.helper.success();
|
53
|
+
} catch (error) {
|
54
|
+
return this.ctx.helper.fail({ msg: (error as Error).message });
|
55
|
+
}
|
56
|
+
}
|
57
|
+
|
58
|
+
@Patch('/update/:apiId')
|
59
|
+
async update(@Param('apiId') id: string, @Body() form: ApiUpdateDTO) {
|
60
|
+
const { category, desc, method, path, roleIds: rids } = form;
|
61
|
+
|
62
|
+
try {
|
63
|
+
await this.apiService.update(Number(id), {
|
64
|
+
category,
|
65
|
+
desc,
|
66
|
+
method,
|
67
|
+
path,
|
68
|
+
rids,
|
69
|
+
updateAt: dayjs(Date.now()).format('YYYY-MM-DD HH:mm:ss'),
|
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
|
+
@Del('/delete/batch')
|
78
|
+
async del(@Body('ids') ids: string) {
|
79
|
+
try {
|
80
|
+
await this.apiService.deleteBatch(ids.split(',').map((i: string) => Number(i)));
|
81
|
+
return this.ctx.helper.success();
|
82
|
+
} catch (error) {
|
83
|
+
return this.ctx.helper.fail({ msg: (error as Error).message });
|
84
|
+
}
|
85
|
+
}
|
86
|
+
|
87
|
+
@Get('/all/category/:roleId')
|
88
|
+
async getRoleAccessApis(@Param('roleId') roleId: number) {
|
89
|
+
const apis = await this.roleService.getAccessApis(roleId);
|
90
|
+
const list = await this.apiService.getAllTree();
|
91
|
+
return this.ctx.helper.success({
|
92
|
+
data: {
|
93
|
+
accessIds: apis.map((i) => Number(i.id)),
|
94
|
+
list,
|
95
|
+
},
|
96
|
+
});
|
97
|
+
}
|
98
|
+
}
|
@@ -0,0 +1,70 @@
|
|
1
|
+
/*
|
2
|
+
* @Author: zhangyang
|
3
|
+
* @Date: 2022-12-27 16:24:46
|
4
|
+
* @LastEditTime: 2023-01-06 16:31:19
|
5
|
+
* @Description:
|
6
|
+
*/
|
7
|
+
import { Inject, Controller, Post, Body } from '@midwayjs/decorator';
|
8
|
+
import { Context } from '@midwayjs/koa';
|
9
|
+
import { Validate } from '@midwayjs/validate';
|
10
|
+
import { UserService } from '../service';
|
11
|
+
import { UserLoginDTO } from './dto';
|
12
|
+
import * as md5 from 'md5';
|
13
|
+
import { JwtService } from '@midwayjs/jwt';
|
14
|
+
import { CacheManager } from '@midwayjs/cache';
|
15
|
+
|
16
|
+
@Controller('/base')
|
17
|
+
export class UserController {
|
18
|
+
@Inject()
|
19
|
+
ctx: Context;
|
20
|
+
|
21
|
+
@Inject()
|
22
|
+
userService: UserService;
|
23
|
+
|
24
|
+
@Inject()
|
25
|
+
jwt: JwtService;
|
26
|
+
|
27
|
+
@Inject()
|
28
|
+
cacheManager: CacheManager;
|
29
|
+
|
30
|
+
@Validate()
|
31
|
+
@Post('/login')
|
32
|
+
async login(@Body() form: UserLoginDTO) {
|
33
|
+
const { username, password } = form;
|
34
|
+
const user = await this.userService.findOne({
|
35
|
+
username,
|
36
|
+
});
|
37
|
+
|
38
|
+
if (user) {
|
39
|
+
const key = this.ctx.app.getConfig('keys');
|
40
|
+
const exp = this.ctx.app.getConfig('jwt.expiresIn');
|
41
|
+
if (md5(`${key}${password}`) === user.password) {
|
42
|
+
const token = this.jwt.signSync({
|
43
|
+
username,
|
44
|
+
password,
|
45
|
+
nickname: user.nickname,
|
46
|
+
});
|
47
|
+
const cacheKey = `${username}.menu.tree`;
|
48
|
+
await this.cacheManager.del(cacheKey);
|
49
|
+
return this.ctx.helper.success({
|
50
|
+
data: {
|
51
|
+
/**
|
52
|
+
* 过期时间,毫秒
|
53
|
+
*/
|
54
|
+
expires: new Date(Date.now() + exp * 1000),
|
55
|
+
token,
|
56
|
+
},
|
57
|
+
msg: '登录成功!',
|
58
|
+
});
|
59
|
+
} else {
|
60
|
+
return this.ctx.helper.fail({
|
61
|
+
msg: '用户名或密码错误!',
|
62
|
+
});
|
63
|
+
}
|
64
|
+
} else {
|
65
|
+
return this.ctx.helper.fail({
|
66
|
+
msg: '用户名不存在!',
|
67
|
+
});
|
68
|
+
}
|
69
|
+
}
|
70
|
+
}
|