@decaf-ts/for-nest 0.0.2 → 0.0.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 (47) hide show
  1. package/dist/for-nest.cjs +468 -15
  2. package/dist/for-nest.esm.cjs +468 -14
  3. package/lib/RepoFactory.cjs +27 -0
  4. package/lib/RepoFactory.d.ts +6 -0
  5. package/lib/core-module.cjs +27 -7
  6. package/lib/core-module.d.ts +7 -2
  7. package/lib/decoration.cjs +123 -0
  8. package/lib/decoration.d.ts +1 -0
  9. package/lib/decorators/ApiProperty.cjs +63 -0
  10. package/lib/decorators/ApiProperty.d.ts +27 -0
  11. package/lib/decorators/helpers.cjs +140 -0
  12. package/lib/decorators/helpers.d.ts +8 -0
  13. package/lib/decorators/index.cjs +19 -0
  14. package/lib/decorators/index.d.ts +2 -0
  15. package/lib/esm/RepoFactory.d.ts +6 -0
  16. package/lib/esm/RepoFactory.js +24 -0
  17. package/lib/esm/core-module.d.ts +7 -2
  18. package/lib/esm/core-module.js +27 -7
  19. package/lib/esm/decoration.d.ts +1 -0
  20. package/lib/esm/decoration.js +121 -0
  21. package/lib/esm/decorators/ApiProperty.d.ts +27 -0
  22. package/lib/esm/decorators/ApiProperty.js +57 -0
  23. package/lib/esm/decorators/helpers.d.ts +8 -0
  24. package/lib/esm/decorators/helpers.js +132 -0
  25. package/lib/esm/decorators/index.d.ts +2 -0
  26. package/lib/esm/decorators/index.js +3 -0
  27. package/lib/esm/index.d.ts +7 -2
  28. package/lib/esm/index.js +8 -3
  29. package/lib/esm/model-module.d.ts +8 -0
  30. package/lib/esm/model-module.js +119 -0
  31. package/lib/esm/module.d.ts +1 -1
  32. package/lib/esm/module.js +11 -3
  33. package/lib/esm/types.d.ts +1 -0
  34. package/lib/esm/types.js +1 -1
  35. package/lib/esm/utils.d.ts +2 -0
  36. package/lib/esm/utils.js +11 -0
  37. package/lib/index.cjs +8 -3
  38. package/lib/index.d.ts +7 -2
  39. package/lib/model-module.cjs +122 -0
  40. package/lib/model-module.d.ts +8 -0
  41. package/lib/module.cjs +11 -3
  42. package/lib/module.d.ts +1 -1
  43. package/lib/types.cjs +1 -1
  44. package/lib/types.d.ts +1 -0
  45. package/lib/utils.cjs +14 -0
  46. package/lib/utils.d.ts +2 -0
  47. package/package.json +4 -2
