@nest-extended/cli 0.0.2-beta-1 → 0.0.2-beta-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.
- package/package.json +1 -1
- package/src/commands/generate.js +38 -12
- package/src/commands/generate.js.map +1 -1
- package/src/index.js +8 -1
- package/src/index.js.map +1 -1
- package/src/templates/auth.template.js +18 -16
- package/src/templates/auth.template.js.map +1 -1
- package/src/templates/controller.template.js +7 -7
- package/src/templates/controller.template.js.map +1 -1
- package/src/templates/module.template.js +1 -1
- package/src/templates/module.template.js.map +1 -1
- package/src/templates/users.template.js +3 -4
- package/src/templates/users.template.js.map +1 -1
package/package.json
CHANGED
package/src/commands/generate.js
CHANGED
|
@@ -42,6 +42,17 @@ exports.generateCommand
|
|
|
42
42
|
(0, create_file_1.createFileWithContent)(`src/services/${name}/${name}.service.spec.ts`, (0, service_spec_template_1.getServiceSpec)(Name, name));
|
|
43
43
|
(0, create_file_1.createFileWithContent)(`src/services/${name}/${name}.controller.spec.ts`, (0, controller_spec_template_1.getControllerSpec)(Name, name));
|
|
44
44
|
yield (0, update_app_module_1.updateAppModule)(Name, name);
|
|
45
|
+
console.log(chalk.blue('Running lint...'));
|
|
46
|
+
const projectDir = process.cwd();
|
|
47
|
+
const pkgManager = fs.existsSync(path.join(projectDir, 'yarn.lock')) ? 'yarn' : 'npm';
|
|
48
|
+
yield new Promise((resolve) => {
|
|
49
|
+
const lintChild = (0, child_process_1.spawn)(pkgManager, ['run', 'lint'], {
|
|
50
|
+
stdio: 'inherit',
|
|
51
|
+
cwd: projectDir,
|
|
52
|
+
shell: true,
|
|
53
|
+
});
|
|
54
|
+
lintChild.on('close', () => resolve());
|
|
55
|
+
});
|
|
45
56
|
}));
|
|
46
57
|
exports.generateCommand
|
|
47
58
|
.command('app <name>')
|
|
@@ -55,7 +66,8 @@ exports.generateCommand
|
|
|
55
66
|
choices: ['mongo', 'sql'],
|
|
56
67
|
},
|
|
57
68
|
];
|
|
58
|
-
// @ts-
|
|
69
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
70
|
+
// @ts-expect-error
|
|
59
71
|
const answers = yield inquirer.prompt(questions);
|
|
60
72
|
const database = answers['database'];
|
|
61
73
|
if (database === 'sql') {
|
|
@@ -63,9 +75,11 @@ exports.generateCommand
|
|
|
63
75
|
process.exit(1);
|
|
64
76
|
}
|
|
65
77
|
console.log(chalk.blue(`Generating NestJS app: ${appName}`));
|
|
78
|
+
const appDir = path.join(process.cwd(), appName);
|
|
79
|
+
const pkgManager = fs.existsSync(path.join(process.cwd(), 'yarn.lock')) ? 'yarn' : 'npm';
|
|
66
80
|
// 1. Run nest new
|
|
67
81
|
yield new Promise((resolve, reject) => {
|
|
68
|
-
const child = (0, child_process_1.spawn)('npx', ['@nestjs/cli', 'new', appName, '--package-manager',
|
|
82
|
+
const child = (0, child_process_1.spawn)('npx', ['@nestjs/cli', 'new', appName, '--package-manager', pkgManager], {
|
|
69
83
|
stdio: 'inherit',
|
|
70
84
|
shell: true,
|
|
71
85
|
});
|
|
@@ -76,21 +90,23 @@ exports.generateCommand
|
|
|
76
90
|
reject(new Error(`nest new failed with code ${code}`));
|
|
77
91
|
});
|
|
78
92
|
});
|
|
79
|
-
const
|
|
93
|
+
const pkg = require('../../package.json');
|
|
94
|
+
const nestExtendedVersion = pkg.version;
|
|
80
95
|
console.log(chalk.blue('Installing additional dependencies...'));
|
|
81
96
|
// 2. Install dependencies
|
|
82
97
|
yield new Promise((resolve, reject) => {
|
|
83
|
-
const
|
|
84
|
-
|
|
98
|
+
const installArgs = pkgManager === 'yarn' ? ['add'] : ['install'];
|
|
99
|
+
const child = (0, child_process_1.spawn)(pkgManager, [
|
|
100
|
+
...installArgs,
|
|
85
101
|
'@nestjs/mongoose',
|
|
86
102
|
'mongoose',
|
|
87
103
|
'@nestjs/config',
|
|
88
104
|
'nestjs-cls',
|
|
89
105
|
'@nestjs/jwt',
|
|
90
106
|
'bcrypt',
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
107
|
+
`@nest-extended/core@${nestExtendedVersion}`,
|
|
108
|
+
`@nest-extended/mongoose@${nestExtendedVersion}`,
|
|
109
|
+
`@nest-extended/decorators@${nestExtendedVersion}`,
|
|
94
110
|
'zod'
|
|
95
111
|
], {
|
|
96
112
|
stdio: 'inherit',
|
|
@@ -101,12 +117,13 @@ exports.generateCommand
|
|
|
101
117
|
if (code === 0)
|
|
102
118
|
resolve();
|
|
103
119
|
else
|
|
104
|
-
reject(new Error(
|
|
120
|
+
reject(new Error(`${pkgManager} install failed with code ${code}`));
|
|
105
121
|
});
|
|
106
122
|
});
|
|
107
123
|
// 3. Install Dev dependencies
|
|
108
124
|
yield new Promise((resolve, reject) => {
|
|
109
|
-
const
|
|
125
|
+
const devArgs = pkgManager === 'yarn' ? ['add', '-D'] : ['install', '-D'];
|
|
126
|
+
const child = (0, child_process_1.spawn)(pkgManager, [...devArgs, '@types/bcrypt'], {
|
|
110
127
|
stdio: 'inherit',
|
|
111
128
|
cwd: appDir,
|
|
112
129
|
shell: true,
|
|
@@ -115,7 +132,7 @@ exports.generateCommand
|
|
|
115
132
|
if (code === 0)
|
|
116
133
|
resolve();
|
|
117
134
|
else
|
|
118
|
-
reject(new Error(
|
|
135
|
+
reject(new Error(`${pkgManager} dev install failed with code ${code}`));
|
|
119
136
|
});
|
|
120
137
|
});
|
|
121
138
|
console.log(chalk.blue('Configuring project...'));
|
|
@@ -143,7 +160,7 @@ import { UsersModule } from './services/users/users.module';
|
|
|
143
160
|
NestExtendedModule.forRoot({
|
|
144
161
|
softDelete: {
|
|
145
162
|
getQuery: () => ({ deleted: { $ne: true } }),
|
|
146
|
-
getData: (user:
|
|
163
|
+
getData: (user: { _id?: string } | null) => ({
|
|
147
164
|
deleted: true,
|
|
148
165
|
deletedBy: user?._id,
|
|
149
166
|
deletedAt: new Date(),
|
|
@@ -177,6 +194,15 @@ import { UsersModule } from './services/users/users.module';
|
|
|
177
194
|
fs.writeFileSync(path.join(authDir, 'auth.guard.ts'), (0, auth_template_1.getAuthGuard)());
|
|
178
195
|
fs.writeFileSync(path.join(authDir, 'constants/jwt-constants.ts'), (0, auth_template_1.getJwtConstants)());
|
|
179
196
|
fs.writeFileSync(path.join(authDir, 'decorators/public.decorator.ts'), (0, auth_template_1.getPublicDecorator)());
|
|
197
|
+
console.log(chalk.blue('Running lint...'));
|
|
198
|
+
yield new Promise((resolve) => {
|
|
199
|
+
const lintChild = (0, child_process_1.spawn)(pkgManager, ['run', 'lint'], {
|
|
200
|
+
stdio: 'inherit',
|
|
201
|
+
cwd: appDir,
|
|
202
|
+
shell: true,
|
|
203
|
+
});
|
|
204
|
+
lintChild.on('close', () => resolve());
|
|
205
|
+
});
|
|
180
206
|
console.log(chalk.green('App generated successfully!'));
|
|
181
207
|
}));
|
|
182
208
|
//# sourceMappingURL=generate.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generate.js","sourceRoot":"","sources":["../../../../../packages/cli/src/commands/generate.ts"],"names":[],"mappings":";;;;AACA,yCAAoC;AACpC,qCAAqC;AACrC,+BAA+B;AAC/B,6BAA6B;AAC7B,+BAA+B;AAC/B,iDAAsC;AACtC,oDAA2D;AAC3D,gEAA2D;AAC3D,kEAAyD;AACzD,oEAA2D;AAC3D,0EAAiE;AACjE,4DAAmD;AACnD,kEAAyD;AACzD,8EAAoE;AACpE,oFAA0E;AAE1E,8DAOoC;AACpC,gEAA8E;AAEjE,QAAA,eAAe,GAAG,IAAI,mBAAO,CAAC,UAAU,CAAC;KACjD,KAAK,CAAC,GAAG,CAAC;KACV,WAAW,CAAC,wBAAwB,CAAC,CAAC;AAE3C,uBAAe;KACV,OAAO,CAAC,gBAAgB,CAAC;KACzB,WAAW,CAAC,wBAAwB,CAAC;KACrC,MAAM,CAAC,CAAO,OAAe,EAAE,EAAE;IAC9B,qEAAqE;IACrE,MAAM,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACpC,QAAQ,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;QAC5B,QAAQ,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;IACxE,CAAC,CAAC,CAAC;IACH,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa;IAC7C,MAAM,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY;IAEhE,OAAO,CAAC,GAAG,CAAC,2BAA2B,IAAI,KAAK,IAAI,GAAG,CAAC,CAAC;IAEzD,IAAA,mCAAqB,EAAC,eAAe,IAAI,YAAY,EAAE,IAAA,2BAAS,EAAC,IAAI,CAAC,CAAC,CAAC;IACxE,IAAA,mCAAqB,EAAC,gBAAgB,IAAI,IAAI,IAAI,YAAY,EAAE,IAAA,2BAAS,EAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;IACvF,IAAA,mCAAqB,EAAC,gBAAgB,IAAI,IAAI,IAAI,aAAa,EAAE,IAAA,6BAAU,EAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;IACzF,IAAA,mCAAqB,EACjB,gBAAgB,IAAI,IAAI,IAAI,gBAAgB,EAC5C,IAAA,mCAAa,EAAC,IAAI,EAAE,IAAI,EAAE,OAAO,CAAC,CACrC,CAAC;IACF,IAAA,mCAAqB,EAAC,gBAAgB,IAAI,QAAQ,IAAI,SAAS,EAAE,IAAA,qBAAM,EAAC,IAAI,CAAC,CAAC,CAAC;IAC/E,IAAA,mCAAqB,EACjB,gBAAgB,IAAI,IAAI,IAAI,kBAAkB,EAC9C,IAAA,sCAAc,EAAC,IAAI,EAAE,IAAI,CAAC,CAC7B,CAAC;IACF,IAAA,mCAAqB,EACjB,gBAAgB,IAAI,IAAI,IAAI,qBAAqB,EACjD,IAAA,4CAAiB,EAAC,IAAI,EAAE,IAAI,CAAC,CAChC,CAAC;IAEF,MAAM,IAAA,mCAAe,EAAC,IAAI,EAAE,IAAI,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"generate.js","sourceRoot":"","sources":["../../../../../packages/cli/src/commands/generate.ts"],"names":[],"mappings":"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"}
|
package/src/index.js
CHANGED
|
@@ -6,10 +6,17 @@ const generate_1 = require("./commands/generate");
|
|
|
6
6
|
const migration_1 = require("./commands/migration");
|
|
7
7
|
const program = new commander_1.Command();
|
|
8
8
|
const chalk = require("chalk");
|
|
9
|
+
const pkg = require('../package.json');
|
|
9
10
|
program
|
|
10
11
|
.name('nest-cli')
|
|
11
12
|
.description('CLI for @nest-extended packages')
|
|
12
|
-
.version(
|
|
13
|
+
.version(pkg.version);
|
|
14
|
+
program.command('version')
|
|
15
|
+
.alias('v')
|
|
16
|
+
.description('Output the version number')
|
|
17
|
+
.action(() => {
|
|
18
|
+
console.log(pkg.version);
|
|
19
|
+
});
|
|
13
20
|
program.addCommand(generate_1.generateCommand);
|
|
14
21
|
program.addCommand(migration_1.migrationCommand);
|
|
15
22
|
program.command('help')
|
package/src/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../packages/cli/src/index.ts"],"names":[],"mappings":";;;AACA,yCAAoC;AACpC,kDAAsD;AACtD,oDAAwD;AAExD,MAAM,OAAO,GAAG,IAAI,mBAAO,EAAE,CAAC;AAE9B,+BAA+B;AAE/B,OAAO;KACF,IAAI,CAAC,UAAU,CAAC;KAChB,WAAW,CAAC,iCAAiC,CAAC;KAC9C,OAAO,CAAC,OAAO,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../packages/cli/src/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -14,6 +14,7 @@ const getAuthController = () => `import {
|
|
|
14
14
|
import { AuthService } from './auth.service';
|
|
15
15
|
import { Public } from './decorators/public.decorator';
|
|
16
16
|
import { UsersService } from '../users/users.service';
|
|
17
|
+
import { UsersDocument } from '../../schemas/users.schema';
|
|
17
18
|
|
|
18
19
|
@Controller('authentication')
|
|
19
20
|
export class AuthController {
|
|
@@ -25,7 +26,7 @@ export class AuthController {
|
|
|
25
26
|
@Public()
|
|
26
27
|
@HttpCode(HttpStatus.OK)
|
|
27
28
|
@Post('')
|
|
28
|
-
signIn(@Body() signInDto: Record<string,
|
|
29
|
+
signIn(@Body() signInDto: Record<string, string>) {
|
|
29
30
|
if (signInDto.strategy === 'local') {
|
|
30
31
|
return this.authService.signInLocal(signInDto.email, signInDto.password);
|
|
31
32
|
}
|
|
@@ -33,10 +34,10 @@ export class AuthController {
|
|
|
33
34
|
}
|
|
34
35
|
|
|
35
36
|
@Get('verify')
|
|
36
|
-
getProfile(@Request() req: any) {
|
|
37
|
+
getProfile(@Request() req: Record<string, any>) {
|
|
38
|
+
const user = req.user as UsersDocument;
|
|
37
39
|
return {
|
|
38
|
-
user: this.usersService.sanitizeUser(
|
|
39
|
-
organizationUsers: req.orgUsers,
|
|
40
|
+
user: this.usersService.sanitizeUser(user),
|
|
40
41
|
};
|
|
41
42
|
}
|
|
42
43
|
}
|
|
@@ -54,8 +55,9 @@ export class AuthService {
|
|
|
54
55
|
private jwtService: JwtService,
|
|
55
56
|
) { }
|
|
56
57
|
|
|
57
|
-
async signInLocal(email: string, pass: string): Promise<
|
|
58
|
-
|
|
58
|
+
async signInLocal(email: string, pass: string): Promise<Record<string, unknown>> {
|
|
59
|
+
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
|
|
60
|
+
const [user] = (await this.usersService._find({
|
|
59
61
|
email,
|
|
60
62
|
$limit: 1,
|
|
61
63
|
$select: [
|
|
@@ -67,17 +69,18 @@ export class AuthService {
|
|
|
67
69
|
'createdAt',
|
|
68
70
|
'updatedAt',
|
|
69
71
|
],
|
|
70
|
-
}, { pagination: false })
|
|
72
|
+
}, { pagination: false })) as Array<Record<string, any>>;
|
|
71
73
|
|
|
74
|
+
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
|
|
72
75
|
if (!user) throw new UnauthorizedException();
|
|
73
76
|
|
|
74
|
-
const passwordValid = await bcrypt.compare(pass, user.password);
|
|
77
|
+
const passwordValid = await bcrypt.compare(pass, user.password as string);
|
|
75
78
|
if (!passwordValid) {
|
|
76
79
|
throw new UnauthorizedException();
|
|
77
80
|
}
|
|
78
81
|
|
|
79
82
|
const sanitizedUser = this.usersService.sanitizeUser(user);
|
|
80
|
-
const payload = { sub: { id: user._id }, user };
|
|
83
|
+
const payload = { sub: { id: user._id as string }, user };
|
|
81
84
|
return {
|
|
82
85
|
accessToken: await this.jwtService.signAsync(payload),
|
|
83
86
|
user: sanitizedUser,
|
|
@@ -125,7 +128,6 @@ const getAuthGuard = () => `import {
|
|
|
125
128
|
} from '@nestjs/common';
|
|
126
129
|
import { Reflector } from '@nestjs/core';
|
|
127
130
|
import { JwtService } from '@nestjs/jwt';
|
|
128
|
-
import { Request } from 'express';
|
|
129
131
|
import { IS_PUBLIC_KEY } from './decorators/public.decorator';
|
|
130
132
|
import { UsersService } from '../users/users.service';
|
|
131
133
|
import { jwtConstants } from './constants/jwt-constants';
|
|
@@ -148,18 +150,18 @@ export class AuthGuard implements CanActivate {
|
|
|
148
150
|
if (isPublic) {
|
|
149
151
|
return true;
|
|
150
152
|
}
|
|
151
|
-
const request = context.switchToHttp().getRequest();
|
|
152
|
-
const token = this.extractTokenFromHeader(request
|
|
153
|
+
const request = context.switchToHttp().getRequest<{ user?: Record<string, unknown>, headers: Record<string, string | undefined> }>();
|
|
154
|
+
const token = this.extractTokenFromHeader(request);
|
|
153
155
|
if (!token) {
|
|
154
156
|
throw new UnauthorizedException();
|
|
155
157
|
}
|
|
156
158
|
try {
|
|
157
|
-
const payload = await this.jwtService.verifyAsync(token, {
|
|
159
|
+
const payload = await this.jwtService.verifyAsync<{ sub: { id: string } }>(token, {
|
|
158
160
|
secret: jwtConstants.secret,
|
|
159
161
|
});
|
|
160
|
-
const user = await this.usersService._get(payload.sub.id)
|
|
162
|
+
const user = (await this.usersService._get(payload.sub.id)) as Record<string, unknown>;
|
|
161
163
|
if (user) {
|
|
162
|
-
request
|
|
164
|
+
request.user = user;
|
|
163
165
|
this.cls.set('user', user);
|
|
164
166
|
return true;
|
|
165
167
|
}
|
|
@@ -169,7 +171,7 @@ export class AuthGuard implements CanActivate {
|
|
|
169
171
|
throw new UnauthorizedException();
|
|
170
172
|
}
|
|
171
173
|
|
|
172
|
-
private extractTokenFromHeader(request:
|
|
174
|
+
private extractTokenFromHeader(request: { headers: Record<string, string | undefined> }): string | undefined {
|
|
173
175
|
const [type, token] = request.headers.authorization?.split(' ') ?? [];
|
|
174
176
|
return type === 'Bearer' ? token : undefined;
|
|
175
177
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth.template.js","sourceRoot":"","sources":["../../../../../packages/cli/src/templates/auth.template.ts"],"names":[],"mappings":";;;AAAO,MAAM,iBAAiB,GAAG,GAAW,EAAE,CAAC
|
|
1
|
+
{"version":3,"file":"auth.template.js","sourceRoot":"","sources":["../../../../../packages/cli/src/templates/auth.template.ts"],"names":[],"mappings":";;;AAAO,MAAM,iBAAiB,GAAG,GAAW,EAAE,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAwC9C,CAAC;AAxCW,QAAA,iBAAiB,qBAwC5B;AAEK,MAAM,cAAc,GAAG,GAAW,EAAE,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4C3C,CAAC;AA5CW,QAAA,cAAc,kBA4CzB;AAEK,MAAM,aAAa,GAAG,GAAW,EAAE,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA6B1C,CAAC;AA7BW,QAAA,aAAa,iBA6BxB;AAEK,MAAM,YAAY,GAAG,GAAW,EAAE,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAwDzC,CAAC;AAxDW,QAAA,YAAY,gBAwDvB;AAEK,MAAM,kBAAkB,GAAG,GAAW,EAAE,CAAC;;;CAG/C,CAAC;AAHW,QAAA,kBAAkB,sBAG7B;AAEK,MAAM,eAAe,GAAG,GAAW,EAAE,CAAC;;;;;CAK5C,CAAC;AALW,QAAA,eAAe,mBAK1B"}
|
|
@@ -13,7 +13,7 @@ const getController = (Name, name, url) => `import {
|
|
|
13
13
|
} from '@nestjs/common';
|
|
14
14
|
import { ${Name}Service } from './${name}.service';
|
|
15
15
|
import { User, ModifyBody, setCreatedBy } from '@nest-extended/decorators';
|
|
16
|
-
import { ${Name} } from '
|
|
16
|
+
import { ${Name} } from '../../schemas/${name}.schema';
|
|
17
17
|
|
|
18
18
|
@Controller('${url}')
|
|
19
19
|
export class ${Name}Controller {
|
|
@@ -24,7 +24,7 @@ export class ${Name}Controller {
|
|
|
24
24
|
return await this.${name}Service._find(query);
|
|
25
25
|
}
|
|
26
26
|
|
|
27
|
-
@Get('/:id
|
|
27
|
+
@Get('/:id')
|
|
28
28
|
async get(@Query() query: Record<string, any>, @Param('id') id: string) {
|
|
29
29
|
return await this.${name}Service._get(id, query);
|
|
30
30
|
}
|
|
@@ -36,17 +36,17 @@ export class ${Name}Controller {
|
|
|
36
36
|
return await this.${name}Service._create(create${Name}Dto);
|
|
37
37
|
}
|
|
38
38
|
|
|
39
|
-
@Patch('/:id
|
|
39
|
+
@Patch('/:id')
|
|
40
40
|
async patch(
|
|
41
|
-
@Query() query,
|
|
41
|
+
@Query() query: Record<string, any>,
|
|
42
42
|
@Body() patch${Name}Dto: Partial<${Name}>,
|
|
43
|
-
@Param('id') id,
|
|
43
|
+
@Param('id') id: string,
|
|
44
44
|
) {
|
|
45
45
|
return await this.${name}Service._patch(id, patch${Name}Dto, query);
|
|
46
46
|
}
|
|
47
47
|
|
|
48
|
-
@Delete('/:id
|
|
49
|
-
async delete(@Param('id') id, @Query() query, @User() user) {
|
|
48
|
+
@Delete('/:id')
|
|
49
|
+
async delete(@Param('id') id: string, @Query() query: Record<string, any>, @User() user: Record<string, unknown>) {
|
|
50
50
|
return await this.${name}Service._remove(id, query, user);
|
|
51
51
|
}
|
|
52
52
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"controller.template.js","sourceRoot":"","sources":["../../../../../packages/cli/src/templates/controller.template.ts"],"names":[],"mappings":";;;AACO,MAAM,aAAa,GAAG,CAAC,IAAY,EAAE,IAAY,EAAE,GAAW,EAAU,EAAE,CAAC;;;;;;;;;;WAUvE,IAAI,qBAAqB,IAAI;;WAE7B,IAAI,
|
|
1
|
+
{"version":3,"file":"controller.template.js","sourceRoot":"","sources":["../../../../../packages/cli/src/templates/controller.template.ts"],"names":[],"mappings":";;;AACO,MAAM,aAAa,GAAG,CAAC,IAAY,EAAE,IAAY,EAAE,GAAW,EAAU,EAAE,CAAC;;;;;;;;;;WAUvE,IAAI,qBAAqB,IAAI;;WAE7B,IAAI,0BAA0B,IAAI;;eAE9B,GAAG;eACH,IAAI;iCACc,IAAI,YAAY,IAAI;;;;wBAI7B,IAAI;;;;;wBAKJ,IAAI;;;;;wCAKY,IAAI,QAAQ,IAAI;;wBAEhC,IAAI,yBAAyB,IAAI;;;;;;mBAMtC,IAAI,gBAAgB,IAAI;;;wBAGnB,IAAI,2BAA2B,IAAI;;;;;wBAKnC,IAAI;;;CAG3B,CAAC;AAjDW,QAAA,aAAa,iBAiDxB"}
|
|
@@ -5,7 +5,7 @@ const getModule = (Name, name) => `import { Module } from '@nestjs/common';
|
|
|
5
5
|
import { MongooseModule } from '@nestjs/mongoose';
|
|
6
6
|
import { ${Name}Controller } from './${name}.controller';
|
|
7
7
|
import { ${Name}Service } from './${name}.service';
|
|
8
|
-
import { ${Name}, ${Name}Schema } from '
|
|
8
|
+
import { ${Name}, ${Name}Schema } from '../../schemas/${name}.schema';
|
|
9
9
|
|
|
10
10
|
@Module({
|
|
11
11
|
imports: [
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"module.template.js","sourceRoot":"","sources":["../../../../../packages/cli/src/templates/module.template.ts"],"names":[],"mappings":";;;AACO,MAAM,SAAS,GAAG,CAAC,IAAY,EAAE,IAAY,EAAU,EAAE,CAAC;;WAEtD,IAAI,wBAAwB,IAAI;WAChC,IAAI,qBAAqB,IAAI;WAC7B,IAAI,KAAK,IAAI,
|
|
1
|
+
{"version":3,"file":"module.template.js","sourceRoot":"","sources":["../../../../../packages/cli/src/templates/module.template.ts"],"names":[],"mappings":";;;AACO,MAAM,SAAS,GAAG,CAAC,IAAY,EAAE,IAAY,EAAU,EAAE,CAAC;;WAEtD,IAAI,wBAAwB,IAAI;WAChC,IAAI,qBAAqB,IAAI;WAC7B,IAAI,KAAK,IAAI,gCAAgC,IAAI;;;;yCAInB,IAAI,kBAAkB,IAAI;;kBAEjD,IAAI;;MAEhB,IAAI;;cAEI,IAAI;;eAEH,IAAI;CAClB,CAAC;AAjBW,QAAA,SAAS,aAiBpB"}
|
|
@@ -38,7 +38,7 @@ const getUsersService = () => `import { Model } from 'mongoose';
|
|
|
38
38
|
import { Injectable } from '@nestjs/common';
|
|
39
39
|
import { InjectModel } from '@nestjs/mongoose';
|
|
40
40
|
import { NestService } from '@nest-extended/mongoose';
|
|
41
|
-
import { Users, UsersDocument } from '
|
|
41
|
+
import { Users, UsersDocument } from '../../schemas/users.schema';
|
|
42
42
|
|
|
43
43
|
@Injectable()
|
|
44
44
|
export class UsersService extends NestService<Users, UsersDocument> {
|
|
@@ -48,9 +48,8 @@ export class UsersService extends NestService<Users, UsersDocument> {
|
|
|
48
48
|
super(usersModel);
|
|
49
49
|
}
|
|
50
50
|
|
|
51
|
-
sanitizeUser(user:
|
|
52
|
-
|
|
53
|
-
const sanitized = user.toObject ? user.toObject() : { ...user };
|
|
51
|
+
sanitizeUser(user: UsersDocument) {
|
|
52
|
+
const sanitized = user.toObject() as Record<string, unknown>;
|
|
54
53
|
delete sanitized['password'];
|
|
55
54
|
return sanitized;
|
|
56
55
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"users.template.js","sourceRoot":"","sources":["../../../../../packages/cli/src/templates/users.template.ts"],"names":[],"mappings":";;;AAAO,MAAM,cAAc,GAAG,GAAW,EAAE,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA+B3C,CAAC;AA/BW,QAAA,cAAc,kBA+BzB;AAEK,MAAM,eAAe,GAAG,GAAW,EAAE,CAAC
|
|
1
|
+
{"version":3,"file":"users.template.js","sourceRoot":"","sources":["../../../../../packages/cli/src/templates/users.template.ts"],"names":[],"mappings":";;;AAAO,MAAM,cAAc,GAAG,GAAW,EAAE,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA+B3C,CAAC;AA/BW,QAAA,cAAc,kBA+BzB;AAEK,MAAM,eAAe,GAAG,GAAW,EAAE,CAAC;;;;;;;;;;;;;;;;;;;;CAoB5C,CAAC;AApBW,QAAA,eAAe,mBAoB1B"}
|