@hedhog/admin 0.11.1 → 0.12.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (54) hide show
  1. package/{hedhog.yaml → bkp.hedhog.yaml} +1012 -814
  2. package/dist/auth/consts/body.js +23 -23
  3. package/package.json +43 -43
  4. package/src/admin.module.ts +37 -37
  5. package/src/auth/auth.controller.ts +72 -72
  6. package/src/auth/auth.module.ts +39 -39
  7. package/src/auth/auth.service.spec.ts +196 -196
  8. package/src/auth/auth.service.ts +234 -234
  9. package/src/auth/consts/body.ts +26 -26
  10. package/src/auth/consts/subject.ts +1 -1
  11. package/src/auth/dto/forget.dto.ts +6 -6
  12. package/src/auth/dto/login.dto.ts +15 -15
  13. package/src/auth/dto/otp.dto.ts +11 -11
  14. package/src/auth/dto/reset.dto.ts +14 -14
  15. package/src/auth/enums/multifactor-type.enum.ts +4 -4
  16. package/src/auth/guards/auth.guard.ts +50 -50
  17. package/src/auth/types/user.type.ts +8 -8
  18. package/src/dto/delete.dto.ts +8 -8
  19. package/src/dto/update-ids.dto.ts +9 -9
  20. package/src/index.ts +20 -20
  21. package/src/menu/dto/create.dto.ts +25 -25
  22. package/src/menu/dto/order.dto.ts +8 -8
  23. package/src/menu/dto/update.dto.ts +19 -19
  24. package/src/menu/menu.controller.ts +105 -105
  25. package/src/menu/menu.module.ts +18 -18
  26. package/src/menu/menu.service.spec.ts +247 -247
  27. package/src/menu/menu.service.ts +263 -263
  28. package/src/role/dto/create.dto.ts +7 -7
  29. package/src/role/dto/update.dto.ts +4 -4
  30. package/src/role/guards/role.guard.ts +123 -123
  31. package/src/role/role.controller.ts +126 -126
  32. package/src/role/role.module.ts +28 -28
  33. package/src/role/role.service.spec.ts +417 -417
  34. package/src/role/role.service.ts +289 -289
  35. package/src/route/dto/create.dto.ts +13 -13
  36. package/src/route/dto/update.dto.ts +15 -15
  37. package/src/route/route.controller.ts +91 -91
  38. package/src/route/route.module.ts +18 -18
  39. package/src/route/route.service.spec.ts +300 -300
  40. package/src/route/route.service.ts +164 -164
  41. package/src/screen/dto/create.dto.ts +11 -11
  42. package/src/screen/dto/update.dto.ts +19 -19
  43. package/src/screen/screen.controller.ts +93 -93
  44. package/src/screen/screen.module.ts +18 -18
  45. package/src/screen/screen.service.spec.ts +298 -298
  46. package/src/screen/screen.service.ts +179 -179
  47. package/src/types/http-method.ts +8 -8
  48. package/src/user/constants/user.constants.ts +1 -1
  49. package/src/user/dto/create.dto.ts +24 -24
  50. package/src/user/dto/update.dto.ts +41 -41
  51. package/src/user/user.controller.ts +75 -75
  52. package/src/user/user.module.ts +18 -18
  53. package/src/user/user.service.spec.ts +294 -294
  54. package/src/user/user.service.ts +129 -129