package/dist/for-nest.cjs CHANGED
@@ -1,19 +1,332 @@
1
1
  (function (global, factory) {
2
- typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@decaf-ts/decoration'), require('tslib'), require('@nestjs/common'), require('@nestjs/core'), require('@decaf-ts/logging/lib/LoggedClass')) :
3
- typeof define === 'function' && define.amd ? define(['exports', '@decaf-ts/decoration', 'tslib', '@nestjs/common', '@nestjs/core', '@decaf-ts/logging/lib/LoggedClass'], factory) :
4
- (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["for-nest"] = {}, global.decoration, global.tslib, global.common, global.core, global.LoggedClass));
5
- })(this, (function (exports, decoration, tslib, common, core, LoggedClass) { 'use strict';
2
+ typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@decaf-ts/decoration'), require('@decaf-ts/injectable-decorators'), require('@nestjs/common'), require('@decaf-ts/decorator-validation'), require('@nestjs/swagger/dist/decorators/helpers'), require('@nestjs/swagger/dist/utils/enum.utils'), require('@nestjs/swagger/dist/constants'), require('@nestjs/common/constants'), require('@nestjs/common/utils/shared.utils'), require('lodash'), require('@nestjs/swagger/dist/plugin/plugin-constants'), require('@decaf-ts/core'), require('tslib'), require('@nestjs/core'), require('@decaf-ts/logging'), require('@nestjs/swagger'), require('@decaf-ts/db-decorators')) :
3
+ typeof define === 'function' && define.amd ? define(['exports', '@decaf-ts/decoration', '@decaf-ts/injectable-decorators', '@nestjs/common', '@decaf-ts/decorator-validation', '@nestjs/swagger/dist/decorators/helpers', '@nestjs/swagger/dist/utils/enum.utils', '@nestjs/swagger/dist/constants', '@nestjs/common/constants', '@nestjs/common/utils/shared.utils', 'lodash', '@nestjs/swagger/dist/plugin/plugin-constants', '@decaf-ts/core', 'tslib', '@nestjs/core', '@decaf-ts/logging', '@nestjs/swagger', '@decaf-ts/db-decorators'], factory) :
4
+ (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["for-nest"] = {}, global.decoration, global.injectableDecorators, global.common, global.decoratorValidation, global.helpers, global.enum_utils, global.constants, global.constants$1, global.shared_utils, global.lodash, global.pluginConstants, global.core, global.tslib, global.core$1, global.logging, global.swagger, global.dbDecorators));
5
+ })(this, (function (exports, decoration, injectableDecorators, common, decoratorValidation, helpers, enum_utils, constants, constants$1, shared_utils, lodash, pluginConstants, core, tslib, core$1, logging, swagger, dbDecorators) { 'use strict';
6
+
7
+ /* eslint-disable @typescript-eslint/no-unsafe-function-type */
8
+ function createMethodDecorator(metakey, metadata, { overrideExisting } = { overrideExisting: true }) {
9
+ return (target, key, descriptor) => {
10
+ if (typeof metadata === "object") {
11
+ const prevValue = Reflect.getMetadata(metakey, descriptor.value);
12
+ if (prevValue && !overrideExisting) {
13
+ return descriptor;
14
+ }
15
+ Reflect.defineMetadata(metakey, { ...prevValue, ...metadata }, descriptor.value);
16
+ return descriptor;
17
+ }
18
+ Reflect.defineMetadata(metakey, metadata, descriptor.value);
19
+ return descriptor;
20
+ };
21
+ }
22
+ function createClassDecorator(metakey, metadata = []) {
23
+ return (target) => {
24
+ const prevValue = Reflect.getMetadata(metakey, target) || [];
25
+ Reflect.defineMetadata(metakey, [...prevValue, ...metadata], target);
26
+ return target;
27
+ };
28
+ }
29
+ function createPropertyDecorator(metakey, metadata, overrideExisting = true) {
30
+ return (target, propertyKey) => {
31
+ const properties = Reflect.getMetadata(constants.DECORATORS.API_MODEL_PROPERTIES_ARRAY, target) || [];
32
+ const key = `:${propertyKey}`;
33
+ if (!properties.includes(key)) {
34
+ Reflect.defineMetadata(constants.DECORATORS.API_MODEL_PROPERTIES_ARRAY, [...properties, `:${propertyKey}`], target);
35
+ }
36
+ const existingMetadata = Reflect.getMetadata(metakey, target, propertyKey);
37
+ if (existingMetadata) {
38
+ const newMetadata = lodash.pickBy(metadata, lodash.negate(lodash.isUndefined));
39
+ const metadataToSave = overrideExisting
40
+ ? {
41
+ ...existingMetadata,
42
+ ...newMetadata,
43
+ }
44
+ : {
45
+ ...newMetadata,
46
+ ...existingMetadata,
47
+ };
48
+ Reflect.defineMetadata(metakey, metadataToSave, target, propertyKey);
49
+ }
50
+ else {
51
+ const type =
52
+ // @ts-expect-error nest js override
53
+ target?.constructor?.[pluginConstants.METADATA_FACTORY_NAME]?.()[propertyKey]?.type ??
54
+ Reflect.getMetadata("design:type", target, propertyKey);
55
+ Reflect.defineMetadata(metakey, {
56
+ type,
57
+ ...lodash.pickBy(metadata, lodash.negate(lodash.isUndefined)),
58
+ }, target, propertyKey);
59
+ }
60
+ };
61
+ }
62
+ function createMixedDecorator(metakey, metadata) {
63
+ return (target, key, descriptor) => {
64
+ if (descriptor) {
65
+ let metadatas;
66
+ if (Array.isArray(metadata)) {
67
+ const previousMetadata = Reflect.getMetadata(metakey, descriptor.value) || [];
68
+ metadatas = [...previousMetadata, ...metadata];
69
+ }
70
+ else {
71
+ const previousMetadata = Reflect.getMetadata(metakey, descriptor.value) || {};
72
+ metadatas = { ...previousMetadata, ...metadata };
73
+ }
74
+ Reflect.defineMetadata(metakey, metadatas, descriptor.value);
75
+ return descriptor;
76
+ }
77
+ let metadatas;
78
+ if (Array.isArray(metadata)) {
79
+ const previousMetadata = Reflect.getMetadata(metakey, target) || [];
80
+ metadatas = [...previousMetadata, ...metadata];
81
+ }
82
+ else {
83
+ const previousMetadata = Reflect.getMetadata(metakey, target) || {};
84
+ metadatas = Object.assign(Object.assign({}, previousMetadata), metadata);
85
+ }
86
+ Reflect.defineMetadata(metakey, metadatas, target);
87
+ return target;
88
+ };
89
+ }
90
+ function createParamDecorator(metadata, initial) {
91
+ return (target, key, descriptor) => {
92
+ const paramOptions = {
93
+ ...initial,
94
+ ...lodash.pickBy(metadata, lodash.negate(lodash.isUndefined)),
95
+ };
96
+ if (descriptor) {
97
+ const parameters = Reflect.getMetadata(constants.DECORATORS.API_PARAMETERS, descriptor.value) || [];
98
+ Reflect.defineMetadata(constants.DECORATORS.API_PARAMETERS, [...parameters, paramOptions], descriptor.value);
99
+ return descriptor;
100
+ }
101
+ if (typeof target === "object") {
102
+ return target;
103
+ }
104
+ const propertyKeys = Object.getOwnPropertyNames(target.prototype);
105
+ for (const propertyKey of propertyKeys) {
106
+ if (shared_utils.isConstructor(propertyKey)) {
107
+ continue;
108
+ }
109
+ const methodDescriptor = Object.getOwnPropertyDescriptor(target.prototype, propertyKey);
110
+ if (!methodDescriptor) {
111
+ continue;
112
+ }
113
+ const isApiMethod = Reflect.hasMetadata(constants$1.METHOD_METADATA, methodDescriptor.value);
114
+ if (!isApiMethod) {
115
+ continue;
116
+ }
117
+ const parameters = Reflect.getMetadata(constants.DECORATORS.API_PARAMETERS, methodDescriptor.value) || [];
118
+ Reflect.defineMetadata(constants.DECORATORS.API_PARAMETERS, [...parameters, paramOptions], methodDescriptor.value);
119
+ }
120
+ };
121
+ }
122
+ function getTypeIsArrayTuple(input, isArrayFlag) {
123
+ if (!input) {
124
+ return [input, isArrayFlag];
125
+ }
126
+ if (isArrayFlag) {
127
+ return [input, isArrayFlag];
128
+ }
129
+ const isInputArray = lodash.isArray(input);
130
+ const type = isInputArray ? input[0] : input;
131
+ return [type, isInputArray];
132
+ }
133
+
134
+ const isEnumArray = (opts) => (opts.isArray && "enum" in opts && opts.enum !== undefined);
135
+ /**
136
+ * @publicApi
137
+ */
138
+ function ApiProperty(options = {}) {
139
+ return createApiPropertyDecorator(options);
140
+ }
141
+ function createApiPropertyDecorator(options = {}, overrideExisting = true) {
142
+ const [type, isArray] = helpers.getTypeIsArrayTuple(options.type, options.isArray);
143
+ options = {
144
+ ...options,
145
+ type,
146
+ isArray,
147
+ };
148
+ if (isEnumArray(options)) {
149
+ options.type = "array";
150
+ const enumValues = enum_utils.getEnumValues(options.enum);
151
+ options.items = {
152
+ type: enum_utils.getEnumType(enumValues),
153
+ enum: enumValues,
154
+ };
155
+ // @ts-expect-error nest swagger override
156
+ delete options.enum;
157
+ }
158
+ else if ("enum" in options && options.enum !== undefined) {
159
+ const enumValues = enum_utils.getEnumValues(options.enum);
160
+ options.enum = enumValues;
161
+ options.type = enum_utils.getEnumType(enumValues);
162
+ }
163
+ if (Array.isArray(options.type)) {
164
+ options.type = "array";
165
+ options.items = {
166
+ type: "array",
167
+ items: {
168
+ type: options.type[0],
169
+ },
170
+ };
171
+ }
172
+ return createPropertyDecorator(constants.DECORATORS.API_MODEL_PROPERTIES, options, overrideExisting);
173
+ }
174
+ function ApiPropertyOptional(options = {}) {
175
+ return ApiProperty({
176
+ ...options,
177
+ required: false,
178
+ });
179
+ }
180
+ function ApiResponseProperty(options = {}) {
181
+ return ApiProperty({
182
+ readOnly: true,
183
+ ...options,
184
+ });
185
+ }
186
+
187
+ decoration.Decoration.for(injectableDecorators.InjectablesKeys.INJECTABLE)
188
+ .extend({
189
+ decorator: function nestInjectable(category, cfg) {
190
+ return common.Injectable({
191
+ scope: cfg.singleton ? common.Scope.DEFAULT : common.Scope.REQUEST,
192
+ durable: cfg.singleton ? undefined : true,
193
+ });
194
+ },
195
+ })
196
+ .apply();
197
+ decoration.Decoration.for(injectableDecorators.InjectablesKeys.INJECT)
198
+ .extend({
199
+ decorator: function nestInject(category,
200
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
201
+ cfg) {
202
+ return function innerNestInject(target, propertyKey, descriptor) {
203
+ return common.Inject(category || target)(target, propertyKey, descriptor);
204
+ };
205
+ },
206
+ })
207
+ .apply();
208
+ decoration.Decoration.for(decoratorValidation.ValidationKeys.REQUIRED)
209
+ .extend(ApiProperty({
210
+ required: true,
211
+ }))
212
+ .apply();
213
+ decoration.Decoration.for(decoratorValidation.ValidationKeys.MAX)
214
+ .extend({
215
+ decorator: function maxDec(max) {
216
+ return ApiProperty({ maximum: max });
217
+ },
218
+ })
219
+ .apply();
220
+ decoration.Decoration.for(decoratorValidation.ValidationKeys.MIN)
221
+ .extend({
222
+ decorator: function minDec(min) {
223
+ return ApiProperty({ minimum: min });
224
+ },
225
+ })
226
+ .apply();
227
+ decoration.Decoration.for(decoratorValidation.ValidationKeys.MAX_LENGTH)
228
+ .extend({
229
+ decorator: function maxLengthDec(max) {
230
+ return ApiProperty({ maxLength: max });
231
+ },
232
+ })
233
+ .apply();
234
+ decoration.Decoration.for(decoratorValidation.ValidationKeys.MIN_LENGTH)
235
+ .extend({
236
+ decorator: function minLengthDec(min) {
237
+ return ApiProperty({ minLength: min });
238
+ },
239
+ })
240
+ .apply();
241
+ //
242
+ // Decoration.for(ValidationKeys.TYPE)
243
+ // .extend({
244
+ // decorator: function typeDec(type: (string | (() => string))[] | string | (() => string)) {
245
+ // return ApiProperty({ type: type as any });
246
+ // },
247
+ // })
248
+ // .apply();
249
+ //
250
+ // Decoration.for(ValidationKeys.DATE)
251
+ // .extend({
252
+ // decorator: function dateDec() {
253
+ // return ApiProperty({ type: Date });
254
+ // },
255
+ // })
256
+ // .apply();
257
+ decoration.Decoration.for(decoratorValidation.ValidationKeys.LIST)
258
+ .extend({
259
+ decorator: function listDec(clazz) {
260
+ const c = Array.isArray(clazz) ? clazz[0] : clazz;
261
+ return ApiProperty({ type: [c] });
262
+ },
263
+ })
264
+ .apply();
265
+ //
266
+ // Decoration.for(ValidationKeys.OPTION)
267
+ // .extend({
268
+ // decorator: function optionDec(options: string[] | Record<string, any>) {
269
+ // const opts = Array.isArray(options) ? options : Object.values(options);
270
+ // return ApiProperty({ enum: opts });
271
+ // },
272
+ // })
273
+ // .apply();
274
+ decoration.Decoration.for(decoratorValidation.ValidationKeys.PATTERN)
275
+ .extend({
276
+ decorator: function patternDec(pat) {
277
+ return ApiProperty({
278
+ pattern: typeof pat === "string" ? pat : pat.source,
279
+ });
280
+ },
281
+ })
282
+ .apply();
283
+ decoration.Decoration.for(core.PersistenceKeys.COLUMN)
284
+ .extend({
285
+ decorator: function columnDec(name) {
286
+ return ApiProperty({
287
+ name: name,
288
+ });
289
+ },
290
+ })
291
+ .apply();
292
+ decoration.Decoration.for(decoration.DecorationKeys.DESCRIPTION)
293
+ .extend({
294
+ decorator: function descriptionDec(description) {
295
+ return ApiProperty({
296
+ description: description,
297
+ });
298
+ },
299
+ })
300
+ .apply();
6
301
 
7
302
  const DECAF_MODULE_OPTIONS = "DecafModuleOptions";
8
303
  const DECAF_ADAPTER_ID = "DecafAdapter";
9
304
 
10
305
  var DecafCoreModule_1;
11
- let DecafCoreModule = DecafCoreModule_1 = class DecafCoreModule extends LoggedClass.LoggedClass {
306
+ let DecafCoreModule = class DecafCoreModule {
307
+ static { DecafCoreModule_1 = this; }
308
+ static { this._adapterInstance = null; }
309
+ static get log() {
310
+ if (!this._logger)
311
+ this._logger = logging.Logging.for(DecafCoreModule_1);
312
+ return this._logger;
313
+ }
12
314
  constructor(options, moduleRef) {
13
- super();
14
315
  this.options = options;
15
316
  this.moduleRef = moduleRef;
16
317
  }
318
+ static async createAdapter(options) {
319
+ if (!this._adapterInstance) {
320
+ const log = this.log.for(this.createAdapter);
321
+ log.info("Creating adapter instance...");
322
+ this._adapterInstance = new options.adapter(options.conf, options.alias);
323
+ log.info("Adapter instance created successfully!");
324
+ }
325
+ return this._adapterInstance;
326
+ }
327
+ static getAdapterInstance() {
328
+ return this._adapterInstance;
329
+ }
17
330
  static forRoot(options) {
18
331
  const typeOrmModuleOptions = {
19
332
  provide: DECAF_MODULE_OPTIONS,
@@ -21,7 +334,7 @@
21
334
  };
22
335
  const adapter = {
23
336
  useFactory: async (opts) => {
24
- return new opts.adapter(opts.conf, opts.alias);
337
+ return DecafCoreModule_1.createAdapter(opts);
25
338
  },
26
339
  provide: DECAF_ADAPTER_ID,
27
340
  durable: true,
@@ -37,15 +350,17 @@
37
350
  };
38
351
  }
39
352
  async onApplicationShutdown() {
353
+ const log = DecafCoreModule_1.log.for(this.onApplicationShutdown);
40
354
  const adapter = this.moduleRef.get(DECAF_ADAPTER_ID);
41
355
  try {
42
356
  if (adapter) {
43
- this.log.info("Shutting down");
357
+ log.info("Shutting down");
44
358
  await adapter.shutdown();
359
+ DecafCoreModule_1._adapterInstance = null;
45
360
  }
46
361
  }
47
362
  catch (e) {
48
- this.log.error(`Failed to shutdown application`, e);
363
+ log.error(`Failed to shutdown application`, e);
49
364
  }
50
365
  }
51
366
  };
@@ -53,18 +368,145 @@
53
368
  common.Global(),
54
369
  common.Module({}),
55
370
  tslib.__param(0, common.Inject(DECAF_MODULE_OPTIONS)),
56
- tslib.__metadata("design:paramtypes", [Object, core.ModuleRef])
371
+ tslib.__metadata("design:paramtypes", [Object, core$1.ModuleRef])
57
372
  ], DecafCoreModule);
58
373
 
374
+ function repoForModel(model) {
375
+ const m = decoratorValidation.Model.get(model);
376
+ if (!m)
377
+ throw new dbDecorators.InternalError(`Failed to find repository for ${model}`);
378
+ const repo = core.Repository.forModel(m);
379
+ return repo;
380
+ }
381
+
382
+ exports.RepoFactory = class RepoFactory {
383
+ for(model) {
384
+ model = typeof model === "string" ? decoratorValidation.Model.get(model) : model;
385
+ if (!model) {
386
+ throw new dbDecorators.InternalError(`Failed to find repository for ${model}`);
387
+ }
388
+ return core.Repository.forModel(model);
389
+ }
390
+ };
391
+ exports.RepoFactory = tslib.__decorate([
392
+ common.Injectable()
393
+ ], exports.RepoFactory);
394
+
395
+ var DecafModelModule_1;
396
+ let DecafModelModule = class DecafModelModule {
397
+ static { DecafModelModule_1 = this; }
398
+ static get log() {
399
+ if (!this._logger)
400
+ this._logger = logging.Logging.for(DecafModelModule_1);
401
+ return this._logger;
402
+ }
403
+ static toModelController(modelClass) {
404
+ const log = this.log.for(this.toModelController);
405
+ log.debug(`Creating model controller... ${modelClass.name}`);
406
+ const modelName = logging.toKebabCase(core.Repository.table(modelClass));
407
+ const route = modelName;
408
+ let DynamicModelController = class DynamicModelController extends logging.LoggedClass {
409
+ constructor(repoFactory) {
410
+ super();
411
+ this.repoFactory = repoFactory;
412
+ try {
413
+ this.repo = this.repoFactory.for(modelClass.name);
414
+ }
415
+ catch (e) {
416
+ log.error(`Failed to get repository for ${modelClass.name}`, e);
417
+ }
418
+ }
419
+ async create(data) {
420
+ const log = this.log.for(this.create);
421
+ log.verbose(`creating new ${modelName}`);
422
+ const r = repoForModel("Account");
423
+ const created = await r.create(data);
424
+ log.info(`created new ${modelName} with id ${created[r.pk]}`);
425
+ return created;
426
+ }
427
+ async read(id) {
428
+ const log = this.log.for(this.read);
429
+ log.debug(`reading ${modelName} with ${this.repo.pk} ${id}`);
430
+ const read = await this.repo.read(id);
431
+ log.info(`read ${modelName} with id ${read[this.repo.pk]}`);
432
+ return read;
433
+ }
434
+ };
435
+ tslib.__decorate([
436
+ common.Post(),
437
+ swagger.ApiOperation({ summary: `Create a new ${modelName}.` }),
438
+ swagger.ApiBody({
439
+ description: `Payload for ${modelName}`,
440
+ schema: { $ref: swagger.getSchemaPath(modelClass) },
441
+ }),
442
+ swagger.ApiCreatedResponse({ description: `${modelName} created successfully.` }),
443
+ swagger.ApiBadRequestResponse({ description: "Payload validation failed." }),
444
+ swagger.ApiUnprocessableEntityResponse({
445
+ description: "Repository rejected the provided payload.",
446
+ }),
447
+ tslib.__param(0, common.Body()),
448
+ tslib.__metadata("design:type", Function),
449
+ tslib.__metadata("design:paramtypes", [Object]),
450
+ tslib.__metadata("design:returntype", Promise)
451
+ ], DynamicModelController.prototype, "create", null);
452
+ tslib.__decorate([
453
+ common.Get(":id"),
454
+ swagger.ApiOperation({ summary: `Retrieve a ${modelName} by id.` }),
455
+ swagger.ApiParam({
456
+ name: "id",
457
+ description: "Primary key",
458
+ example: "1234-5678",
459
+ }),
460
+ swagger.ApiOkResponse({ description: `${modelName} retrieved successfully.` }),
461
+ swagger.ApiNotFoundResponse({
462
+ description: "No record matches the provided identifier.",
463
+ }),
464
+ tslib.__param(0, common.Param("id")),
465
+ tslib.__metadata("design:type", Function),
466
+ tslib.__metadata("design:paramtypes", [String]),
467
+ tslib.__metadata("design:returntype", Promise)
468
+ ], DynamicModelController.prototype, "read", null);
469
+ DynamicModelController = tslib.__decorate([
470
+ common.Controller(route),
471
+ swagger.ApiTags(modelName),
472
+ swagger.ApiExtraModels(modelClass),
473
+ tslib.__metadata("design:paramtypes", [exports.RepoFactory])
474
+ ], DynamicModelController);
475
+ return DynamicModelController;
476
+ }
477
+ static forRoot(flavour) {
478
+ const log = this.log.for(this.forRoot);
479
+ log.info(`Generating controllers for flavour...`);
480
+ const trackedModels = core.Adapter.models(flavour);
481
+ const controllers = trackedModels.map(this.toModelController.bind(this));
482
+ log.info(`Generated ${controllers.length} controllers`);
483
+ return {
484
+ module: DecafModelModule_1,
485
+ controllers,
486
+ providers: [exports.RepoFactory],
487
+ };
488
+ }
489
+ };
490
+ DecafModelModule = DecafModelModule_1 = tslib.__decorate([
491
+ common.Module({})
492
+ ], DecafModelModule);
493
+
59
494
  var DecafModule_1;
60
495
  /**
61
496
  * @publicApi
62
497
  */
63
498
  exports.DecafModule = DecafModule_1 = class DecafModule {
64
- static forRoot(options) {
499
+ static async forRootAsync(options) {
500
+ const { autoControllers } = options;
501
+ const adapter = await DecafCoreModule.createAdapter(options);
502
+ const flavour = adapter.flavour;
503
+ const imports = [DecafCoreModule.forRoot(options)];
504
+ if (autoControllers) {
505
+ imports.push(DecafModelModule.forRoot(flavour));
506
+ }
65
507
  return {
66
508
  module: DecafModule_1,
67
- imports: [DecafCoreModule.forRoot(options)],
509
+ imports: imports,
68
510
  };
69
511
  }
70
512
  };
@@ -73,7 +515,7 @@
73
515
  ], exports.DecafModule);
74
516
 
75
517
  /**
76
- * @module ts-workspace
518
+ * @module for-nest
77
519
  * @description This module serves as the main entry point for the ts-workspace library. It aggregates and exports
78
520
  * functionality from various submodules and utilities within the project.
79
521
  *
@@ -99,14 +541,25 @@
99
541
  * @constant
100
542
  * @type {string}
101
543
  */
102
- const VERSION = "0.0.1";
544
+ const VERSION = "0.0.2";
103
545
  const PACKAGE_NAME = "##PACKAGE_NAME##";
104
546
  decoration.Metadata.registerLibrary(PACKAGE_NAME, VERSION);
105
547
 
548
+ exports.ApiProperty = ApiProperty;
549
+ exports.ApiPropertyOptional = ApiPropertyOptional;
550
+ exports.ApiResponseProperty = ApiResponseProperty;
106
551
  exports.DECAF_ADAPTER_ID = DECAF_ADAPTER_ID;
107
552
  exports.DECAF_MODULE_OPTIONS = DECAF_MODULE_OPTIONS;
108
553
  exports.PACKAGE_NAME = PACKAGE_NAME;
109
554
  exports.VERSION = VERSION;
555
+ exports.createApiPropertyDecorator = createApiPropertyDecorator;
556
+ exports.createClassDecorator = createClassDecorator;
557
+ exports.createMethodDecorator = createMethodDecorator;
558
+ exports.createMixedDecorator = createMixedDecorator;
559
+ exports.createParamDecorator = createParamDecorator;
560
+ exports.createPropertyDecorator = createPropertyDecorator;
561
+ exports.getTypeIsArrayTuple = getTypeIsArrayTuple;
562
+ exports.repoForModel = repoForModel;
110
563
 
111
564
  }));
