@lenne.tech/nest-server 3.2.1 → 3.3.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 (142) hide show
  1. package/dist/core/common/args/filter.args.d.ts +5 -0
  2. package/dist/core/common/args/filter.args.js +10 -0
  3. package/dist/core/common/args/filter.args.js.map +1 -1
  4. package/dist/core/common/args/pagination.args.d.ts +8 -1
  5. package/dist/core/common/args/pagination.args.js +24 -6
  6. package/dist/core/common/args/pagination.args.js.map +1 -1
  7. package/dist/core/common/decorators/restricted.decorator.d.ts +3 -0
  8. package/dist/core/common/decorators/restricted.decorator.js +14 -5
  9. package/dist/core/common/decorators/restricted.decorator.js.map +1 -1
  10. package/dist/core/common/helpers/context.helper.js +15 -5
  11. package/dist/core/common/helpers/context.helper.js.map +1 -1
  12. package/dist/core/common/helpers/filter.helper.d.ts +3 -3
  13. package/dist/core/common/helpers/filter.helper.js.map +1 -1
  14. package/dist/core/common/helpers/graphql.helper.d.ts +4 -4
  15. package/dist/core/common/helpers/input.helper.js +13 -7
  16. package/dist/core/common/helpers/input.helper.js.map +1 -1
  17. package/dist/core/common/helpers/model.helper.js +0 -1
  18. package/dist/core/common/helpers/model.helper.js.map +1 -1
  19. package/dist/core/common/helpers/service.helper.d.ts +11 -8
  20. package/dist/core/common/helpers/service.helper.js +50 -12
  21. package/dist/core/common/helpers/service.helper.js.map +1 -1
  22. package/dist/core/common/inputs/combined-filter.input.d.ts +8 -2
  23. package/dist/core/common/inputs/combined-filter.input.js +16 -5
  24. package/dist/core/common/inputs/combined-filter.input.js.map +1 -1
  25. package/dist/core/common/inputs/core-input.input.d.ts +8 -0
  26. package/dist/core/common/inputs/core-input.input.js +15 -0
  27. package/dist/core/common/inputs/core-input.input.js.map +1 -0
  28. package/dist/core/common/inputs/filter.input.d.ts +7 -1
  29. package/dist/core/common/inputs/filter.input.js +14 -1
  30. package/dist/core/common/inputs/filter.input.js.map +1 -1
  31. package/dist/core/common/inputs/single-filter.input.d.ts +2 -1
  32. package/dist/core/common/inputs/single-filter.input.js +10 -1
  33. package/dist/core/common/inputs/single-filter.input.js.map +1 -1
  34. package/dist/core/common/inputs/sort.input.d.ts +2 -1
  35. package/dist/core/common/inputs/sort.input.js +7 -1
  36. package/dist/core/common/inputs/sort.input.js.map +1 -1
  37. package/dist/core/common/interceptors/check-response.interceptor.js +1 -1
  38. package/dist/core/common/interceptors/check-response.interceptor.js.map +1 -1
  39. package/dist/core/common/interfaces/core-persistence-model.interface.d.ts +1 -0
  40. package/dist/core/common/interfaces/server-options.interface.d.ts +3 -15
  41. package/dist/core/common/models/core-model.model.d.ts +6 -0
  42. package/dist/core/common/models/core-model.model.js +14 -5
  43. package/dist/core/common/models/core-model.model.js.map +1 -1
  44. package/dist/core/common/models/core-persistence.model.d.ts +5 -29
  45. package/dist/core/common/models/core-persistence.model.js +19 -41
  46. package/dist/core/common/models/core-persistence.model.js.map +1 -1
  47. package/dist/core/common/pipes/check-input.pipe.d.ts +2 -3
  48. package/dist/core/common/pipes/check-input.pipe.js +5 -20
  49. package/dist/core/common/pipes/check-input.pipe.js.map +1 -1
  50. package/dist/core/common/pipes/map-and-validate.pipe.d.ts +4 -0
  51. package/dist/core/common/pipes/map-and-validate.pipe.js +40 -0
  52. package/dist/core/common/pipes/map-and-validate.pipe.js.map +1 -0
  53. package/dist/core/common/types/plain-input.type.d.ts +3 -0
  54. package/dist/core/common/types/plain-input.type.js +3 -0
  55. package/dist/core/common/types/plain-input.type.js.map +1 -0
  56. package/dist/core/modules/auth/core-auth.model.d.ts +3 -1
  57. package/dist/core/modules/auth/core-auth.model.js +7 -1
  58. package/dist/core/modules/auth/core-auth.model.js.map +1 -1
  59. package/dist/core/modules/auth/core-auth.module.d.ts +5 -2
  60. package/dist/core/modules/auth/core-auth.module.js +25 -17
  61. package/dist/core/modules/auth/core-auth.module.js.map +1 -1
  62. package/dist/core/modules/auth/core-auth.resolver.d.ts +1 -1
  63. package/dist/core/modules/user/core-user.model.d.ts +3 -0
  64. package/dist/core/modules/user/core-user.model.js +9 -4
  65. package/dist/core/modules/user/core-user.model.js.map +1 -1
  66. package/dist/core/modules/user/core-user.service.d.ts +9 -13
  67. package/dist/core/modules/user/core-user.service.js +37 -62
  68. package/dist/core/modules/user/core-user.service.js.map +1 -1
  69. package/dist/core/modules/user/inputs/core-user-create.input.js.map +1 -1
  70. package/dist/core/modules/user/inputs/core-user.input.d.ts +2 -2
  71. package/dist/core/modules/user/inputs/core-user.input.js +3 -3
  72. package/dist/core/modules/user/inputs/core-user.input.js.map +1 -1
  73. package/dist/core.module.js +4 -4
  74. package/dist/core.module.js.map +1 -1
  75. package/dist/index.d.ts +6 -2
  76. package/dist/index.js +6 -2
  77. package/dist/index.js.map +1 -1
  78. package/dist/main.js +0 -2
  79. package/dist/main.js.map +1 -1
  80. package/dist/server/common/models/persistence.model.d.ts +4 -2
  81. package/dist/server/common/models/persistence.model.js +6 -2
  82. package/dist/server/common/models/persistence.model.js.map +1 -1
  83. package/dist/server/modules/auth/auth.model.d.ts +1 -0
  84. package/dist/server/modules/auth/auth.model.js +4 -0
  85. package/dist/server/modules/auth/auth.model.js.map +1 -1
  86. package/dist/server/modules/user/inputs/user-create.input.js.map +1 -1
  87. package/dist/server/modules/user/inputs/user.input.js.map +1 -1
  88. package/dist/server/modules/user/user.model.d.ts +3 -2
  89. package/dist/server/modules/user/user.model.js +9 -5
  90. package/dist/server/modules/user/user.model.js.map +1 -1
  91. package/dist/server/modules/user/user.resolver.d.ts +2 -2
  92. package/dist/server/modules/user/user.resolver.js +11 -13
  93. package/dist/server/modules/user/user.resolver.js.map +1 -1
  94. package/dist/server/modules/user/user.service.d.ts +6 -7
  95. package/dist/server/modules/user/user.service.js +7 -7
  96. package/dist/server/modules/user/user.service.js.map +1 -1
  97. package/dist/test/test.helper.d.ts +1 -1
  98. package/dist/tsconfig.build.tsbuildinfo +1 -1
  99. package/package.json +26 -26
  100. package/src/core/common/args/filter.args.ts +22 -1
  101. package/src/core/common/args/pagination.args.ts +42 -7
  102. package/src/core/common/decorators/restricted.decorator.ts +22 -5
  103. package/src/core/common/helpers/context.helper.ts +14 -3
  104. package/src/core/common/helpers/filter.helper.ts +3 -3
  105. package/src/core/common/helpers/input.helper.ts +17 -11
  106. package/src/core/common/helpers/model.helper.ts +0 -3
  107. package/src/core/common/helpers/service.helper.ts +95 -30
  108. package/src/core/common/inputs/combined-filter.input.ts +30 -9
  109. package/src/core/common/inputs/core-input.input.ts +36 -0
  110. package/src/core/common/inputs/filter.input.ts +27 -3
  111. package/src/core/common/inputs/single-filter.input.ts +7 -6
  112. package/src/core/common/inputs/sort.input.ts +4 -3
  113. package/src/core/common/interceptors/check-response.interceptor.ts +2 -2
  114. package/src/core/common/interfaces/core-persistence-model.interface.ts +1 -0
  115. package/src/core/common/interfaces/server-options.interface.ts +3 -33
  116. package/src/core/common/models/core-model.model.ts +42 -3
  117. package/src/core/common/models/core-persistence.model.ts +33 -120
  118. package/src/core/common/pipes/check-input.pipe.ts +13 -33
  119. package/src/core/common/pipes/map-and-validate.pipe.ts +32 -0
  120. package/src/core/common/types/plain-input.type.ts +6 -0
  121. package/src/core/modules/auth/core-auth.model.ts +15 -1
  122. package/src/core/modules/auth/core-auth.module.ts +38 -22
  123. package/src/core/modules/auth/core-auth.resolver.ts +1 -1
  124. package/src/core/modules/user/core-user.model.ts +16 -4
  125. package/src/core/modules/user/core-user.service.ts +58 -110
  126. package/src/core/modules/user/inputs/core-user-create.input.ts +4 -0
  127. package/src/core/modules/user/inputs/core-user.input.ts +7 -3
  128. package/src/core.module.ts +13 -6
  129. package/src/index.ts +6 -2
  130. package/src/main.ts +0 -4
  131. package/src/server/common/models/persistence.model.ts +16 -2
  132. package/src/server/modules/auth/auth.model.ts +13 -0
  133. package/src/server/modules/user/inputs/user-create.input.ts +4 -0
  134. package/src/server/modules/user/inputs/user.input.ts +4 -0
  135. package/src/server/modules/user/user.model.ts +18 -5
  136. package/src/server/modules/user/user.resolver.ts +15 -19
  137. package/src/server/modules/user/user.service.ts +9 -10
  138. package/src/test/test.helper.ts +1 -1
  139. package/dist/core/common/pipes/map.pipe.d.ts +0 -4
  140. package/dist/core/common/pipes/map.pipe.js +0 -25
  141. package/dist/core/common/pipes/map.pipe.js.map +0 -1
  142. package/src/core/common/pipes/map.pipe.ts +0 -16
