@hedhog/admin 0.12.2 → 0.12.3

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 (137) hide show
  1. package/bkp.hedhog.yaml +1012 -1012
  2. package/dist/auth/auth.controller.d.ts +1 -10
  3. package/dist/auth/auth.controller.d.ts.map +1 -1
  4. package/dist/auth/auth.service.d.ts +1 -10
  5. package/dist/auth/auth.service.d.ts.map +1 -1
  6. package/dist/auth/auth.service.js.map +1 -1
  7. package/dist/auth/auth.service.spec.d.ts +0 -1
  8. package/dist/auth/auth.service.spec.js +171 -161
  9. package/dist/auth/auth.service.spec.js.map +1 -1
  10. package/dist/auth/consts/body.js +23 -23
  11. package/dist/menu/menu.controller.d.ts +6 -33
  12. package/dist/menu/menu.controller.d.ts.map +1 -1
  13. package/dist/menu/menu.service.d.ts +6 -33
  14. package/dist/menu/menu.service.d.ts.map +1 -1
  15. package/dist/menu/menu.service.js.map +1 -1
  16. package/dist/role/guards/role.guard.js.map +1 -1
  17. package/dist/role/role.controller.d.ts +5 -5
  18. package/dist/role/role.service.d.ts +5 -5
  19. package/dist/role/role.service.js.map +1 -1
  20. package/dist/route/route.controller.d.ts +6 -27
  21. package/dist/route/route.controller.d.ts.map +1 -1
  22. package/dist/route/route.service.d.ts +6 -27
  23. package/dist/route/route.service.d.ts.map +1 -1
  24. package/dist/route/route.service.js.map +1 -1
  25. package/dist/screen/screen.controller.d.ts +6 -24
  26. package/dist/screen/screen.controller.d.ts.map +1 -1
  27. package/dist/screen/screen.service.d.ts +6 -24
  28. package/dist/screen/screen.service.d.ts.map +1 -1
  29. package/dist/screen/screen.service.js.map +1 -1
  30. package/dist/user/user.controller.d.ts +5 -32
  31. package/dist/user/user.controller.d.ts.map +1 -1
  32. package/dist/user/user.service.d.ts +5 -32
  33. package/dist/user/user.service.d.ts.map +1 -1
  34. package/dist/user/user.service.js.map +1 -1
  35. package/dist/user/user.service.spec.d.ts +0 -1
  36. package/dist/user/user.service.spec.js +259 -250
  37. package/dist/user/user.service.spec.js.map +1 -1
  38. package/frontend/menu/components/create-panel.tsx.ejs +55 -0
  39. package/frontend/menu/components/update-panel.tsx.ejs +67 -0
  40. package/frontend/menu/locales/en/admin.menu.json +11 -0
  41. package/frontend/menu/locales/pt/admin.menu.json +11 -0
  42. package/frontend/menu/react-query/handlers.ts.ejs +28 -0
  43. package/frontend/menu/react-query/requests.ts.ejs +56 -0
  44. package/frontend/menu-locale/locales/en/admin.menu-locale.json +11 -0
  45. package/frontend/menu-locale/locales/pt/admin.menu-locale.json +11 -0
  46. package/frontend/menu-screen/locales/en/admin.menu-screen.json +11 -0
  47. package/frontend/menu-screen/locales/pt/admin.menu-screen.json +11 -0
  48. package/frontend/multifactor/components/create-panel.tsx.ejs +55 -0
  49. package/frontend/multifactor/components/update-panel.tsx.ejs +70 -0
  50. package/frontend/multifactor/locales/en/admin.multifactor.json +11 -0
  51. package/frontend/multifactor/locales/pt/admin.multifactor.json +11 -0
  52. package/frontend/multifactor/react-query/handlers.ts.ejs +28 -0
  53. package/frontend/multifactor/react-query/requests.ts.ejs +59 -0
  54. package/frontend/multifactor-locale/locales/en/admin.multifactor-locale.json +11 -0
  55. package/frontend/multifactor-locale/locales/pt/admin.multifactor-locale.json +11 -0
  56. package/frontend/screen/components/create-panel.tsx.ejs +55 -0
  57. package/frontend/screen/components/update-panel.tsx.ejs +67 -0
  58. package/frontend/screen/locales/en/admin.screen.json +11 -0
  59. package/frontend/screen/locales/pt/admin.screen.json +11 -0
  60. package/frontend/screen/react-query/handlers.ts.ejs +28 -0
  61. package/frontend/screen/react-query/requests.ts.ejs +56 -0
  62. package/frontend/screen-locale/locales/en/admin.screen-locale.json +11 -0
  63. package/frontend/screen-locale/locales/pt/admin.screen-locale.json +11 -0
  64. package/frontend/translation/components/create-panel.tsx.ejs +52 -0
  65. package/frontend/translation/components/update-panel.tsx.ejs +67 -0
  66. package/frontend/translation/fields/en.json +1 -0
  67. package/frontend/translation/fields/pt.json +1 -0
  68. package/frontend/translation/locales/en/admin.translation.json +11 -0
  69. package/frontend/translation/locales/pt/admin.translation.json +11 -0
  70. package/frontend/translation/modules/en.json +1 -0
  71. package/frontend/translation/modules/pt.json +1 -0
  72. package/frontend/translation/react-query/handlers.ts.ejs +28 -0
  73. package/frontend/translation/react-query/requests.ts.ejs +58 -0
  74. package/frontend/translation-namespace/components/create-panel.tsx.ejs +53 -0
  75. package/frontend/translation-namespace/components/update-panel.tsx.ejs +70 -0
  76. package/frontend/translation-namespace/locales/en/admin.translation-namespace.json +11 -0
  77. package/frontend/translation-namespace/locales/pt/admin.translation-namespace.json +11 -0
  78. package/frontend/translation-namespace/react-query/handlers.ts.ejs +28 -0
  79. package/frontend/translation-namespace/react-query/requests.ts.ejs +60 -0
  80. package/frontend/user/components/create-panel.tsx.ejs +52 -0
  81. package/frontend/user/components/update-panel.tsx.ejs +64 -0
  82. package/frontend/user/locales/en/admin.user.json +11 -0
  83. package/frontend/user/locales/pt/admin.user.json +11 -0
  84. package/frontend/user/react-query/handlers.ts.ejs +28 -0
  85. package/frontend/user/react-query/requests.ts.ejs +55 -0
  86. package/package.json +6 -6
  87. package/src/admin.module.ts +37 -37
  88. package/src/auth/auth.controller.ts +72 -72
  89. package/src/auth/auth.module.ts +39 -39
  90. package/src/auth/auth.service.spec.ts +196 -196
  91. package/src/auth/auth.service.ts +234 -234
  92. package/src/auth/consts/body.ts +26 -26
  93. package/src/auth/consts/subject.ts +1 -1
  94. package/src/auth/dto/forget.dto.ts +6 -6
  95. package/src/auth/dto/login.dto.ts +15 -15
  96. package/src/auth/dto/otp.dto.ts +11 -11
  97. package/src/auth/dto/reset.dto.ts +14 -14
  98. package/src/auth/enums/multifactor-type.enum.ts +4 -4
  99. package/src/auth/guards/auth.guard.ts +50 -50
  100. package/src/auth/types/user.type.ts +8 -8
  101. package/src/dto/delete.dto.ts +8 -8
  102. package/src/dto/update-ids.dto.ts +9 -9
  103. package/src/index.ts +20 -20
  104. package/src/menu/dto/create.dto.ts +25 -25
  105. package/src/menu/dto/order.dto.ts +8 -8
  106. package/src/menu/dto/update.dto.ts +19 -19
  107. package/src/menu/menu.controller.ts +105 -105
  108. package/src/menu/menu.module.ts +18 -18
  109. package/src/menu/menu.service.spec.ts +247 -247
  110. package/src/menu/menu.service.ts +263 -263
  111. package/src/role/dto/create.dto.ts +7 -7
  112. package/src/role/dto/update.dto.ts +4 -4
  113. package/src/role/guards/role.guard.ts +123 -123
  114. package/src/role/role.controller.ts +126 -126
  115. package/src/role/role.module.ts +28 -28
  116. package/src/role/role.service.spec.ts +417 -417
  117. package/src/role/role.service.ts +289 -289
  118. package/src/route/dto/create.dto.ts +13 -13
  119. package/src/route/dto/update.dto.ts +15 -15
  120. package/src/route/route.controller.ts +91 -91
  121. package/src/route/route.module.ts +18 -18
  122. package/src/route/route.service.spec.ts +300 -300
  123. package/src/route/route.service.ts +164 -164
  124. package/src/screen/dto/create.dto.ts +11 -11
  125. package/src/screen/dto/update.dto.ts +19 -19
  126. package/src/screen/screen.controller.ts +93 -93
  127. package/src/screen/screen.module.ts +18 -18
  128. package/src/screen/screen.service.spec.ts +298 -298
  129. package/src/screen/screen.service.ts +179 -179
  130. package/src/types/http-method.ts +8 -8
  131. package/src/user/constants/user.constants.ts +1 -1
  132. package/src/user/dto/create.dto.ts +24 -24
  133. package/src/user/dto/update.dto.ts +41 -41
  134. package/src/user/user.controller.ts +75 -75
  135. package/src/user/user.module.ts +18 -18
  136. package/src/user/user.service.spec.ts +294 -294
  137. package/src/user/user.service.ts +129 -129