112
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"for-nest.cjs","sources":["../src/constants.ts","../src/core-module.ts","../src/module.ts","../src/index.ts"],"sourcesContent":["export const DECAF_MODULE_OPTIONS = \"DecafModuleOptions\";\nexport const DECAF_ADAPTER_ID = \"DecafAdapter\";\n","import {\n  DynamicModule,\n  Global,\n  Inject,\n  Module,\n  OnApplicationShutdown,\n  Scope,\n} from \"@nestjs/common\";\nimport { ModuleRef } from \"@nestjs/core\";\nimport type { DecafModuleOptions } from \"./types\";\nimport { DECAF_ADAPTER_ID, DECAF_MODULE_OPTIONS } from \"./constants\";\nimport { FactoryProvider } from \"@nestjs/common/interfaces/modules/provider.interface\";\nimport { Adapter } from \"@decaf-ts/core\";\nimport { LoggedClass } from \"@decaf-ts/logging/lib/LoggedClass\";\n\n@Global()\n@Module({})\nexport class DecafCoreModule<\n    CONF,\n    ADAPTER extends Adapter<CONF, any, any, any, any>,\n  >\n  extends LoggedClass\n  implements OnApplicationShutdown\n{\n  constructor(\n    @Inject(DECAF_MODULE_OPTIONS)\n    private readonly options: DecafModuleOptions<CONF, ADAPTER>,\n    private readonly moduleRef: ModuleRef\n  ) {\n    super();\n  }\n\n  static forRoot(options: DecafModuleOptions): DynamicModule {\n    const typeOrmModuleOptions = {\n      provide: DECAF_MODULE_OPTIONS,\n      useValue: options,\n    };\n\n    const adapter: FactoryProvider<any> = {\n      useFactory: async (opts: DecafModuleOptions) => {\n        return new opts.adapter(opts.conf, opts.alias);\n      },\n      provide: DECAF_ADAPTER_ID,\n      durable: true,\n      scope: Scope.DEFAULT,\n      inject: [DECAF_MODULE_OPTIONS],\n    };\n\n    const providers = [adapter, typeOrmModuleOptions];\n    const exports = [adapter];\n\n    return {\n      module: DecafCoreModule,\n      providers,\n      exports,\n    };\n  }\n\n  async onApplicationShutdown(): Promise<void> {\n    const adapter = this.moduleRef.get<ADAPTER>(DECAF_ADAPTER_ID);\n    try {\n      if (adapter) {\n        this.log.info(\"Shutting down\");\n        await adapter.shutdown();\n      }\n    } catch (e: unknown) {\n      this.log.error(`Failed to shutdown application`, e as Error);\n    }\n  }\n}\n","import { DynamicModule, Module } from \"@nestjs/common\";\nimport { DecafModuleOptions } from \"./types\";\nimport { DecafCoreModule } from \"./core-module\";\n\n/**\n * @publicApi\n */\n@Module({})\nexport class DecafModule {\n  static forRoot(options: DecafModuleOptions): DynamicModule {\n    return {\n      module: DecafModule,\n      imports: [DecafCoreModule.forRoot(options)],\n    };\n  }\n}\n","/**\n * @module ts-workspace\n * @description This module serves as the main entry point for the ts-workspace library. It aggregates and exports\n * functionality from various submodules and utilities within the project.\n *\n * The module includes:\n * 1. Utility functions and types from the \"./utils\" directory:\n *    - These likely contain helper functions, common types, and shared functionality used throughout the project.\n *    - May include operations for data manipulation, type checking, or other general-purpose utilities.\n *\n * 2. A namespace and related types from the \"./namespace\" directory:\n *    - This could contain domain-specific code or a collection of related functionality.\n *    - Might include interfaces, types, or classes that represent core concepts in the library.\n *\n * 3. A VERSION constant:\n *    - Represents the current version of the module.\n *    - Useful for version checking and compatibility purposes.\n *\n * This structure provides a clean and organized export of the module's functionality, allowing consumers\n * to easily import and use specific parts of the library as needed.\n */\n\nimport { Metadata } from \"@decaf-ts/decoration\";\n\nexport * from \"./constants\";\nexport * from \"./module\";\nexport * from \"./types\";\n\n/**\n * Represents the current version of the ts-workspace module.\n * The actual version number is replaced during the build process.\n * @constant\n * @type {string}\n */\nexport const VERSION = \"##VERSION##\";\nexport const PACKAGE_NAME = \"##PACKAGE_NAME##\";\n\nMetadata.registerLibrary(PACKAGE_NAME, VERSION);\n"],"names":["LoggedClass","Scope","__decorate","Global","Module","__param","Inject","ModuleRef","DecafModule","Metadata"],"mappings":";;;;;;AAAO,UAAM,oBAAoB,GAAG;AAC7B,UAAM,gBAAgB,GAAG;;;ICgBzB,IAAM,eAAe,GAAA,iBAAA,GAArB,MAAM,eAIX,SAAQA,uBAAW,CAAA;QAGnB,WAEmB,CAAA,OAA0C,EAC1C,SAAoB,EAAA;IAErC,QAAA,KAAK,EAAE;YAHU,IAAO,CAAA,OAAA,GAAP,OAAO;YACP,IAAS,CAAA,SAAA,GAAT,SAAS;;QAK5B,OAAO,OAAO,CAAC,OAA2B,EAAA;IACxC,QAAA,MAAM,oBAAoB,GAAG;IAC3B,YAAA,OAAO,EAAE,oBAAoB;IAC7B,YAAA,QAAQ,EAAE,OAAO;aAClB;IAED,QAAA,MAAM,OAAO,GAAyB;IACpC,YAAA,UAAU,EAAE,OAAO,IAAwB,KAAI;IAC7C,gBAAA,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC;iBAC/C;IACD,YAAA,OAAO,EAAE,gBAAgB;IACzB,YAAA,OAAO,EAAE,IAAI;gBACb,KAAK,EAAEC,YAAK,CAAC,OAAO;gBACpB,MAAM,EAAE,CAAC,oBAAoB,CAAC;aAC/B;IAED,QAAA,MAAM,SAAS,GAAG,CAAC,OAAO,EAAE,oBAAoB,CAAC;IACjD,QAAA,MAAM,OAAO,GAAG,CAAC,OAAO,CAAC;YAEzB,OAAO;IACL,YAAA,MAAM,EAAE,iBAAe;gBACvB,SAAS;gBACT,OAAO;aACR;;IAGH,IAAA,MAAM,qBAAqB,GAAA;YACzB,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAU,gBAAgB,CAAC;IAC7D,QAAA,IAAI;gBACF,IAAI,OAAO,EAAE;IACX,gBAAA,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC;IAC9B,gBAAA,MAAM,OAAO,CAAC,QAAQ,EAAE;;;YAE1B,OAAO,CAAU,EAAE;gBACnB,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAgC,8BAAA,CAAA,EAAE,CAAU,CAAC;;;KAGjE;IApDY,eAAe,GAAA,iBAAA,GAAAC,gBAAA,CAAA;IAF3B,IAAAC,aAAM,EAAE;QACRC,aAAM,CAAC,EAAE,CAAC;IASN,IAAAC,aAAA,CAAA,CAAA,EAAAC,aAAM,CAAC,oBAAoB,CAAC,CAAA;uDAEDC,cAAS,CAAA;IAV5B,CAAA,EAAA,eAAe,CAoD3B;;;ICjED;;IAEG;AAEUC,uBAAW,GAAjB,aAAA,GAAA,MAAM,WAAW,CAAA;QACtB,OAAO,OAAO,CAAC,OAA2B,EAAA;YACxC,OAAO;IACL,YAAA,MAAM,EAAE,aAAW;gBACnB,OAAO,EAAE,CAAC,eAAe,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;aAC5C;;;AALQA,uBAAW,GAAA,aAAA,GAAAN,gBAAA,CAAA;QADvBE,aAAM,CAAC,EAAE;IACG,CAAA,EAAAI,mBAAW,CAOvB;;ICfD;;;;;;;;;;;;;;;;;;;;IAoBG;IAQH;;;;;IAKG;AACI,UAAM,OAAO,GAAG;AAChB,UAAM,YAAY,GAAG;AAE5BC,uBAAQ,CAAC,eAAe,CAAC,YAAY,EAAE,OAAO,CAAC;;;;;;;;;;;"}
565
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"for-nest.cjs","sources":["../src/decorators/helpers.ts","../src/decorators/ApiProperty.ts","../src/decoration.ts","../src/constants.ts","../src/core-module.ts","../src/utils.ts","../src/RepoFactory.ts","../src/model-module.ts","../src/module.ts","../src/index.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-unsafe-function-type */\n\nimport { METHOD_METADATA } from \"@nestjs/common/constants\";\nimport { isConstructor } from \"@nestjs/common/utils/shared.utils\";\nimport { isArray, isUndefined, negate, pickBy } from \"lodash\";\nimport { METADATA_FACTORY_NAME } from \"@nestjs/swagger/dist/plugin/plugin-constants\";\nimport { DECORATORS } from \"@nestjs/swagger/dist/constants\";\n\nexport function createMethodDecorator<T = any>(\n  metakey: string,\n  metadata: T,\n  { overrideExisting } = { overrideExisting: true }\n): MethodDecorator {\n  return (\n    target: object,\n    key: string | symbol,\n    descriptor: PropertyDescriptor\n  ) => {\n    if (typeof metadata === \"object\") {\n      const prevValue = Reflect.getMetadata(metakey, descriptor.value);\n      if (prevValue && !overrideExisting) {\n        return descriptor;\n      }\n      Reflect.defineMetadata(\n        metakey,\n        { ...prevValue, ...metadata },\n        descriptor.value\n      );\n      return descriptor;\n    }\n    Reflect.defineMetadata(metakey, metadata, descriptor.value);\n    return descriptor;\n  };\n}\n\nexport function createClassDecorator<T extends Array<any> = any>(\n  metakey: string,\n  metadata: T = [] as unknown as T\n): ClassDecorator {\n  return (target) => {\n    const prevValue = Reflect.getMetadata(metakey, target) || [];\n    Reflect.defineMetadata(metakey, [...prevValue, ...metadata], target);\n    return target;\n  };\n}\n\nexport function createPropertyDecorator<T extends Record<string, any> = any>(\n  metakey: string,\n  metadata: T,\n  overrideExisting = true\n): PropertyDecorator {\n  return (target: object, propertyKey?: any) => {\n    const properties =\n      Reflect.getMetadata(DECORATORS.API_MODEL_PROPERTIES_ARRAY, target) || [];\n\n    const key = `:${propertyKey}`;\n    if (!properties.includes(key)) {\n      Reflect.defineMetadata(\n        DECORATORS.API_MODEL_PROPERTIES_ARRAY,\n        [...properties, `:${propertyKey}`],\n        target\n      );\n    }\n    const existingMetadata = Reflect.getMetadata(metakey, target, propertyKey);\n    if (existingMetadata) {\n      const newMetadata = pickBy(metadata, negate(isUndefined));\n      const metadataToSave = overrideExisting\n        ? {\n            ...existingMetadata,\n            ...newMetadata,\n          }\n        : {\n            ...newMetadata,\n            ...existingMetadata,\n          };\n\n      Reflect.defineMetadata(metakey, metadataToSave, target, propertyKey);\n    } else {\n      const type =\n        // @ts-expect-error nest js override\n        target?.constructor?.[METADATA_FACTORY_NAME]?.()[propertyKey]?.type ??\n        Reflect.getMetadata(\"design:type\", target, propertyKey);\n\n      Reflect.defineMetadata(\n        metakey,\n        {\n          type,\n          ...pickBy(metadata, negate(isUndefined)),\n        },\n        target,\n        propertyKey\n      );\n    }\n  };\n}\n\nexport function createMixedDecorator<T = any>(\n  metakey: string,\n  metadata: T\n): MethodDecorator & ClassDecorator {\n  return (\n    target: object,\n    key?: string | symbol,\n    descriptor?: TypedPropertyDescriptor<any>\n  ): any => {\n    if (descriptor) {\n      let metadatas: any;\n      if (Array.isArray(metadata)) {\n        const previousMetadata =\n          Reflect.getMetadata(metakey, descriptor.value) || [];\n        metadatas = [...previousMetadata, ...metadata];\n      } else {\n        const previousMetadata =\n          Reflect.getMetadata(metakey, descriptor.value) || {};\n        metadatas = { ...previousMetadata, ...metadata };\n      }\n      Reflect.defineMetadata(metakey, metadatas, descriptor.value);\n      return descriptor;\n    }\n\n    let metadatas: any;\n    if (Array.isArray(metadata)) {\n      const previousMetadata = Reflect.getMetadata(metakey, target) || [];\n      metadatas = [...previousMetadata, ...metadata];\n    } else {\n      const previousMetadata = Reflect.getMetadata(metakey, target) || {};\n      metadatas = Object.assign(Object.assign({}, previousMetadata), metadata);\n    }\n    Reflect.defineMetadata(metakey, metadatas, target);\n    return target;\n  };\n}\n\nexport function createParamDecorator<T extends Record<string, any> = any>(\n  metadata: T,\n  initial: Partial<T>\n): MethodDecorator & ClassDecorator {\n  return (\n    target: object | Function,\n    key?: string | symbol,\n    descriptor?: TypedPropertyDescriptor<any>\n  ): any => {\n    const paramOptions = {\n      ...initial,\n      ...pickBy(metadata, negate(isUndefined)),\n    };\n\n    if (descriptor) {\n      const parameters =\n        Reflect.getMetadata(DECORATORS.API_PARAMETERS, descriptor.value) || [];\n      Reflect.defineMetadata(\n        DECORATORS.API_PARAMETERS,\n        [...parameters, paramOptions],\n        descriptor.value\n      );\n      return descriptor;\n    }\n\n    if (typeof target === \"object\") {\n      return target;\n    }\n\n    const propertyKeys = Object.getOwnPropertyNames(target.prototype);\n\n    for (const propertyKey of propertyKeys) {\n      if (isConstructor(propertyKey)) {\n        continue;\n      }\n\n      const methodDescriptor = Object.getOwnPropertyDescriptor(\n        target.prototype,\n        propertyKey\n      );\n\n      if (!methodDescriptor) {\n        continue;\n      }\n\n      const isApiMethod = Reflect.hasMetadata(\n        METHOD_METADATA,\n        methodDescriptor.value\n      );\n\n      if (!isApiMethod) {\n        continue;\n      }\n\n      const parameters =\n        Reflect.getMetadata(\n          DECORATORS.API_PARAMETERS,\n          methodDescriptor.value\n        ) || [];\n      Reflect.defineMetadata(\n        DECORATORS.API_PARAMETERS,\n        [...parameters, paramOptions],\n        methodDescriptor.value\n      );\n    }\n  };\n}\n\nexport function getTypeIsArrayTuple(\n  input: Function | [Function] | undefined | string | Record<string, any>,\n  isArrayFlag: boolean\n): [Function | undefined, boolean] {\n  if (!input) {\n    return [input as undefined, isArrayFlag];\n  }\n  if (isArrayFlag) {\n    return [input as Function, isArrayFlag];\n  }\n  const isInputArray = isArray(input);\n  const type = isInputArray ? input[0] : input;\n  return [type as Function, isInputArray];\n}\n","import { Type } from \"@nestjs/common\";\nimport {\n  EnumAllowedTypes,\n  SchemaObjectMetadata,\n} from \"@nestjs/swagger/dist/interfaces/schema-object-metadata.interface\";\nimport { EnumSchemaAttributes } from \"@nestjs/swagger/dist/interfaces/enum-schema-attributes.interface\";\nimport { getTypeIsArrayTuple } from \"@nestjs/swagger/dist/decorators/helpers\";\nimport {\n  getEnumType,\n  getEnumValues,\n} from \"@nestjs/swagger/dist/utils/enum.utils\";\nimport { DECORATORS } from \"@nestjs/swagger/dist/constants\";\nimport { createPropertyDecorator } from \"./helpers\";\n\nexport type ApiPropertyCommonOptions = SchemaObjectMetadata & {\n  \"x-enumNames\"?: string[];\n  /**\n   * Lazy function returning the type for which the decorated property\n   * can be used as an id\n   *\n   * Use together with @ApiDefaultGetter on the getter route of the type\n   * to generate OpenAPI link objects\n   *\n   * @see [Swagger link objects](https://swagger.io/docs/specification/links/)\n   */\n  // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\n  link?: () => Type<unknown> | Function;\n};\n\nexport type ApiPropertyOptions =\n  | ApiPropertyCommonOptions\n  | (ApiPropertyCommonOptions & {\n      enumName: string;\n      enumSchema?: EnumSchemaAttributes;\n    });\n\nconst isEnumArray = (\n  opts: ApiPropertyOptions\n): opts is {\n  isArray: true;\n  enum: EnumAllowedTypes;\n  type: any;\n  items: any;\n} => (opts.isArray && \"enum\" in opts && opts.enum !== undefined) as boolean;\n\n/**\n * @publicApi\n */\nexport function ApiProperty(\n  options: ApiPropertyOptions = {}\n): PropertyDecorator {\n  return createApiPropertyDecorator(options);\n}\n\nexport function createApiPropertyDecorator(\n  options: ApiPropertyOptions = {},\n  overrideExisting = true\n): PropertyDecorator {\n  const [type, isArray] = getTypeIsArrayTuple(\n    options.type,\n    options.isArray as boolean\n  );\n  options = {\n    ...options,\n    type,\n    isArray,\n  } as ApiPropertyOptions;\n\n  if (isEnumArray(options)) {\n    options.type = \"array\";\n\n    const enumValues = getEnumValues(options.enum);\n    options.items = {\n      type: getEnumType(enumValues),\n      enum: enumValues,\n    };\n    // @ts-expect-error nest swagger override\n    delete options.enum;\n  } else if (\"enum\" in options && options.enum !== undefined) {\n    const enumValues = getEnumValues(options.enum);\n\n    options.enum = enumValues;\n    options.type = getEnumType(enumValues);\n  }\n\n  if (Array.isArray(options.type)) {\n    options.type = \"array\";\n    options.items = {\n      type: \"array\",\n      items: {\n        type: options.type[0],\n      },\n    };\n  }\n\n  return createPropertyDecorator(\n    DECORATORS.API_MODEL_PROPERTIES,\n    options,\n    overrideExisting\n  );\n}\n\nexport function ApiPropertyOptional(\n  options: ApiPropertyOptions = {}\n): PropertyDecorator {\n  return ApiProperty({\n    ...options,\n    required: false,\n  } as ApiPropertyOptions);\n}\n\nexport function ApiResponseProperty(\n  options: Pick<\n    ApiPropertyOptions,\n    \"type\" | \"example\" | \"format\" | \"deprecated\" | \"enum\"\n  > = {}\n): PropertyDecorator {\n  return ApiProperty({\n    readOnly: true,\n    ...options,\n  } as ApiPropertyOptions);\n}\n","import {\n  InjectableConfig,\n  InjectablesKeys,\n  InjectOptions,\n} from \"@decaf-ts/injectable-decorators\";\nimport { Inject, Injectable, Scope } from \"@nestjs/common\";\nimport { Constructor, Decoration, DecorationKeys } from \"@decaf-ts/decoration\";\nimport { ValidationKeys } from \"@decaf-ts/decorator-validation\";\nimport { ApiProperty } from \"./decorators/ApiProperty\";\nimport { PersistenceKeys } from \"@decaf-ts/core\";\n\nDecoration.for(InjectablesKeys.INJECTABLE)\n  .extend({\n    decorator: function nestInjectable(\n      category: string | Constructor,\n      cfg: InjectableConfig\n    ) {\n      return Injectable({\n        scope: cfg.singleton ? Scope.DEFAULT : Scope.REQUEST,\n        durable: cfg.singleton ? undefined : true,\n      });\n    },\n  })\n  .apply();\n\nDecoration.for(InjectablesKeys.INJECT)\n  .extend({\n    decorator: function nestInject(\n      category: symbol | string | Constructor,\n      // eslint-disable-next-line @typescript-eslint/no-unused-vars\n      cfg: InjectOptions\n    ) {\n      return function innerNestInject(\n        target: object,\n        propertyKey?: any,\n        descriptor?: any\n      ) {\n        return Inject(category || (target as Constructor))(\n          target,\n          propertyKey,\n          descriptor\n        );\n      };\n    },\n  })\n  .apply();\n\nDecoration.for(ValidationKeys.REQUIRED)\n  .extend(\n    ApiProperty({\n      required: true,\n    })\n  )\n  .apply();\n\nDecoration.for(ValidationKeys.MAX)\n  .extend({\n    decorator: function maxDec(max: number) {\n      return ApiProperty({ maximum: max });\n    },\n  })\n  .apply();\n\nDecoration.for(ValidationKeys.MIN)\n  .extend({\n    decorator: function minDec(min: number) {\n      return ApiProperty({ minimum: min });\n    },\n  })\n  .apply();\n\nDecoration.for(ValidationKeys.MAX_LENGTH)\n  .extend({\n    decorator: function maxLengthDec(max: number) {\n      return ApiProperty({ maxLength: max });\n    },\n  })\n  .apply();\n\nDecoration.for(ValidationKeys.MIN_LENGTH)\n  .extend({\n    decorator: function minLengthDec(min: number) {\n      return ApiProperty({ minLength: min });\n    },\n  })\n  .apply();\n//\n// Decoration.for(ValidationKeys.TYPE)\n//   .extend({\n//     decorator: function typeDec(type: (string | (() => string))[] | string | (() => string)) {\n//       return ApiProperty({ type: type as any });\n//     },\n//   })\n//   .apply();\n//\n// Decoration.for(ValidationKeys.DATE)\n//   .extend({\n//     decorator: function dateDec() {\n//       return ApiProperty({ type: Date });\n//     },\n//   })\n//   .apply();\n\nDecoration.for(ValidationKeys.LIST)\n  .extend({\n    decorator: function listDec(\n      clazz:\n        | Constructor<any>\n        | (() => Constructor<any>)\n        | (Constructor<any> | (() => Constructor<any>))[]\n    ) {\n      const c = Array.isArray(clazz) ? clazz[0] : clazz;\n      return ApiProperty({ type: [c] });\n    },\n  })\n  .apply();\n\n//\n// Decoration.for(ValidationKeys.OPTION)\n//   .extend({\n//     decorator: function optionDec(options: string[] | Record<string, any>) {\n//       const opts = Array.isArray(options) ? options : Object.values(options);\n//       return ApiProperty({ enum: opts });\n//     },\n//   })\n//   .apply();\n\nDecoration.for(ValidationKeys.PATTERN)\n  .extend({\n    decorator: function patternDec(pat: RegExp | string) {\n      return ApiProperty({\n        pattern: typeof pat === \"string\" ? pat : pat.source,\n      });\n    },\n  })\n  .apply();\n\nDecoration.for(PersistenceKeys.COLUMN)\n  .extend({\n    decorator: function columnDec(name: string) {\n      return ApiProperty({\n        name: name,\n      });\n    },\n  })\n  .apply();\n\nDecoration.for(DecorationKeys.DESCRIPTION)\n  .extend({\n    decorator: function descriptionDec(description: string) {\n      return ApiProperty({\n        description: description,\n      });\n    },\n  })\n  .apply();\n","export const DECAF_MODULE_OPTIONS = \"DecafModuleOptions\";\nexport const DECAF_ADAPTER_ID = \"DecafAdapter\";\n","import {\n  DynamicModule,\n  Global,\n  Inject,\n  Module,\n  OnApplicationShutdown,\n  Scope,\n} from \"@nestjs/common\";\nimport { ModuleRef } from \"@nestjs/core\";\nimport type { DecafModuleOptions } from \"./types\";\nimport { DECAF_ADAPTER_ID, DECAF_MODULE_OPTIONS } from \"./constants\";\nimport { FactoryProvider } from \"@nestjs/common/interfaces/modules/provider.interface\";\nimport { Adapter } from \"@decaf-ts/core\";\nimport { Logger, Logging } from \"@decaf-ts/logging\";\n\n@Global()\n@Module({})\nexport class DecafCoreModule<\n  CONF,\n  ADAPTER extends Adapter<CONF, any, any, any, any>,\n> implements OnApplicationShutdown\n{\n  private static _logger: Logger;\n  private static _adapterInstance: Adapter<any, any, any, any, any> | null =\n    null;\n\n  protected static get log(): Logger {\n    if (!this._logger) this._logger = Logging.for(DecafCoreModule);\n    return this._logger;\n  }\n\n  constructor(\n    @Inject(DECAF_MODULE_OPTIONS)\n    private readonly options: DecafModuleOptions<CONF, ADAPTER>,\n    private readonly moduleRef: ModuleRef\n  ) {}\n\n  static async createAdapter(\n    options: DecafModuleOptions\n  ): Promise<Adapter<any, any, any, any, any>> {\n    if (!this._adapterInstance) {\n      const log = this.log.for(this.createAdapter);\n      log.info(\"Creating adapter instance...\");\n      this._adapterInstance = new options.adapter(options.conf, options.alias);\n      log.info(\"Adapter instance created successfully!\");\n    }\n    return this._adapterInstance;\n  }\n\n  static getAdapterInstance(): Adapter<any, any, any, any, any> | null {\n    return this._adapterInstance;\n  }\n\n  static forRoot(options: DecafModuleOptions): DynamicModule {\n    const typeOrmModuleOptions = {\n      provide: DECAF_MODULE_OPTIONS,\n      useValue: options,\n    };\n\n    const adapter: FactoryProvider<any> = {\n      useFactory: async (opts: DecafModuleOptions) => {\n        return DecafCoreModule.createAdapter(opts);\n      },\n      provide: DECAF_ADAPTER_ID,\n      durable: true,\n      scope: Scope.DEFAULT,\n      inject: [DECAF_MODULE_OPTIONS],\n    };\n\n    const providers = [adapter, typeOrmModuleOptions];\n    const exports = [adapter];\n\n    return {\n      module: DecafCoreModule,\n      providers,\n      exports,\n    };\n  }\n\n  async onApplicationShutdown(): Promise<void> {\n    const log = DecafCoreModule.log.for(this.onApplicationShutdown);\n    const adapter = this.moduleRef.get<ADAPTER>(DECAF_ADAPTER_ID);\n    try {\n      if (adapter) {\n        log.info(\"Shutting down\");\n        await adapter.shutdown();\n        DecafCoreModule._adapterInstance = null;\n      }\n    } catch (e: unknown) {\n      log.error(`Failed to shutdown application`, e as Error);\n    }\n  }\n}\n","import {Model} from \"@decaf-ts/decorator-validation\";\nimport {InternalError} from \"@decaf-ts/db-decorators\";\nimport {Repository} from \"@decaf-ts/core\";\n\nexport function repoForModel(model: string) {\n\tconst m = Model.get(model);\n\tif (!m)\n\t\tthrow new InternalError(`Failed to find repository for ${model}`)\n\tconst repo = Repository.forModel(m);\n\treturn repo;\n}","import { Model } from \"@decaf-ts/decorator-validation\";\nimport { InternalError } from \"@decaf-ts/db-decorators\";\nimport { Repo, Repository } from \"@decaf-ts/core\";\nimport { Constructor } from \"@decaf-ts/decoration\";\nimport { Injectable } from \"@nestjs/common\";\n\n@Injectable()\nexport class RepoFactory {\n  for<M extends Model>(model: string | Constructor<M>): Repo<M> {\n    model = typeof model === \"string\" ? (Model.get(model) as any) : model;\n    if (!model) {\n      throw new InternalError(`Failed to find repository for ${model}`);\n    }\n    return Repository.forModel(model as Constructor<M>);\n  }\n}\n","import { Body, Controller, Get, Param, Post } from \"@nestjs/common\";\nimport {\n  ApiBadRequestResponse,\n  ApiBody,\n  ApiCreatedResponse,\n  ApiExtraModels,\n  ApiNotFoundResponse,\n  ApiOkResponse,\n  ApiOperation,\n  ApiParam,\n  ApiTags,\n  ApiUnprocessableEntityResponse,\n  getSchemaPath,\n} from \"@nestjs/swagger\";\nimport { Adapter, Repository } from \"@decaf-ts/core\";\nimport { Model, ModelConstructor } from \"@decaf-ts/decorator-validation\";\nimport { LoggedClass, Logger, Logging, toKebabCase } from \"@decaf-ts/logging\";\nimport { repoForModel } from \"./utils\";\nimport { RepoFactory } from \"./RepoFactory\";\nimport { DynamicModule, Module } from \"@nestjs/common\";\n\n@Module({})\nexport class DecafModelModule {\n  private static _logger: Logger;\n\n  protected static get log(): Logger {\n    if (!this._logger) this._logger = Logging.for(DecafModelModule);\n    return this._logger;\n  }\n\n  private static toModelController<T extends Model<any>>(\n    modelClass: ModelConstructor<any>\n  ) {\n    const log = this.log.for(this.toModelController);\n    log.debug(`Creating model controller... ${modelClass.name}`);\n    const modelName = toKebabCase(Repository.table(modelClass));\n    const route = modelName;\n\n    @Controller(route)\n    @ApiTags(modelName)\n    @ApiExtraModels(modelClass)\n    class DynamicModelController extends LoggedClass {\n      private readonly repo: any; //= this.repoFactory.for(modelClass.name);\n\n      constructor(private readonly repoFactory: RepoFactory) {\n        super();\n        try {\n          this.repo = this.repoFactory.for(modelClass.name);\n        } catch (e: unknown) {\n          log.error(\n            `Failed to get repository for ${modelClass.name}`,\n            e as Error\n          );\n        }\n      }\n\n      @Post()\n      @ApiOperation({ summary: `Create a new ${modelName}.` })\n      @ApiBody({\n        description: `Payload for ${modelName}`,\n        schema: { $ref: getSchemaPath(modelClass) },\n      })\n      @ApiCreatedResponse({ description: `${modelName} created successfully.` })\n      @ApiBadRequestResponse({ description: \"Payload validation failed.\" })\n      @ApiUnprocessableEntityResponse({\n        description: \"Repository rejected the provided payload.\",\n      })\n      async create(@Body() data: T): Promise<Model<any>> {\n        const log = this.log.for(this.create);\n        log.verbose(`creating new ${modelName}`);\n        const r = repoForModel(\"Account\");\n        const created = await r.create(data);\n        log.info(`created new ${modelName} with id ${created[r.pk]}`);\n        return created;\n      }\n\n      @Get(\":id\")\n      @ApiOperation({ summary: `Retrieve a ${modelName} by id.` })\n      @ApiParam({\n        name: \"id\",\n        description: \"Primary key\",\n        example: \"1234-5678\",\n      })\n      @ApiOkResponse({ description: `${modelName} retrieved successfully.` })\n      @ApiNotFoundResponse({\n        description: \"No record matches the provided identifier.\",\n      })\n      async read(@Param(\"id\") id: string) {\n        const log = this.log.for(this.read);\n        log.debug(`reading ${modelName} with ${this.repo.pk as string} ${id}`);\n        const read = await this.repo.read(id);\n        log.info(`read ${modelName} with id ${read[this.repo.pk]}`);\n        return read;\n      }\n\n      // @Post()\n      // @ApiOperation({summary: \"Create a new record for the given model.\"})\n      // @ApiCreatedResponse({description: \"Record created successfully.\"})\n      // @ApiBadRequestResponse({description: \"Payload validation failed.\"})\n      // @ApiUnprocessableEntityResponse({description: \"Repository rejected the provided payload.\"})\n      // async create(@Param(\"model\") model: string, @Body() data: any) {\n      //     const log = this.log.for(this.create);\n      //     log.verbose(`creating new ${model}`);\n      //     let repo: Repo<Model>;\n      //     let created: Model;\n      //     try {\n      //         repo = repoForModel(model);\n      //         created = await repo.create(data);\n      //     } catch (e: unknown) {\n      //         log.error(`Failed to create new ${model}`, e as Error);\n      //         throw e;\n      //     }\n      //     log.info(`created new ${model} with id ${created[repo.pk]}`);\n      //     return created;\n      // }\n\n      // @Get(\":id\")\n      // @ApiOperation({summary: \"Retrieve a single record by id.\"})\n      // @ApiParam({\n      //     name: \"model\",\n      //     // description: 'Name of the model repository to target.' + `\\n${modelList.map((m: string, i: number) => `${m} - ${Metadata.description(trackedModels[i])}`).join('\\n')}`,\n      //     example: \"agent\",\n      // })\n      // @ApiParam({\n      //     name: \"id\",\n      //     description: \"Primary key value used to load the record.\",\n      //     example: \"1234-5678\",\n      // })\n      // @ApiOkResponse({description: \"Record retrieved successfully.\"})\n      // @ApiNotFoundResponse({description: \"No record matches the provided identifier.\"})\n      // async read(@Param(\"model\") model: string, @Param(\"id\") id: string) {\n      //     const log = this.log.for(this.read);\n      //     let repo: Repo<Model>;\n      //     let read: Model;\n      //     try {\n      //         repo = repoForModel(model);\n      //         log.debug(`reading ${model} with ${repo.pk as string} ${id}`);\n      //         read = await repo.read(id);\n      //     } catch (e: unknown) {\n      //         log.error(`Failed to read ${model} with id ${id}`, e as Error);\n      //         throw e;\n      //     }\n      //     log.info(`read ${model} with id ${read[repo.pk]}`);\n      //     return read;\n      // }\n    }\n\n    return DynamicModelController;\n  }\n\n  static forRoot(flavour: string): DynamicModule {\n    const log = this.log.for(this.forRoot);\n    log.info(`Generating controllers for flavour...`);\n\n    const trackedModels = Adapter.models(flavour);\n    const controllers = trackedModels.map(this.toModelController.bind(this));\n\n    log.info(`Generated ${controllers.length} controllers`);\n\n    return {\n      module: DecafModelModule,\n      controllers,\n      providers: [RepoFactory],\n    };\n  }\n}\n","import { DynamicModule, ForwardReference, Module, Type } from \"@nestjs/common\";\nimport { DecafModuleOptions } from \"./types\";\nimport { DecafCoreModule } from \"./core-module\";\nimport { DecafModelModule } from \"./model-module\";\n\n/**\n * @publicApi\n */\n@Module({})\nexport class DecafModule {\n  static async forRootAsync(\n    options: DecafModuleOptions\n  ): Promise<DynamicModule> {\n    const { autoControllers } = options;\n\n    const adapter = await DecafCoreModule.createAdapter(options);\n    const flavour = adapter.flavour;\n\n    const imports:\n      | (\n          | DynamicModule\n          | Type<any>\n          | Promise<DynamicModule>\n          | ForwardReference<any>\n        )[]\n      | undefined = [DecafCoreModule.forRoot(options)];\n\n    if (autoControllers) {\n      imports.push(DecafModelModule.forRoot(flavour));\n    }\n\n    return {\n      module: DecafModule,\n      imports: imports,\n    };\n  }\n}\n","/**\n * @module for-nest\n * @description This module serves as the main entry point for the ts-workspace library. It aggregates and exports\n * functionality from various submodules and utilities within the project.\n *\n * The module includes:\n * 1. Utility functions and types from the \"./utils\" directory:\n *    - These likely contain helper functions, common types, and shared functionality used throughout the project.\n *    - May include operations for data manipulation, type checking, or other general-purpose utilities.\n *\n * 2. A namespace and related types from the \"./namespace\" directory:\n *    - This could contain domain-specific code or a collection of related functionality.\n *    - Might include interfaces, types, or classes that represent core concepts in the library.\n *\n * 3. A VERSION constant:\n *    - Represents the current version of the module.\n *    - Useful for version checking and compatibility purposes.\n *\n * This structure provides a clean and organized export of the module's functionality, allowing consumers\n * to easily import and use specific parts of the library as needed.\n */\n\nimport { Metadata } from \"@decaf-ts/decoration\";\nimport \"./decoration\";\n\nexport * from \"./decorators\";\nexport * from \"./constants\";\nexport * from \"./decoration\";\nexport * from \"./module\";\nexport * from \"./RepoFactory\";\nexport * from \"./types\";\nexport * from \"./utils\";\n\n/**\n * Represents the current version of the ts-workspace module.\n * The actual version number is replaced during the build process.\n * @constant\n * @type {string}\n */\nexport const VERSION = \"##VERSION##\";\nexport const PACKAGE_NAME = \"##PACKAGE_NAME##\";\n\nMetadata.registerLibrary(PACKAGE_NAME, VERSION);\n"],"names":["DECORATORS","pickBy","negate","isUndefined","METADATA_FACTORY_NAME","isConstructor","METHOD_METADATA","isArray","getTypeIsArrayTuple","getEnumValues","getEnumType","Decoration","InjectablesKeys","Injectable","Scope","Inject","ValidationKeys","PersistenceKeys","DecorationKeys","Logging","__decorate","Global","Module","__param","ModuleRef","Model","InternalError","Repository","RepoFactory","toKebabCase","LoggedClass","Post","ApiOperation","ApiBody","getSchemaPath","ApiCreatedResponse","ApiBadRequestResponse","ApiUnprocessableEntityResponse","Body","Get","ApiParam","ApiOkResponse","ApiNotFoundResponse","Param","Controller","ApiTags","ApiExtraModels","Adapter","DecafModule","Metadata"],"mappings":"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"}