@@ -16,4 +16,17 @@ export class Auth extends CoreAuthModel {
16
16
  */
17
17
  @Field((type) => User, { description: 'User who signed in' })
18
18
  user: User = undefined;
19
+
20
+ // ===================================================================================================================
21
+ // Properties
22
+ // ===================================================================================================================
23
+
24
+ /**
25
+ * Initialize instance with default values instead of undefined
26
+ */
27
+ init() {
28
+ super.init();
29
+ // Nothing more to initialize yet
30
+ return this;
31
+ }
19
32
  }
@@ -3,6 +3,10 @@ import { CoreUserCreateInput } from '../../../../core/modules/user/inputs/core-u
3
3
 
4
4
  /**
5
5
  * User input to create a new user
6
+ *
7
+ * HINT: All properties (in this class and all classes that extend this class) must be initialized with undefined,
8
+ * otherwise the property will not be recognized via Object.keys (this is necessary for mapping) or will be initialized
9
+ * with a default value that may overwrite an existing value in the DB.
6
10
  */
7
11
  @InputType({ description: 'User input to create a new user' })
8
12
  export class UserCreateInput extends CoreUserCreateInput {
@@ -3,6 +3,10 @@ import { CoreUserInput } from '../../../../core/modules/user/inputs/core-user.in
3
3
 
4
4
  /**
5
5
  * User input to update a user
6
+ *
7
+ * HINT: All properties (in this class and all classes that extend this class) must be initialized with undefined,
8
+ * otherwise the property will not be recognized via Object.keys (this is necessary for mapping) or will be initialized
9
+ * with a default value that may overwrite an existing value in the DB.
6
10
  */
7
11
  @InputType({ description: 'User input' })
8
12
  export class UserInput extends CoreUserInput {
@@ -1,16 +1,16 @@
1
1
  import { Field, ObjectType } from '@nestjs/graphql';
2
2
  import { CoreUserModel } from '../../../core/modules/user/core-user.model';
3
3
  import { PersistenceModel } from '../../common/models/persistence.model';
4
- import { Prop, Schema, SchemaFactory } from '@nestjs/mongoose';
5
- import * as mongoose from 'mongoose';
4
+ import { Prop, Schema as MongooseSchema, SchemaFactory } from '@nestjs/mongoose';
5
+ import { Schema, Document } from 'mongoose';
6
6
 
7
7
  export type UserDocument = User & Document;
8
8
 
9
9
  /**
10
10
  * User schema
11
11
  */
12
- @Schema()
13
12
  @ObjectType({ description: 'User' })
13
+ @MongooseSchema({ timestamps: true })
14
14
  export class User extends CoreUserModel implements PersistenceModel {
15
15
  // ===================================================================================================================
16
16
  // Properties
@@ -32,7 +32,7 @@ export class User extends CoreUserModel implements PersistenceModel {
32
32
  description: 'ID of the user who created the object',
33
33
  nullable: true,
34
34
  })
35
- @Prop({ type: mongoose.Schema.Types.ObjectId, ref: 'User' })
35
+ @Prop({ type: Schema.Types.ObjectId, ref: 'User' })
36
36
  createdBy: User = undefined;
37
37
 
38
38
  /**
@@ -44,8 +44,21 @@ export class User extends CoreUserModel implements PersistenceModel {
44
44
  description: 'ID of the user who last updated the object',
45
45
  nullable: true,
46
46
  })
47
- @Prop({ type: mongoose.Schema.Types.ObjectId, ref: 'User' })
47
+ @Prop({ type: Schema.Types.ObjectId, ref: 'User' })
48
48
  updatedBy: User = undefined;
49
+
50
+ // ===================================================================================================================
51
+ // Methods
52
+ // ===================================================================================================================
53
+
54
+ /**
55
+ * Initialize instance with default values instead of undefined
56
+ */
57
+ init() {
58
+ super.init();
59
+ // Nothing more to initialize yet
60
+ return this;
61
+ }
49
62
  }
50
63
 
51
64
  export const UserSchema = SchemaFactory.createForClass(User);
@@ -47,8 +47,8 @@ export class UserResolver {
47
47
  * Request new password for user with email
48
48
  */
49
49
  @Query((returns) => Boolean, { description: 'Request new password for user with email' })
50
- async requestPasswordResetMail(@Args('email') email: string) {
51
- return await this.usersService.requestPasswordResetMail(email);
50
+ async requestPasswordResetMail(@Args('email') email: string): Promise<boolean> {
51
+ return !!(await this.usersService.sendPasswordResetMail(email));
52
52
  }
53
53
 
54
54
  // ===========================================================================
@@ -58,28 +58,29 @@ export class UserResolver {
58
58
  * Verify user with email
59
59
  */
60
60
  @Mutation((returns) => Boolean, { description: 'Verify user with email' })
61
- async verifyUser(@Args('token') token: string) {
62
- return await this.usersService.verify(token);
61
+ async verifyUser(@Args('token') token: string): Promise<boolean> {
62
+ return !!(await this.usersService.verify(token));
63
63
  }
64
64
 
65
65
  /**
66
66
  * Set new password for user with token
67
67
  */
68
68
  @Mutation((returns) => Boolean, { description: 'Set new password for user with token' })
69
- async resetPassword(@Args('token') token: string, @Args('password') password: string) {
70
- return await this.usersService.resetPassword(token, password);
69
+ async resetPassword(@Args('token') token: string, @Args('password') password: string): Promise<boolean> {
70
+ return !!(await this.usersService.resetPassword(token, password));
71
71
  }
72
72
 
73
73
  /**
74
74
  * Create new user
75
75
  */
76
76
  @Mutation((returns) => User, { description: 'Create a new user' })
77
- async createUser(
78
- @Args('input') input: UserCreateInput,
79
- @GraphQLUser() user: User,
80
- @Info() info: GraphQLResolveInfo
81
- ): Promise<User> {
82
- return await this.usersService.create(input, user, info);
77
+ async createUser(@Args('input') input: UserCreateInput, @GraphQLUser() user: User): Promise<User> {
78
+ // Check input
79
+ // Hint: necessary as long as global CheckInputPipe can't access context for current user
80
+ // (see https://github.com/nestjs/graphql/issues/325)
81
+ input = await InputHelper.check(input, user, UserCreateInput);
82
+
83
+ return await this.usersService.create(input, user);
83
84
  }
84
85
 
85
86
  /**
@@ -87,19 +88,14 @@ export class UserResolver {
87
88
  */
88
89
  @Roles(RoleEnum.ADMIN, RoleEnum.OWNER)
89
90
  @Mutation((returns) => User, { description: 'Update existing user' })
90
- async updateUser(
91
- @Args('input', { type: () => UserInput }) input: UserInput,
92
- @Args('id') id: string,
93
- @GraphQLUser() user: User,
94
- @Info() info: GraphQLResolveInfo
95
- ): Promise<User> {
91
+ async updateUser(@Args('input') input: UserInput, @Args('id') id: string, @GraphQLUser() user: User): Promise<User> {
96
92
  // Check input
97
93
  // Hint: necessary as long as global CheckInputPipe can't access context for current user
98
94
  // (see https://github.com/nestjs/graphql/issues/325)
99
95
  input = await InputHelper.check(input, user, UserInput);
100
96
 
101
97
  // Update user
102
- return await this.usersService.update(id, input, user, info);
98
+ return await this.usersService.update(id, input, user);
103
99
  }
104
100
 
105
101
  /**
@@ -1,6 +1,5 @@
1
1
  import { Inject, Injectable, UnauthorizedException, UnprocessableEntityException } from '@nestjs/common';
2
2
  import * as fs from 'fs';
3
- import { GraphQLResolveInfo } from 'graphql';
4
3
  import envConfig from '../../../config.env';
5
4
  import { FilterArgs } from '../../../core/common/args/filter.args';
6
5
  import { Filter } from '../../../core/common/helpers/filter.helper';
@@ -10,7 +9,7 @@ import { EmailService } from '../../../core/common/services/email.service';
10
9
  import { CoreUserService } from '../../../core/modules/user/core-user.service';
11
10
  import { UserCreateInput } from './inputs/user-create.input';
12
11
  import { UserInput } from './inputs/user.input';
13
- import { User } from './user.model';
12
+ import { User, UserDocument } from './user.model';
14
13
  import { InjectModel } from '@nestjs/mongoose';
15
14
  import { Model } from 'mongoose';
16
15
  import { ICorePersistenceModel } from '../../../core/common/interfaces/core-persistence-model.interface';
@@ -39,7 +38,7 @@ export class UserService extends CoreUserService<User, UserInput, UserCreateInpu
39
38
  constructor(
40
39
  protected readonly configService: ConfigService,
41
40
  protected readonly emailService: EmailService,
42
- @InjectModel('User') protected readonly userModel: Model<User>,
41
+ @InjectModel('User') protected readonly userModel: Model<UserDocument>,
43
42
  @Inject('PUB_SUB') protected readonly pubSub: PubSub
44
43
  ) {
45
44
  super(userModel, emailService);
@@ -53,10 +52,10 @@ export class UserService extends CoreUserService<User, UserInput, UserCreateInpu
53
52
  /**
54
53
  * Create new user and send welcome email
55
54
  */
56
- async create(input: UserCreateInput, currentUser?: User, ...args: any[]): Promise<User> {
55
+ async create(input: UserCreateInput, currentUser?: User): Promise<User> {
57
56
  const user = await super.create(input, currentUser);
58
57
 
59
- await this.prepareOutput(user, args[0]);
58
+ await this.prepareOutput(user);
60
59
 
61
60
  await this.pubSub.publish('userCreated', User.map(user));
62
61
 
@@ -82,15 +81,15 @@ export class UserService extends CoreUserService<User, UserInput, UserCreateInpu
82
81
  *
83
82
  * @param email
84
83
  */
85
- async requestPasswordResetMail(email: string): Promise<boolean> {
86
- const user = await super.sentResetPasswordMail(email);
84
+ async sendPasswordResetMail(email: string): Promise<User> {
85
+ const user = await super.setPasswordResetTokenForEmail(email);
87
86
 
88
87
  await this.emailService.sendMail(user.email, 'Password reset', {
89
88
  htmlTemplate: 'password-reset',
90
89
  templateData: { name: user.username, link: envConfig.email.passwordResetLink + '/' + user.passwordResetToken },
91
90
  });
92
91
 
93
- return true;
92
+ return user;
94
93
  }
95
94
 
96
95
  /**
@@ -140,7 +139,7 @@ export class UserService extends CoreUserService<User, UserInput, UserCreateInpu
140
139
  /**
141
140
  * Prepare output before return
142
141
  */
143
- protected async prepareOutput(user: User, info?: GraphQLResolveInfo) {
144
- return ServiceHelper.prepareOutput(user, User, this);
142
+ protected async prepareOutput(user: User): Promise<User> {
143
+ return ServiceHelper.prepareOutput(user);
145
144
  }
146
145
  }
@@ -18,7 +18,7 @@ export enum TestGraphQLType {
18
18
  * GraphQL fields
19
19
  */
20
20
  export interface TestFieldObject {
21
- [key: string]: boolean | string[] | TestFieldObject;
21
+ [key: string]: boolean | (string | TestFieldObject)[] | TestFieldObject;
22
22
  }
23
23
 
24
24
  /**
@@ -1,4 +0,0 @@
1
- import { PipeTransform, ArgumentMetadata } from '@nestjs/common';
2
- export declare class MapPipe implements PipeTransform {
3
- transform(value: any, metadata: ArgumentMetadata): any;
4
- }
@@ -1,25 +0,0 @@
1
- "use strict";
2
- var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
- return c > 3 && r && Object.defineProperty(target, key, r), r;
7
- };
8
- Object.defineProperty(exports, "__esModule", { value: true });
9
- exports.MapPipe = void 0;
10
- const common_1 = require("@nestjs/common");
11
- let MapPipe = class MapPipe {
12
- transform(value, metadata) {
13
- var _a;
14
- let result = value;
15
- if ((_a = metadata.metatype) === null || _a === void 0 ? void 0 : _a.map) {
16
- result = metadata.metatype.map(value);
17
- }
18
- return result;
19
- }
20
- };
21
- MapPipe = __decorate([
22
- (0, common_1.Injectable)()
23
- ], MapPipe);
24
- exports.MapPipe = MapPipe;
25
- //# sourceMappingURL=map.pipe.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"map.pipe.js","sourceRoot":"","sources":["../../../../src/core/common/pipes/map.pipe.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAA6E;AAG7E,IAAa,OAAO,GAApB,MAAa,OAAO;IAClB,SAAS,CAAC,KAAU,EAAE,QAA0B;;QAC9C,IAAI,MAAM,GAAG,KAAK,CAAC;QAGnB,IAAI,MAAC,QAAQ,CAAC,QAAgB,0CAAE,GAAG,EAAE;YAEnC,MAAM,GAAI,QAAQ,CAAC,QAAgB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;SAChD;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;CACF,CAAA;AAZY,OAAO;IADnB,IAAA,mBAAU,GAAE;GACA,OAAO,CAYnB;AAZY,0BAAO"}
@@ -1,16 +0,0 @@
1
- import { PipeTransform, Injectable, ArgumentMetadata } from '@nestjs/common';
2
-
3
- @Injectable()
4
- export class MapPipe implements PipeTransform {
5
- transform(value: any, metadata: ArgumentMetadata) {
6
- let result = value;
7
-
8
- // Check map function is available
9
- if ((metadata.metatype as any)?.map) {
10
- // Map object to correct type
11
- result = (metadata.metatype as any).map(value);
12
- }
13
-
14
- return result;
15
- }
16
- }