@@ -1,129 +1,129 @@
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 { genSalt, hash } from 'bcrypt';
10
- import { DeleteDTO } from '../dto/delete.dto';
11
- import { UpdateIdsDTO } from '../dto/update-ids.dto';
12
- import { SALT_ROUNDS } from './constants/user.constants';
13
- import { CreateDTO } from './dto/create.dto';
14
- import { UpdateDTO } from './dto/update.dto';
15
-
16
- @Injectable()
17
- export class UserService {
18
- constructor(
19
- @Inject(forwardRef(() => PrismaService))
20
- private readonly prismaService: PrismaService,
21
- @Inject(forwardRef(() => PaginationService))
22
- private readonly paginationService: PaginationService,
23
- ) {}
24
-
25
- async listRoles(userId: number, paginationParams: PaginationDTO) {
26
- return this.paginationService.paginate(
27
- this.prismaService.role,
28
- paginationParams,
29
- {
30
- include: {
31
- role_user: {
32
- where: {
33
- user_id: userId,
34
- },
35
- select: {
36
- user_id: true,
37
- role_id: true,
38
- },
39
- },
40
- },
41
- },
42
- );
43
- }
44
-
45
- async updateRoles(userId: number, { ids }: UpdateIdsDTO) {
46
- await this.prismaService.role_user.deleteMany({
47
- where: {
48
- user_id: userId,
49
- },
50
- });
51
-
52
- return this.prismaService.role_user.createMany({
53
- data: ids.map((role) => {
54
- return {
55
- user_id: userId,
56
- role_id: role,
57
- };
58
- }),
59
- skipDuplicates: true,
60
- });
61
- }
62
-
63
- async list(paginationParams: PaginationDTO) {
64
- const fields = ['name', 'email'];
65
- const OR = this.prismaService.createInsensitiveSearch(
66
- fields,
67
- paginationParams,
68
- );
69
-
70
- return this.paginationService.paginate(
71
- this.prismaService.user,
72
- paginationParams,
73
- {
74
- where: {
75
- OR,
76
- },
77
- },
78
- );
79
- }
80
-
81
- async get(userId: number) {
82
- return this.prismaService.user.findUnique({ where: { id: userId } });
83
- }
84
-
85
- async hashPassword(password: string): Promise<string> {
86
- const salt = await genSalt(SALT_ROUNDS);
87
- return hash(password, salt);
88
- }
89
-
90
- async create({ email, name, password }: CreateDTO) {
91
- const hashedPassword = await this.hashPassword(password);
92
-
93
- return this.prismaService.user.create({
94
- data: {
95
- email,
96
- name,
97
- password: hashedPassword,
98
- },
99
- });
100
- }
101
-
102
- async update({ id, data }: { id: number; data: UpdateDTO }) {
103
- return this.prismaService.user.update({
104
- where: { id },
105
- data,
106
- });
107
- }
108
-
109
- async delete({ ids }: DeleteDTO) {
110
- if (ids == undefined || ids == null) {
111
- throw new BadRequestException(
112
- `You must select at least one user to delete.`,
113
- );
114
- }
115
-
116
- return this.prismaService.user.deleteMany({
117
- where: {
118
- id: {
119
- in: ids,
120
- },
121
- email: {
122
- not: {
123
- startsWith: 'root@',
124
- },
125
- },
126
- },
127
- });
128
- }
129
- }
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 { genSalt, hash } from 'bcrypt';
10
+ import { DeleteDTO } from '../dto/delete.dto';
11
+ import { UpdateIdsDTO } from '../dto/update-ids.dto';
12
+ import { SALT_ROUNDS } from './constants/user.constants';
13
+ import { CreateDTO } from './dto/create.dto';
14
+ import { UpdateDTO } from './dto/update.dto';
15
+
16
+ @Injectable()
17
+ export class UserService {
18
+ constructor(
19
+ @Inject(forwardRef(() => PrismaService))
20
+ private readonly prismaService: PrismaService,
21
+ @Inject(forwardRef(() => PaginationService))
22
+ private readonly paginationService: PaginationService,
23
+ ) { }
24
+
25
+ async listRoles(userId: number, paginationParams: PaginationDTO) {
26
+ return this.paginationService.paginate(
27
+ (this.prismaService as any).role,
28
+ paginationParams,
29
+ {
30
+ include: {
31
+ role_user: {
32
+ where: {
33
+ user_id: userId,
34
+ },
35
+ select: {
36
+ user_id: true,
37
+ role_id: true,
38
+ },
39
+ },
40
+ },
41
+ },
42
+ );
43
+ }
44
+
45
+ async updateRoles(userId: number, { ids }: UpdateIdsDTO) {
46
+ await (this.prismaService as any).role_user.deleteMany({
47
+ where: {
48
+ user_id: userId,
49
+ },
50
+ });
51
+
52
+ return (this.prismaService as any).role_user.createMany({
53
+ data: ids.map((role) => {
54
+ return {
55
+ user_id: userId,
56
+ role_id: role,
57
+ };
58
+ }),
59
+ skipDuplicates: true,
60
+ });
61
+ }
62
+
63
+ async list(paginationParams: PaginationDTO) {
64
+ const fields = ['name', 'email'];
65
+ const OR = (this.prismaService as any).createInsensitiveSearch(
66
+ fields,
67
+ paginationParams,
68
+ );
69
+
70
+ return this.paginationService.paginate(
71
+ (this.prismaService as any).user,
72
+ paginationParams,
73
+ {
74
+ where: {
75
+ OR,
76
+ },
77
+ },
78
+ );
79
+ }
80
+
81
+ async get(userId: number) {
82
+ return (this.prismaService as any).user.findUnique({ where: { id: userId } });
83
+ }
84
+
85
+ async hashPassword(password: string): Promise<string> {
86
+ const salt = await genSalt(SALT_ROUNDS);
87
+ return hash(password, salt);
88
+ }
89
+
90
+ async create({ email, name, password }: CreateDTO) {
91
+ const hashedPassword = await this.hashPassword(password);
92
+
93
+ return (this.prismaService as any).user.create({
94
+ data: {
95
+ email,
96
+ name,
97
+ password: hashedPassword,
98
+ },
99
+ });
100
+ }
101
+
102
+ async update({ id, data }: { id: number; data: UpdateDTO }) {
103
+ return (this.prismaService as any).user.update({
104
+ where: { id },
105
+ data,
106
+ });
107
+ }
108
+
109
+ async delete({ ids }: DeleteDTO) {
110
+ if (ids == undefined || ids == null) {
111
+ throw new BadRequestException(
112
+ `You must select at least one user to delete.`,
113
+ );
114
+ }
115
+
116
+ return (this.prismaService as any).user.deleteMany({
117
+ where: {
118
+ id: {
119
+ in: ids,
120
+ },
121
+ email: {
122
+ not: {
123
+ startsWith: 'root@',
124
+ },
125
+ },
126
+ },
127
+ });
128
+ }
129
+ }