@@ -1,179 +1,179 @@
1
- import { PaginationDTO, PaginationService } from '@hedhog/pagination';
2
- import { PrismaService } from '@hedhog/prisma';
3
- import {
4
- BadRequestException,
5
- Inject,
6
- Injectable,
7
- forwardRef,
8
- } from '@nestjs/common';
9
- import { DeleteDTO } from '../dto/delete.dto';
10
- import { UpdateIdsDTO } from '../dto/update-ids.dto';
11
- import { CreateDTO } from './dto/create.dto';
12
- import { UpdateDTO } from './dto/update.dto';
13
-
14
- @Injectable()
15
- export class ScreenService {
16
- constructor(
17
- @Inject(forwardRef(() => PrismaService))
18
- private readonly prismaService: PrismaService,
19
- @Inject(forwardRef(() => PaginationService))
20
- private readonly paginationService: PaginationService,
21
- ) {}
22
-
23
- async updateRoles(screenId: number, data: UpdateIdsDTO) {
24
- await this.prismaService.role_screen.deleteMany({
25
- where: {
26
- screen_id: screenId,
27
- },
28
- });
29
-
30
- return this.prismaService.role_screen.createMany({
31
- data: data.ids.map((roleId) => ({
32
- screen_id: screenId,
33
- role_id: roleId,
34
- })),
35
- skipDuplicates: true,
36
- });
37
- }
38
- async updateRoutes(screenId: number, { ids }: UpdateIdsDTO) {
39
- ids = (
40
- await this.prismaService.route.findMany({
41
- where: {
42
- id: {
43
- in: ids,
44
- },
45
- },
46
- select: {
47
- id: true,
48
- },
49
- })
50
- ).map((route) => route.id);
51
-
52
- await this.prismaService.route_screen.deleteMany({
53
- where: {
54
- screen_id: screenId,
55
- },
56
- });
57
-
58
- return this.prismaService.route_screen.createMany({
59
- data: ids.map((routeId) => ({
60
- screen_id: screenId,
61
- route_id: routeId,
62
- })),
63
- skipDuplicates: true,
64
- });
65
- }
66
- async listRoutes(screenId: number, paginationParams: PaginationDTO) {
67
- return this.paginationService.paginate(
68
- this.prismaService.route,
69
- paginationParams,
70
- {
71
- include: {
72
- route_screen: {
73
- where: {
74
- screen_id: screenId,
75
- },
76
- select: {
77
- route_id: true,
78
- screen_id: true,
79
- },
80
- },
81
- },
82
- },
83
- );
84
- }
85
-
86
- async listRoles(
87
- locale: string,
88
- screenId: number,
89
- paginationParams: PaginationDTO,
90
- ) {
91
- return this.paginationService.paginate(
92
- this.prismaService.role,
93
- paginationParams,
94
- {
95
- include: {
96
- role_screen: {
97
- where: {
98
- screen_id: screenId,
99
- },
100
- select: {
101
- role_id: true,
102
- screen_id: true,
103
- },
104
- },
105
- },
106
- },
107
- );
108
- }
109
-
110
- async list(locale: string, paginationParams: PaginationDTO) {
111
- const fields = ['slug', 'icon'];
112
- const OR: any[] = this.prismaService.createInsensitiveSearch(
113
- fields,
114
- paginationParams,
115
- );
116
-
117
- const result = await this.paginationService.paginate(
118
- this.prismaService.screen,
119
- paginationParams,
120
- {
121
- where: {
122
- OR,
123
- },
124
- include: {
125
- screen_locale: {
126
- where: {
127
- locale: {
128
- code: locale,
129
- },
130
- },
131
- select: {
132
- name: true,
133
- description: true,
134
- },
135
- },
136
- },
137
- },
138
- 'screen_locale',
139
- );
140
-
141
- return result;
142
- }
143
-
144
- async get(screenId: number) {
145
- return this.prismaService.screen.findUnique({ where: { id: screenId } });
146
- }
147
-
148
- async create({ slug, icon }: CreateDTO) {
149
- return this.prismaService.screen.create({
150
- data: {
151
- slug,
152
- icon,
153
- },
154
- });
155
- }
156
-
157
- async update({ id, data }: { id: number; data: UpdateDTO }) {
158
- return this.prismaService.screen.update({
159
- where: { id },
160
- data,
161
- });
162
- }
163
-
164
- async delete({ ids }: DeleteDTO) {
165
- if (ids == undefined || ids == null) {
166
- throw new BadRequestException(
167
- `You must select at least one screen to delete.`,
168
- );
169
- }
170
-
171
- return this.prismaService.screen.deleteMany({
172
- where: {
173
- id: {
174
- in: ids,
175
- },
176
- },
177
- });
178
- }
179
- }
1
+ import { PaginationDTO, PaginationService } from '@hedhog/pagination';
2
+ import { PrismaService } from '@hedhog/prisma';
3
+ import {
4
+ BadRequestException,
5
+ Inject,
6
+ Injectable,
7
+ forwardRef,
8
+ } from '@nestjs/common';
9
+ import { DeleteDTO } from '../dto/delete.dto';
10
+ import { UpdateIdsDTO } from '../dto/update-ids.dto';
11
+ import { CreateDTO } from './dto/create.dto';
12
+ import { UpdateDTO } from './dto/update.dto';
13
+
14
+ @Injectable()
15
+ export class ScreenService {
16
+ constructor(
17
+ @Inject(forwardRef(() => PrismaService))
18
+ private readonly prismaService: PrismaService,
19
+ @Inject(forwardRef(() => PaginationService))
20
+ private readonly paginationService: PaginationService,
21
+ ) {}
22
+
23
+ async updateRoles(screenId: number, data: UpdateIdsDTO) {
24
+ await this.prismaService.role_screen.deleteMany({
25
+ where: {
26
+ screen_id: screenId,
27
+ },
28
+ });
29
+
30
+ return this.prismaService.role_screen.createMany({
31
+ data: data.ids.map((roleId) => ({
32
+ screen_id: screenId,
33
+ role_id: roleId,
34
+ })),
35
+ skipDuplicates: true,
36
+ });
37
+ }
38
+ async updateRoutes(screenId: number, { ids }: UpdateIdsDTO) {
39
+ ids = (
40
+ await this.prismaService.route.findMany({
41
+ where: {
42
+ id: {
43
+ in: ids,
44
+ },
45
+ },
46
+ select: {
47
+ id: true,
48
+ },
49
+ })
50
+ ).map((route) => route.id);
51
+
52
+ await this.prismaService.route_screen.deleteMany({
53
+ where: {
54
+ screen_id: screenId,
55
+ },
56
+ });
57
+
58
+ return this.prismaService.route_screen.createMany({
59
+ data: ids.map((routeId) => ({
60
+ screen_id: screenId,
61
+ route_id: routeId,
62
+ })),
63
+ skipDuplicates: true,
64
+ });
65
+ }
66
+ async listRoutes(screenId: number, paginationParams: PaginationDTO) {
67
+ return this.paginationService.paginate(
68
+ this.prismaService.route,
69
+ paginationParams,
70
+ {
71
+ include: {
72
+ route_screen: {
73
+ where: {
74
+ screen_id: screenId,
75
+ },
76
+ select: {
77
+ route_id: true,
78
+ screen_id: true,
79
+ },
80
+ },
81
+ },
82
+ },
83
+ );
84
+ }
85
+
86
+ async listRoles(
87
+ locale: string,
88
+ screenId: number,
89
+ paginationParams: PaginationDTO,
90
+ ) {
91
+ return this.paginationService.paginate(
92
+ this.prismaService.role,
93
+ paginationParams,
94
+ {
95
+ include: {
96
+ role_screen: {
97
+ where: {
98
+ screen_id: screenId,
99
+ },
100
+ select: {
101
+ role_id: true,
102
+ screen_id: true,
103
+ },
104
+ },
105
+ },
106
+ },
107
+ );
108
+ }
109
+
110
+ async list(locale: string, paginationParams: PaginationDTO) {
111
+ const fields = ['slug', 'icon'];
112
+ const OR: any[] = this.prismaService.createInsensitiveSearch(
113
+ fields,
114
+ paginationParams,
115
+ );
116
+
117
+ const result = await this.paginationService.paginate(
118
+ this.prismaService.screen,
119
+ paginationParams,
120
+ {
121
+ where: {
122
+ OR,
123
+ },
124
+ include: {
125
+ screen_locale: {
126
+ where: {
127
+ locale: {
128
+ code: locale,
129
+ },
130
+ },
131
+ select: {
132
+ name: true,
133
+ description: true,
134
+ },
135
+ },
136
+ },
137
+ },
138
+ 'screen_locale',
139
+ );
140
+
141
+ return result;
142
+ }
143
+
144
+ async get(screenId: number) {
145
+ return this.prismaService.screen.findUnique({ where: { id: screenId } });
146
+ }
147
+
148
+ async create({ slug, icon }: CreateDTO) {
149
+ return this.prismaService.screen.create({
150
+ data: {
151
+ slug,
152
+ icon,
153
+ },
154
+ });
155
+ }
156
+
157
+ async update({ id, data }: { id: number; data: UpdateDTO }) {
158
+ return this.prismaService.screen.update({
159
+ where: { id },
160
+ data,
161
+ });
162
+ }
163
+
164
+ async delete({ ids }: DeleteDTO) {
165
+ if (ids == undefined || ids == null) {
166
+ throw new BadRequestException(
167
+ `You must select at least one screen to delete.`,
168
+ );
169
+ }
170
+
171
+ return this.prismaService.screen.deleteMany({
172
+ where: {
173
+ id: {
174
+ in: ids,
175
+ },
176
+ },
177
+ });
178
+ }
179
+ }
@@ -1,8 +1,8 @@
1
- export type HttpMethod =
2
- | 'GET'
3
- | 'POST'
4
- | 'PUT'
5
- | 'DELETE'
6
- | 'PATCH'
7
- | 'OPTIONS'
8
- | 'HEAD';
1
+ export type HttpMethod =
2
+ | 'GET'
3
+ | 'POST'
4
+ | 'PUT'
5
+ | 'DELETE'
6
+ | 'PATCH'
7
+ | 'OPTIONS'
8
+ | 'HEAD';
@@ -1 +1 @@
1
- export const SALT_ROUNDS = 10;
1
+ export const SALT_ROUNDS = 10;
@@ -1,24 +1,24 @@
1
- import { IsEmail, IsString, IsStrongPassword } from 'class-validator';
2
-
3
- export class CreateDTO {
4
- @IsString({ message: 'O nome deve ser uma string' })
5
- name: string;
6
-
7
- @IsEmail({}, { message: 'O email deve ser um email válido' })
8
- email: string;
9
-
10
- @IsStrongPassword(
11
- {
12
- minLength: 6,
13
- minLowercase: 1,
14
- minUppercase: 0,
15
- minNumbers: 0,
16
- minSymbols: 0,
17
- },
18
- {
19
- message:
20
- 'A senha deve ter pelo menos 6 caracteres, contendo pelo menos uma letra minúscula',
21
- },
22
- )
23
- password: string;
24
- }
1
+ import { IsEmail, IsString, IsStrongPassword } from 'class-validator';
2
+
3
+ export class CreateDTO {
4
+ @IsString({ message: 'O nome deve ser uma string' })
5
+ name: string;
6
+
7
+ @IsEmail({}, { message: 'O email deve ser um email válido' })
8
+ email: string;
9
+
10
+ @IsStrongPassword(
11
+ {
12
+ minLength: 6,
13
+ minLowercase: 1,
14
+ minUppercase: 0,
15
+ minNumbers: 0,
16
+ minSymbols: 0,
17
+ },
18
+ {
19
+ message:
20
+ 'A senha deve ter pelo menos 6 caracteres, contendo pelo menos uma letra minúscula',
21
+ },
22
+ )
23
+ password: string;
24
+ }
@@ -1,41 +1,41 @@
1
- import {
2
- IsEmail,
3
- IsInt,
4
- IsOptional,
5
- IsString,
6
- IsStrongPassword,
7
- } from 'class-validator';
8
-
9
- export class UpdateDTO {
10
- @IsString({ message: 'The name must be a string' })
11
- @IsOptional()
12
- name?: string;
13
-
14
- @IsEmail({}, { message: 'The email must be a valid email' })
15
- @IsOptional()
16
- email?: string;
17
-
18
- @IsOptional()
19
- @IsStrongPassword(
20
- {
21
- minLength: 6,
22
- minLowercase: 1,
23
- minUppercase: 0,
24
- minNumbers: 0,
25
- minSymbols: 0,
26
- },
27
- {
28
- message:
29
- 'The password must be at least 6 characters long and contain at least one lowercase',
30
- },
31
- )
32
- password?: string;
33
-
34
- @IsOptional()
35
- @IsInt({ message: 'The multifactor_id must be an integer' })
36
- multifactor_id?: number;
37
-
38
- @IsOptional()
39
- @IsString({ message: 'The code must be a string' })
40
- code?: string;
41
- }
1
+ import {
2
+ IsEmail,
3
+ IsInt,
4
+ IsOptional,
5
+ IsString,
6
+ IsStrongPassword,
7
+ } from 'class-validator';
8
+
9
+ export class UpdateDTO {
10
+ @IsString({ message: 'The name must be a string' })
11
+ @IsOptional()
12
+ name?: string;
13
+
14
+ @IsEmail({}, { message: 'The email must be a valid email' })
15
+ @IsOptional()
16
+ email?: string;
17
+
18
+ @IsOptional()
19
+ @IsStrongPassword(
20
+ {
21
+ minLength: 6,
22
+ minLowercase: 1,
23
+ minUppercase: 0,
24
+ minNumbers: 0,
25
+ minSymbols: 0,
26
+ },
27
+ {
28
+ message:
29
+ 'The password must be at least 6 characters long and contain at least one lowercase',
30
+ },
31
+ )
32
+ password?: string;
33
+
34
+ @IsOptional()
35
+ @IsInt({ message: 'The multifactor_id must be an integer' })
36
+ multifactor_id?: number;
37
+
38
+ @IsOptional()
39
+ @IsString({ message: 'The code must be a string' })
40
+ code?: string;
41
+ }
@@ -1,75 +1,75 @@
1
- import { Pagination } from '@hedhog/pagination';
2
- import {
3
- Body,
4
- Controller,
5
- Delete,
6
- Get,
7
- Inject,
8
- Param,
9
- ParseIntPipe,
10
- Patch,
11
- Post,
12
- forwardRef,
13
- } from '@nestjs/common';
14
- import { DeleteDTO } from '../dto/delete.dto';
15
- import { UpdateIdsDTO } from '../dto/update-ids.dto';
16
- import { Role } from '@hedhog/core';
17
- import { CreateDTO } from './dto/create.dto';
18
- import { UpdateDTO } from './dto/update.dto';
19
- import { UserService } from './user.service';
20
-
21
- @Role()
22
- @Controller('user')
23
- export class UserController {
24
- constructor(
25
- @Inject(forwardRef(() => UserService))
26
- private readonly userService: UserService,
27
- ) {}
28
-
29
- @Get()
30
- async list(@Pagination() paginationParams) {
31
- return this.userService.list(paginationParams);
32
- }
33
-
34
- @Get(':userId/role')
35
- async listRoles(
36
- @Param('userId', ParseIntPipe) userId: number,
37
- @Pagination() paginationParams,
38
- ) {
39
- return this.userService.listRoles(userId, paginationParams);
40
- }
41
-
42
- @Patch(':userId/role')
43
- async updateRoles(
44
- @Param('userId', ParseIntPipe) userId: number,
45
- @Body() data: UpdateIdsDTO,
46
- ) {
47
- return this.userService.updateRoles(userId, data);
48
- }
49
-
50
- @Get(':userId')
51
- async get(@Param('userId', ParseIntPipe) userId: number) {
52
- return this.userService.get(userId);
53
- }
54
-
55
- @Post()
56
- create(@Body() data: CreateDTO) {
57
- return this.userService.create(data);
58
- }
59
-
60
- @Patch(':userId')
61
- async update(
62
- @Param('userId', ParseIntPipe) userId: number,
63
- @Body() data: UpdateDTO,
64
- ) {
65
- return this.userService.update({
66
- id: userId,
67
- data,
68
- });
69
- }
70
-
71
- @Delete()
72
- async delete(@Body() data: DeleteDTO) {
73
- return this.userService.delete(data);
74
- }
75
- }
1
+ import { Pagination } from '@hedhog/pagination';
2
+ import {
3
+ Body,
4
+ Controller,
5
+ Delete,
6
+ Get,
7
+ Inject,
8
+ Param,
9
+ ParseIntPipe,
10
+ Patch,
11
+ Post,
12
+ forwardRef,
13
+ } from '@nestjs/common';
14
+ import { DeleteDTO } from '../dto/delete.dto';
15
+ import { UpdateIdsDTO } from '../dto/update-ids.dto';
16
+ import { Role } from '@hedhog/core';
17
+ import { CreateDTO } from './dto/create.dto';
18
+ import { UpdateDTO } from './dto/update.dto';
19
+ import { UserService } from './user.service';
20
+
21
+ @Role()
22
+ @Controller('user')
23
+ export class UserController {
24
+ constructor(
25
+ @Inject(forwardRef(() => UserService))
26
+ private readonly userService: UserService,
27
+ ) {}
28
+
29
+ @Get()
30
+ async list(@Pagination() paginationParams) {
31
+ return this.userService.list(paginationParams);
32
+ }
33
+
34
+ @Get(':userId/role')
35
+ async listRoles(
36
+ @Param('userId', ParseIntPipe) userId: number,
37
+ @Pagination() paginationParams,
38
+ ) {
39
+ return this.userService.listRoles(userId, paginationParams);
40
+ }
41
+
42
+ @Patch(':userId/role')
43
+ async updateRoles(
44
+ @Param('userId', ParseIntPipe) userId: number,
45
+ @Body() data: UpdateIdsDTO,
46
+ ) {
47
+ return this.userService.updateRoles(userId, data);
48
+ }
49
+
50
+ @Get(':userId')
51
+ async get(@Param('userId', ParseIntPipe) userId: number) {
52
+ return this.userService.get(userId);
53
+ }
54
+
55
+ @Post()
56
+ create(@Body() data: CreateDTO) {
57
+ return this.userService.create(data);
58
+ }
59
+
60
+ @Patch(':userId')
61
+ async update(
62
+ @Param('userId', ParseIntPipe) userId: number,
63
+ @Body() data: UpdateDTO,
64
+ ) {
65
+ return this.userService.update({
66
+ id: userId,
67
+ data,
68
+ });
69
+ }
70
+
71
+ @Delete()
72
+ async delete(@Body() data: DeleteDTO) {
73
+ return this.userService.delete(data);
74
+ }
75
+ }