@decaf-ts/for-nest 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/LICENSE.md ADDED
@@ -0,0 +1,22 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025 Tiago Venceslau and Contributors
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
22
+
package/README.md ADDED
@@ -0,0 +1,93 @@
1
+ [![Banner](./workdocs/assets/Banner.png)](https://decaf-ts.github.io/ts-workspace/)
2
+ ## Typescript Template
3
+
4
+ This repository is meant to provide an enterprise template for any standard Typescript project
5
+
6
+
7
+ ![Licence](https://img.shields.io/github/license/decaf-ts/for-nest.svg?style=plastic)
8
+ ![GitHub language count](https://img.shields.io/github/languages/count/decaf-ts/for-nest?style=plastic)
9
+ ![GitHub top language](https://img.shields.io/github/languages/top/decaf-ts/for-nest?style=plastic)
10
+
11
+ [![Build & Test](https://github.com/decaf-ts/for-nest/actions/workflows/nodejs-build-prod.yaml/badge.svg)](https://github.com/decaf-ts/for-nest/actions/workflows/nodejs-build-prod.yaml)
12
+ [![CodeQL](https://github.com/decaf-ts/for-nest/actions/workflows/codeql-analysis.yml/badge.svg)](https://github.com/decaf-ts/for-nest/actions/workflows/codeql-analysis.yml)[![Snyk Analysis](https://github.com/decaf-ts/for-nest/actions/workflows/snyk-analysis.yaml/badge.svg)](https://github.com/decaf-ts/for-nest/actions/workflows/snyk-analysis.yaml)
13
+ [![Pages builder](https://github.com/decaf-ts/for-nest/actions/workflows/pages.yaml/badge.svg)](https://github.com/decaf-ts/for-nest/actions/workflows/pages.yaml)
14
+ [![.github/workflows/release-on-tag.yaml](https://github.com/decaf-ts/for-nest/actions/workflows/release-on-tag.yaml/badge.svg?event=release)](https://github.com/decaf-ts/for-nest/actions/workflows/release-on-tag.yaml)
15
+
16
+ ![Open Issues](https://img.shields.io/github/issues/decaf-ts/for-nest.svg)
17
+ ![Closed Issues](https://img.shields.io/github/issues-closed/decaf-ts/for-nest.svg)
18
+ ![Pull Requests](https://img.shields.io/github/issues-pr-closed/decaf-ts/for-nest.svg)
19
+ ![Maintained](https://img.shields.io/badge/Maintained%3F-yes-green.svg)
20
+
21
+ ![Forks](https://img.shields.io/github/forks/decaf-ts/for-nest.svg)
22
+ ![Stars](https://img.shields.io/github/stars/decaf-ts/for-nest.svg)
23
+ ![Watchers](https://img.shields.io/github/watchers/decaf-ts/for-nest.svg)
24
+
25
+ ![Node Version](https://img.shields.io/badge/dynamic/json.svg?url=https%3A%2F%2Fraw.githubusercontent.com%2Fbadges%2Fshields%2Fmaster%2Fpackage.json&label=Node&query=$.engines.node&colorB=blue)
26
+ ![NPM Version](https://img.shields.io/badge/dynamic/json.svg?url=https%3A%2F%2Fraw.githubusercontent.com%2Fbadges%2Fshields%2Fmaster%2Fpackage.json&label=NPM&query=$.engines.npm&colorB=purple)
27
+
28
+ Documentation available [here](https://decaf-ts.github.io/for-nest/)
29
+
30
+ ### Description
31
+
32
+ No one needs the hassle of setting up new repos every time.
33
+
34
+ Now you can create new repositories from this template and enjoy having everything set up for you.
35
+
36
+
37
+
38
+ ### How to Use
39
+
40
+ - [Initial Setup](./workdocs/tutorials/For%20Developers.md#_initial-setup_)
41
+ - [Installation](./workdocs/tutorials/For%20Developers.md#installation)
42
+ - [Scripts](./workdocs/tutorials/For%20Developers.md#scripts)
43
+ - [Linting](./workdocs/tutorials/For%20Developers.md#testing)
44
+ - [CI/CD](./workdocs/tutorials/For%20Developers.md#continuous-integrationdeployment)
45
+ - [Publishing](./workdocs/tutorials/For%20Developers.md#publishing)
46
+ - [Structure](./workdocs/tutorials/For%20Developers.md#repository-structure)
47
+ - [IDE Integrations](./workdocs/tutorials/For%20Developers.md#ide-integrations)
48
+ - [VSCode(ium)](./workdocs/tutorials/For%20Developers.md#visual-studio-code-vscode)
49
+ - [WebStorm](./workdocs/tutorials/For%20Developers.md#webstorm)
50
+ - [Considerations](./workdocs/tutorials/For%20Developers.md#considerations)
51
+
52
+
53
+
54
+
55
+ ### Related
56
+
57
+ [![Readme Card](https://github-readme-stats.vercel.app/api/pin/?username=decaf-ts&repo=ts-workspace)](https://github.com/decaf-ts/ts-workspace)
58
+
59
+ ### Social
60
+
61
+ [![LinkedIn](https://img.shields.io/badge/LinkedIn-0077B5?style=for-the-badge&logo=linkedin&logoColor=white)](https://www.linkedin.com/in/decaf-ts/)
62
+
63
+
64
+
65
+
66
+ #### Languages
67
+
68
+ ![TypeScript](https://img.shields.io/badge/TypeScript-007ACC?style=for-the-badge&logo=typescript&logoColor=white)
69
+ ![JavaScript](https://img.shields.io/badge/JavaScript-F7DF1E?style=for-the-badge&logo=javascript&logoColor=black)
70
+ ![NodeJS](https://img.shields.io/badge/Node.js-43853D?style=for-the-badge&logo=node.js&logoColor=white)
71
+ ![ShellScript](https://img.shields.io/badge/Shell_Script-121011?style=for-the-badge&logo=gnu-bash&logoColor=white)
72
+
73
+ ## Getting help
74
+
75
+ If you have bug reports, questions or suggestions please [create a new issue](https://github.com/decaf-ts/ts-workspace/issues/new/choose).
76
+
77
+ ## Contributing
78
+
79
+ I am grateful for any contributions made to this project. Please read [this](./workdocs/98-Contributing.md) to get started.
80
+
81
+ ## Supporting
82
+
83
+ The first and easiest way you can support it is by [Contributing](./workdocs/98-Contributing.md). Even just finding a typo in the documentation is important.
84
+
85
+ Financial support is always welcome and helps keep both me and the project alive and healthy.
86
+
87
+ So if you can, if this project in any way. either by learning something or simply by helping you save precious time, please consider donating.
88
+
89
+ ## License
90
+
91
+ This project is released under the [MIT License](./LICENSE.md).
92
+
93
+ By developers, for developers...
@@ -0,0 +1,112 @@
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';
6
+
7
+ const DECAF_MODULE_OPTIONS = "DecafModuleOptions";
8
+ const DECAF_ADAPTER_ID = "DecafAdapter";
9
+
10
+ var DecafCoreModule_1;
11
+ let DecafCoreModule = DecafCoreModule_1 = class DecafCoreModule extends LoggedClass.LoggedClass {
12
+ constructor(options, moduleRef) {
13
+ super();
14
+ this.options = options;
15
+ this.moduleRef = moduleRef;
16
+ }
17
+ static forRoot(options) {
18
+ const typeOrmModuleOptions = {
19
+ provide: DECAF_MODULE_OPTIONS,
20
+ useValue: options,
21
+ };
22
+ const adapter = {
23
+ useFactory: async (opts) => {
24
+ return new opts.adapter(opts.conf, opts.alias);
25
+ },
26
+ provide: DECAF_ADAPTER_ID,
27
+ durable: true,
28
+ scope: common.Scope.DEFAULT,
29
+ inject: [DECAF_MODULE_OPTIONS],
30
+ };
31
+ const providers = [adapter, typeOrmModuleOptions];
32
+ const exports = [adapter];
33
+ return {
34
+ module: DecafCoreModule_1,
35
+ providers,
36
+ exports,
37
+ };
38
+ }
39
+ async onApplicationShutdown() {
40
+ const adapter = this.moduleRef.get(DECAF_ADAPTER_ID);
41
+ try {
42
+ if (adapter) {
43
+ this.log.info("Shutting down");
44
+ await adapter.shutdown();
45
+ }
46
+ }
47
+ catch (e) {
48
+ this.log.error(`Failed to shutdown application`, e);
49
+ }
50
+ }
51
+ };
52
+ DecafCoreModule = DecafCoreModule_1 = tslib.__decorate([
53
+ common.Global(),
54
+ common.Module({}),
55
+ tslib.__param(0, common.Inject(DECAF_MODULE_OPTIONS)),
56
+ tslib.__metadata("design:paramtypes", [Object, core.ModuleRef])
57
+ ], DecafCoreModule);
58
+
59
+ var DecafModule_1;
60
+ /**
61
+ * @publicApi
62
+ */
63
+ exports.DecafModule = DecafModule_1 = class DecafModule {
64
+ static forRoot(options) {
65
+ return {
66
+ module: DecafModule_1,
67
+ imports: [DecafCoreModule.forRoot(options)],
68
+ };
69
+ }
70
+ };
71
+ exports.DecafModule = DecafModule_1 = tslib.__decorate([
72
+ common.Module({})
73
+ ], exports.DecafModule);
74
+
75
+ /**
76
+ * @module ts-workspace
77
+ * @description This module serves as the main entry point for the ts-workspace library. It aggregates and exports
78
+ * functionality from various submodules and utilities within the project.
79
+ *
80
+ * The module includes:
81
+ * 1. Utility functions and types from the "./utils" directory:
82
+ * - These likely contain helper functions, common types, and shared functionality used throughout the project.
83
+ * - May include operations for data manipulation, type checking, or other general-purpose utilities.
84
+ *
85
+ * 2. A namespace and related types from the "./namespace" directory:
86
+ * - This could contain domain-specific code or a collection of related functionality.
87
+ * - Might include interfaces, types, or classes that represent core concepts in the library.
88
+ *
89
+ * 3. A VERSION constant:
90
+ * - Represents the current version of the module.
91
+ * - Useful for version checking and compatibility purposes.
92
+ *
93
+ * This structure provides a clean and organized export of the module's functionality, allowing consumers
94
+ * to easily import and use specific parts of the library as needed.
95
+ */
96
+ /**
97
+ * Represents the current version of the ts-workspace module.
98
+ * The actual version number is replaced during the build process.
99
+ * @constant
100
+ * @type {string}
101
+ */
102
+ const VERSION = "0.0.1";
103
+ const PACKAGE_NAME = "##PACKAGE_NAME##";
104
+ decoration.Metadata.registerLibrary(PACKAGE_NAME, VERSION);
105
+
106
+ exports.DECAF_ADAPTER_ID = DECAF_ADAPTER_ID;
107
+ exports.DECAF_MODULE_OPTIONS = DECAF_MODULE_OPTIONS;
108
+ exports.PACKAGE_NAME = PACKAGE_NAME;
109
+ exports.VERSION = VERSION;
110
+
111
+ }));
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;;;;;;;;;;;"}
@@ -0,0 +1,107 @@
1
+ import { Metadata } from '@decaf-ts/decoration';
2
+ import { __decorate, __param, __metadata } from 'tslib';
3
+ import { Global, Module, Inject, Scope } from '@nestjs/common';
4
+ import { ModuleRef } from '@nestjs/core';
5
+ import { LoggedClass } from '@decaf-ts/logging/lib/LoggedClass';
6
+
7
+ const DECAF_MODULE_OPTIONS = "DecafModuleOptions";
8
+ const DECAF_ADAPTER_ID = "DecafAdapter";
9
+
10
+ var DecafCoreModule_1;
11
+ let DecafCoreModule = DecafCoreModule_1 = class DecafCoreModule extends LoggedClass {
12
+ constructor(options, moduleRef) {
13
+ super();
14
+ this.options = options;
15
+ this.moduleRef = moduleRef;
16
+ }
17
+ static forRoot(options) {
18
+ const typeOrmModuleOptions = {
19
+ provide: DECAF_MODULE_OPTIONS,
20
+ useValue: options,
21
+ };
22
+ const adapter = {
23
+ useFactory: async (opts) => {
24
+ return new opts.adapter(opts.conf, opts.alias);
25
+ },
26
+ provide: DECAF_ADAPTER_ID,
27
+ durable: true,
28
+ scope: Scope.DEFAULT,
29
+ inject: [DECAF_MODULE_OPTIONS],
30
+ };
31
+ const providers = [adapter, typeOrmModuleOptions];
32
+ const exports = [adapter];
33
+ return {
34
+ module: DecafCoreModule_1,
35
+ providers,
36
+ exports,
37
+ };
38
+ }
39
+ async onApplicationShutdown() {
40
+ const adapter = this.moduleRef.get(DECAF_ADAPTER_ID);
41
+ try {
42
+ if (adapter) {
43
+ this.log.info("Shutting down");
44
+ await adapter.shutdown();
45
+ }
46
+ }
47
+ catch (e) {
48
+ this.log.error(`Failed to shutdown application`, e);
49
+ }
50
+ }
51
+ };
52
+ DecafCoreModule = DecafCoreModule_1 = __decorate([
53
+ Global(),
54
+ Module({}),
55
+ __param(0, Inject(DECAF_MODULE_OPTIONS)),
56
+ __metadata("design:paramtypes", [Object, ModuleRef])
57
+ ], DecafCoreModule);
58
+
59
+ var DecafModule_1;
60
+ /**
61
+ * @publicApi
62
+ */
63
+ let DecafModule = DecafModule_1 = class DecafModule {
64
+ static forRoot(options) {
65
+ return {
66
+ module: DecafModule_1,
67
+ imports: [DecafCoreModule.forRoot(options)],
68
+ };
69
+ }
70
+ };
71
+ DecafModule = DecafModule_1 = __decorate([
72
+ Module({})
73
+ ], DecafModule);
74
+
75
+ /**
76
+ * @module ts-workspace
77
+ * @description This module serves as the main entry point for the ts-workspace library. It aggregates and exports
78
+ * functionality from various submodules and utilities within the project.
79
+ *
80
+ * The module includes:
81
+ * 1. Utility functions and types from the "./utils" directory:
82
+ * - These likely contain helper functions, common types, and shared functionality used throughout the project.
83
+ * - May include operations for data manipulation, type checking, or other general-purpose utilities.
84
+ *
85
+ * 2. A namespace and related types from the "./namespace" directory:
86
+ * - This could contain domain-specific code or a collection of related functionality.
87
+ * - Might include interfaces, types, or classes that represent core concepts in the library.
88
+ *
89
+ * 3. A VERSION constant:
90
+ * - Represents the current version of the module.
91
+ * - Useful for version checking and compatibility purposes.
92
+ *
93
+ * This structure provides a clean and organized export of the module's functionality, allowing consumers
94
+ * to easily import and use specific parts of the library as needed.
95
+ */
96
+ /**
97
+ * Represents the current version of the ts-workspace module.
98
+ * The actual version number is replaced during the build process.
99
+ * @constant
100
+ * @type {string}
101
+ */
102
+ const VERSION = "0.0.1";
103
+ const PACKAGE_NAME = "##PACKAGE_NAME##";
104
+ Metadata.registerLibrary(PACKAGE_NAME, VERSION);
105
+
106
+ export { DECAF_ADAPTER_ID, DECAF_MODULE_OPTIONS, DecafModule, PACKAGE_NAME, VERSION };
107
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9yLW5lc3QuZXNtLmNqcyIsInNvdXJjZXMiOlsiLi4vc3JjL2NvbnN0YW50cy50cyIsIi4uL3NyYy9jb3JlLW1vZHVsZS50cyIsIi4uL3NyYy9tb2R1bGUudHMiLCIuLi9zcmMvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IERFQ0FGX01PRFVMRV9PUFRJT05TID0gXCJEZWNhZk1vZHVsZU9wdGlvbnNcIjtcbmV4cG9ydCBjb25zdCBERUNBRl9BREFQVEVSX0lEID0gXCJEZWNhZkFkYXB0ZXJcIjtcbiIsImltcG9ydCB7XG4gIER5bmFtaWNNb2R1bGUsXG4gIEdsb2JhbCxcbiAgSW5qZWN0LFxuICBNb2R1bGUsXG4gIE9uQXBwbGljYXRpb25TaHV0ZG93bixcbiAgU2NvcGUsXG59IGZyb20gXCJAbmVzdGpzL2NvbW1vblwiO1xuaW1wb3J0IHsgTW9kdWxlUmVmIH0gZnJvbSBcIkBuZXN0anMvY29yZVwiO1xuaW1wb3J0IHR5cGUgeyBEZWNhZk1vZHVsZU9wdGlvbnMgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHsgREVDQUZfQURBUFRFUl9JRCwgREVDQUZfTU9EVUxFX09QVElPTlMgfSBmcm9tIFwiLi9jb25zdGFudHNcIjtcbmltcG9ydCB7IEZhY3RvcnlQcm92aWRlciB9IGZyb20gXCJAbmVzdGpzL2NvbW1vbi9pbnRlcmZhY2VzL21vZHVsZXMvcHJvdmlkZXIuaW50ZXJmYWNlXCI7XG5pbXBvcnQgeyBBZGFwdGVyIH0gZnJvbSBcIkBkZWNhZi10cy9jb3JlXCI7XG5pbXBvcnQgeyBMb2dnZWRDbGFzcyB9IGZyb20gXCJAZGVjYWYtdHMvbG9nZ2luZy9saWIvTG9nZ2VkQ2xhc3NcIjtcblxuQEdsb2JhbCgpXG5ATW9kdWxlKHt9KVxuZXhwb3J0IGNsYXNzIERlY2FmQ29yZU1vZHVsZTxcbiAgICBDT05GLFxuICAgIEFEQVBURVIgZXh0ZW5kcyBBZGFwdGVyPENPTkYsIGFueSwgYW55LCBhbnksIGFueT4sXG4gID5cbiAgZXh0ZW5kcyBMb2dnZWRDbGFzc1xuICBpbXBsZW1lbnRzIE9uQXBwbGljYXRpb25TaHV0ZG93blxue1xuICBjb25zdHJ1Y3RvcihcbiAgICBASW5qZWN0KERFQ0FGX01PRFVMRV9PUFRJT05TKVxuICAgIHByaXZhdGUgcmVhZG9ubHkgb3B0aW9uczogRGVjYWZNb2R1bGVPcHRpb25zPENPTkYsIEFEQVBURVI+LFxuICAgIHByaXZhdGUgcmVhZG9ubHkgbW9kdWxlUmVmOiBNb2R1bGVSZWZcbiAgKSB7XG4gICAgc3VwZXIoKTtcbiAgfVxuXG4gIHN0YXRpYyBmb3JSb290KG9wdGlvbnM6IERlY2FmTW9kdWxlT3B0aW9ucyk6IER5bmFtaWNNb2R1bGUge1xuICAgIGNvbnN0IHR5cGVPcm1Nb2R1bGVPcHRpb25zID0ge1xuICAgICAgcHJvdmlkZTogREVDQUZfTU9EVUxFX09QVElPTlMsXG4gICAgICB1c2VWYWx1ZTogb3B0aW9ucyxcbiAgICB9O1xuXG4gICAgY29uc3QgYWRhcHRlcjogRmFjdG9yeVByb3ZpZGVyPGFueT4gPSB7XG4gICAgICB1c2VGYWN0b3J5OiBhc3luYyAob3B0czogRGVjYWZNb2R1bGVPcHRpb25zKSA9PiB7XG4gICAgICAgIHJldHVybiBuZXcgb3B0cy5hZGFwdGVyKG9wdHMuY29uZiwgb3B0cy5hbGlhcyk7XG4gICAgICB9LFxuICAgICAgcHJvdmlkZTogREVDQUZfQURBUFRFUl9JRCxcbiAgICAgIGR1cmFibGU6IHRydWUsXG4gICAgICBzY29wZTogU2NvcGUuREVGQVVMVCxcbiAgICAgIGluamVjdDogW0RFQ0FGX01PRFVMRV9PUFRJT05TXSxcbiAgICB9O1xuXG4gICAgY29uc3QgcHJvdmlkZXJzID0gW2FkYXB0ZXIsIHR5cGVPcm1Nb2R1bGVPcHRpb25zXTtcbiAgICBjb25zdCBleHBvcnRzID0gW2FkYXB0ZXJdO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIG1vZHVsZTogRGVjYWZDb3JlTW9kdWxlLFxuICAgICAgcHJvdmlkZXJzLFxuICAgICAgZXhwb3J0cyxcbiAgICB9O1xuICB9XG5cbiAgYXN5bmMgb25BcHBsaWNhdGlvblNodXRkb3duKCk6IFByb21pc2U8dm9pZD4ge1xuICAgIGNvbnN0IGFkYXB0ZXIgPSB0aGlzLm1vZHVsZVJlZi5nZXQ8QURBUFRFUj4oREVDQUZfQURBUFRFUl9JRCk7XG4gICAgdHJ5IHtcbiAgICAgIGlmIChhZGFwdGVyKSB7XG4gICAgICAgIHRoaXMubG9nLmluZm8oXCJTaHV0dGluZyBkb3duXCIpO1xuICAgICAgICBhd2FpdCBhZGFwdGVyLnNodXRkb3duKCk7XG4gICAgICB9XG4gICAgfSBjYXRjaCAoZTogdW5rbm93bikge1xuICAgICAgdGhpcy5sb2cuZXJyb3IoYEZhaWxlZCB0byBzaHV0ZG93biBhcHBsaWNhdGlvbmAsIGUgYXMgRXJyb3IpO1xuICAgIH1cbiAgfVxufVxuIiwiaW1wb3J0IHsgRHluYW1pY01vZHVsZSwgTW9kdWxlIH0gZnJvbSBcIkBuZXN0anMvY29tbW9uXCI7XG5pbXBvcnQgeyBEZWNhZk1vZHVsZU9wdGlvbnMgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHsgRGVjYWZDb3JlTW9kdWxlIH0gZnJvbSBcIi4vY29yZS1tb2R1bGVcIjtcblxuLyoqXG4gKiBAcHVibGljQXBpXG4gKi9cbkBNb2R1bGUoe30pXG5leHBvcnQgY2xhc3MgRGVjYWZNb2R1bGUge1xuICBzdGF0aWMgZm9yUm9vdChvcHRpb25zOiBEZWNhZk1vZHVsZU9wdGlvbnMpOiBEeW5hbWljTW9kdWxlIHtcbiAgICByZXR1cm4ge1xuICAgICAgbW9kdWxlOiBEZWNhZk1vZHVsZSxcbiAgICAgIGltcG9ydHM6IFtEZWNhZkNvcmVNb2R1bGUuZm9yUm9vdChvcHRpb25zKV0sXG4gICAgfTtcbiAgfVxufVxuIiwiLyoqXG4gKiBAbW9kdWxlIHRzLXdvcmtzcGFjZVxuICogQGRlc2NyaXB0aW9uIFRoaXMgbW9kdWxlIHNlcnZlcyBhcyB0aGUgbWFpbiBlbnRyeSBwb2ludCBmb3IgdGhlIHRzLXdvcmtzcGFjZSBsaWJyYXJ5LiBJdCBhZ2dyZWdhdGVzIGFuZCBleHBvcnRzXG4gKiBmdW5jdGlvbmFsaXR5IGZyb20gdmFyaW91cyBzdWJtb2R1bGVzIGFuZCB1dGlsaXRpZXMgd2l0aGluIHRoZSBwcm9qZWN0LlxuICpcbiAqIFRoZSBtb2R1bGUgaW5jbHVkZXM6XG4gKiAxLiBVdGlsaXR5IGZ1bmN0aW9ucyBhbmQgdHlwZXMgZnJvbSB0aGUgXCIuL3V0aWxzXCIgZGlyZWN0b3J5OlxuICogICAgLSBUaGVzZSBsaWtlbHkgY29udGFpbiBoZWxwZXIgZnVuY3Rpb25zLCBjb21tb24gdHlwZXMsIGFuZCBzaGFyZWQgZnVuY3Rpb25hbGl0eSB1c2VkIHRocm91Z2hvdXQgdGhlIHByb2plY3QuXG4gKiAgICAtIE1heSBpbmNsdWRlIG9wZXJhdGlvbnMgZm9yIGRhdGEgbWFuaXB1bGF0aW9uLCB0eXBlIGNoZWNraW5nLCBvciBvdGhlciBnZW5lcmFsLXB1cnBvc2UgdXRpbGl0aWVzLlxuICpcbiAqIDIuIEEgbmFtZXNwYWNlIGFuZCByZWxhdGVkIHR5cGVzIGZyb20gdGhlIFwiLi9uYW1lc3BhY2VcIiBkaXJlY3Rvcnk6XG4gKiAgICAtIFRoaXMgY291bGQgY29udGFpbiBkb21haW4tc3BlY2lmaWMgY29kZSBvciBhIGNvbGxlY3Rpb24gb2YgcmVsYXRlZCBmdW5jdGlvbmFsaXR5LlxuICogICAgLSBNaWdodCBpbmNsdWRlIGludGVyZmFjZXMsIHR5cGVzLCBvciBjbGFzc2VzIHRoYXQgcmVwcmVzZW50IGNvcmUgY29uY2VwdHMgaW4gdGhlIGxpYnJhcnkuXG4gKlxuICogMy4gQSBWRVJTSU9OIGNvbnN0YW50OlxuICogICAgLSBSZXByZXNlbnRzIHRoZSBjdXJyZW50IHZlcnNpb24gb2YgdGhlIG1vZHVsZS5cbiAqICAgIC0gVXNlZnVsIGZvciB2ZXJzaW9uIGNoZWNraW5nIGFuZCBjb21wYXRpYmlsaXR5IHB1cnBvc2VzLlxuICpcbiAqIFRoaXMgc3RydWN0dXJlIHByb3ZpZGVzIGEgY2xlYW4gYW5kIG9yZ2FuaXplZCBleHBvcnQgb2YgdGhlIG1vZHVsZSdzIGZ1bmN0aW9uYWxpdHksIGFsbG93aW5nIGNvbnN1bWVyc1xuICogdG8gZWFzaWx5IGltcG9ydCBhbmQgdXNlIHNwZWNpZmljIHBhcnRzIG9mIHRoZSBsaWJyYXJ5IGFzIG5lZWRlZC5cbiAqL1xuXG5pbXBvcnQgeyBNZXRhZGF0YSB9IGZyb20gXCJAZGVjYWYtdHMvZGVjb3JhdGlvblwiO1xuXG5leHBvcnQgKiBmcm9tIFwiLi9jb25zdGFudHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL21vZHVsZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdHlwZXNcIjtcblxuLyoqXG4gKiBSZXByZXNlbnRzIHRoZSBjdXJyZW50IHZlcnNpb24gb2YgdGhlIHRzLXdvcmtzcGFjZSBtb2R1bGUuXG4gKiBUaGUgYWN0dWFsIHZlcnNpb24gbnVtYmVyIGlzIHJlcGxhY2VkIGR1cmluZyB0aGUgYnVpbGQgcHJvY2Vzcy5cbiAqIEBjb25zdGFudFxuICogQHR5cGUge3N0cmluZ31cbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBcIiMjVkVSU0lPTiMjXCI7XG5leHBvcnQgY29uc3QgUEFDS0FHRV9OQU1FID0gXCIjI1BBQ0tBR0VfTkFNRSMjXCI7XG5cbk1ldGFkYXRhLnJlZ2lzdGVyTGlicmFyeShQQUNLQUdFX05BTUUsIFZFUlNJT04pO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFPLE1BQU0sb0JBQW9CLEdBQUc7QUFDN0IsTUFBTSxnQkFBZ0IsR0FBRzs7O0FDZ0J6QixJQUFNLGVBQWUsR0FBQSxpQkFBQSxHQUFyQixNQUFNLGVBSVgsU0FBUSxXQUFXLENBQUE7SUFHbkIsV0FFbUIsQ0FBQSxPQUEwQyxFQUMxQyxTQUFvQixFQUFBO0FBRXJDLFFBQUEsS0FBSyxFQUFFO1FBSFUsSUFBTyxDQUFBLE9BQUEsR0FBUCxPQUFPO1FBQ1AsSUFBUyxDQUFBLFNBQUEsR0FBVCxTQUFTOztJQUs1QixPQUFPLE9BQU8sQ0FBQyxPQUEyQixFQUFBO0FBQ3hDLFFBQUEsTUFBTSxvQkFBb0IsR0FBRztBQUMzQixZQUFBLE9BQU8sRUFBRSxvQkFBb0I7QUFDN0IsWUFBQSxRQUFRLEVBQUUsT0FBTztTQUNsQjtBQUVELFFBQUEsTUFBTSxPQUFPLEdBQXlCO0FBQ3BDLFlBQUEsVUFBVSxFQUFFLE9BQU8sSUFBd0IsS0FBSTtBQUM3QyxnQkFBQSxPQUFPLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUM7YUFDL0M7QUFDRCxZQUFBLE9BQU8sRUFBRSxnQkFBZ0I7QUFDekIsWUFBQSxPQUFPLEVBQUUsSUFBSTtZQUNiLEtBQUssRUFBRSxLQUFLLENBQUMsT0FBTztZQUNwQixNQUFNLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztTQUMvQjtBQUVELFFBQUEsTUFBTSxTQUFTLEdBQUcsQ0FBQyxPQUFPLEVBQUUsb0JBQW9CLENBQUM7QUFDakQsUUFBQSxNQUFNLE9BQU8sR0FBRyxDQUFDLE9BQU8sQ0FBQztRQUV6QixPQUFPO0FBQ0wsWUFBQSxNQUFNLEVBQUUsaUJBQWU7WUFDdkIsU0FBUztZQUNULE9BQU87U0FDUjs7QUFHSCxJQUFBLE1BQU0scUJBQXFCLEdBQUE7UUFDekIsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQVUsZ0JBQWdCLENBQUM7QUFDN0QsUUFBQSxJQUFJO1lBQ0YsSUFBSSxPQUFPLEVBQUU7QUFDWCxnQkFBQSxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUM7QUFDOUIsZ0JBQUEsTUFBTSxPQUFPLENBQUMsUUFBUSxFQUFFOzs7UUFFMUIsT0FBTyxDQUFVLEVBQUU7WUFDbkIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBZ0MsOEJBQUEsQ0FBQSxFQUFFLENBQVUsQ0FBQzs7O0NBR2pFO0FBcERZLGVBQWUsR0FBQSxpQkFBQSxHQUFBLFVBQUEsQ0FBQTtBQUYzQixJQUFBLE1BQU0sRUFBRTtJQUNSLE1BQU0sQ0FBQyxFQUFFLENBQUM7QUFTTixJQUFBLE9BQUEsQ0FBQSxDQUFBLEVBQUEsTUFBTSxDQUFDLG9CQUFvQixDQUFDLENBQUE7NkNBRUQsU0FBUyxDQUFBO0FBVjVCLENBQUEsRUFBQSxlQUFlLENBb0QzQjs7O0FDakVEOztBQUVHO0FBRVUsSUFBQSxXQUFXLEdBQWpCLGFBQUEsR0FBQSxNQUFNLFdBQVcsQ0FBQTtJQUN0QixPQUFPLE9BQU8sQ0FBQyxPQUEyQixFQUFBO1FBQ3hDLE9BQU87QUFDTCxZQUFBLE1BQU0sRUFBRSxhQUFXO1lBQ25CLE9BQU8sRUFBRSxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7U0FDNUM7OztBQUxRLFdBQVcsR0FBQSxhQUFBLEdBQUEsVUFBQSxDQUFBO0lBRHZCLE1BQU0sQ0FBQyxFQUFFO0FBQ0csQ0FBQSxFQUFBLFdBQVcsQ0FPdkI7O0FDZkQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBb0JHO0FBUUg7Ozs7O0FBS0c7QUFDSSxNQUFNLE9BQU8sR0FBRztBQUNoQixNQUFNLFlBQVksR0FBRztBQUU1QixRQUFRLENBQUMsZUFBZSxDQUFDLFlBQVksRUFBRSxPQUFPLENBQUM7Ozs7In0=
@@ -0,0 +1,122 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.default = nest;
4
+ const commander_1 = require("commander");
5
+ const utils_1 = require("@decaf-ts/utils");
6
+ const logging_1 = require("@decaf-ts/logging");
7
+ var Projects;
8
+ (function (Projects) {
9
+ Projects["NEST_PROJECT"] = "nest-project";
10
+ })(Projects || (Projects = {}));
11
+ var Types;
12
+ (function (Types) {
13
+ Types["CONTROLLER"] = "page";
14
+ Types["SCHEMATICS"] = "schematics";
15
+ })(Types || (Types = {}));
16
+ const logger = logging_1.Logging.for("nestjs-cli");
17
+ /**
18
+ * Creates and returns a Command object for the Angular CLI module in decaf-ts.
19
+ * This function sets up a 'generate' command that can create various Angular artifacts.
20
+ *
21
+ * @returns {Command} A Command object configured with the 'generate' subcommand and its action.
22
+ *
23
+ * The command syntax is: generate <type> <name> [project]
24
+ * @param {Types} type - The type of artifact to generate (e.g., service, component, directive, page).
25
+ * @param {string} name - The name of the artifact to be generated.
26
+ * @param {Projects} [project=Projects.FOR_ANGULAR] - The project for which to generate the artifact.
27
+ * Defaults to the main Angular project if not specified.
28
+ *
29
+ * @throws {Error} If an invalid type is provided.
30
+ *
31
+ * @example
32
+ * // Usage in CLI
33
+ * // decaf-ts generate service my-service
34
+ * // decaf-ts generate component my-component for-angular-app
35
+ */
36
+ function nest() {
37
+ return new commander_1.Command()
38
+ .name("nest")
39
+ .command("generate <type> <name> [project]")
40
+ .description(`decaf-ts NestJS CLI module`)
41
+ .action(async (type, name,
42
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
43
+ project = Projects.NEST_PROJECT) => {
44
+ if (!validateType(type))
45
+ return logger.error(`${type} is not valid. Use service, component or directive.`);
46
+ //
47
+ // if (type === Types.SCHEMATICS) return await generateSchematics();
48
+ //
49
+ // if (type === Types.CONTROLLER) {
50
+ // logger.info(
51
+ // `Pages can be only generate for app. Forcing project to: ${Projects.FOR_ANGULAR_APP}`
52
+ // );
53
+ // project = Projects.FOR_ANGULAR_APP;
54
+ // }
55
+ //
56
+ // (project as string) = parseProjectName(project);
57
+ //
58
+ // if (!validateProject(project)) project = Projects.NEST_PROJECT;
59
+ // const command =
60
+ // project === Projects.FOR_ANGULAR_APP
61
+ // ? "ionic generate"
62
+ // : `ng generate --project=${Projects.NEST_PROJECT} --path=src/lib/${type}s`;
63
+ //
64
+ // try {
65
+ // const result = await execute(`${command} ${type} ${name}`);
66
+ // logger.info(result as string);
67
+ // } catch (error: any) {
68
+ // logger.error(error?.message || error);
69
+ // }
70
+ });
71
+ }
72
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
73
+ async function generateSchematics() {
74
+ return Promise.all([
75
+ execute(`npm link schematics`),
76
+ execute(`cd schematics`),
77
+ execute(`npm install`),
78
+ execute(`npm run build`),
79
+ execute(`npx schematics .:schematics --name=decaf`),
80
+ ])
81
+ .then((res) => res)
82
+ .catch((error) => error);
83
+ }
84
+ /**
85
+ * Executes a shell command asynchronously.
86
+ *
87
+ * @param command - The shell command to execute.
88
+ * @returns A Promise that resolves with the command's stdout output as a string if successful,
89
+ * or rejects with an error message if the command fails or produces stderr output.
90
+ */
91
+ async function execute(command) {
92
+ try {
93
+ return await (0, utils_1.runCommand)(command).promise;
94
+ }
95
+ catch (error) {
96
+ logger.error(error?.message || error);
97
+ }
98
+ }
99
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
100
+ function parseProjectName(value) {
101
+ return value.toLowerCase();
102
+ }
103
+ /**
104
+ * Validates if the given type value is a valid enum member of Types.
105
+ *
106
+ * @param value - The type value to validate.
107
+ * @returns A boolean indicating whether the value is a valid Types enum member.
108
+ */
109
+ function validateType(value) {
110
+ return Object.values(Types).includes(value);
111
+ }
112
+ /**
113
+ * Validates if the given project value is a valid enum member of Projects.
114
+ *
115
+ * @param value - The project value to validate.
116
+ * @returns A boolean indicating whether the value is a valid Projects enum member.
117
+ */
118
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
119
+ function validateProject(value) {
120
+ return Object.values(Projects).includes(value);
121
+ }
122
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cli-module.js","sourceRoot":"","sources":["../src/cli-module.ts"],"names":[],"mappings":";;AAkCA,uBA0CC;AA5ED,yCAAoC;AACpC,2CAA6C;AAC7C,+CAA4C;AAE5C,IAAK,QAEJ;AAFD,WAAK,QAAQ;IACX,yCAA6B,CAAA;AAC/B,CAAC,EAFI,QAAQ,KAAR,QAAQ,QAEZ;AAED,IAAK,KAGJ;AAHD,WAAK,KAAK;IACR,4BAAmB,CAAA;IACnB,kCAAyB,CAAA;AAC3B,CAAC,EAHI,KAAK,KAAL,KAAK,QAGT;AAED,MAAM,MAAM,GAAG,iBAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;AAEzC;;;;;;;;;;;;;;;;;;GAkBG;AACH,SAAwB,IAAI;IAC1B,OAAO,IAAI,mBAAO,EAAE;SACjB,IAAI,CAAC,MAAM,CAAC;SACZ,OAAO,CAAC,kCAAkC,CAAC;SAC3C,WAAW,CAAC,4BAA4B,CAAC;SACzC,MAAM,CACL,KAAK,EACH,IAAW,EACX,IAAY;IACZ,6DAA6D;IAC7D,UAAoB,QAAQ,CAAC,YAAY,EACzC,EAAE;QACF,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;YACrB,OAAO,MAAM,CAAC,KAAK,CACjB,GAAG,IAAI,qDAAqD,CAC7D,CAAC;QACJ,EAAE;QACF,sEAAsE;QACtE,EAAE;QACF,qCAAqC;QACrC,mBAAmB;QACnB,8FAA8F;QAC9F,SAAS;QACT,0CAA0C;QAC1C,MAAM;QACN,EAAE;QACF,qDAAqD;QACrD,EAAE;QACF,oEAAoE;QACpE,oBAAoB;QACpB,2CAA2C;QAC3C,2BAA2B;QAC3B,oFAAoF;QACpF,EAAE;QACF,UAAU;QACV,kEAAkE;QAClE,qCAAqC;QACrC,2BAA2B;QAC3B,6CAA6C;QAC7C,MAAM;IACR,CAAC,CACF,CAAC;AACN,CAAC;AAED,6DAA6D;AAC7D,KAAK,UAAU,kBAAkB;IAC/B,OAAO,OAAO,CAAC,GAAG,CAAC;QACjB,OAAO,CAAC,qBAAqB,CAAC;QAC9B,OAAO,CAAC,eAAe,CAAC;QACxB,OAAO,CAAC,aAAa,CAAC;QACtB,OAAO,CAAC,eAAe,CAAC;QACxB,OAAO,CAAC,0CAA0C,CAAC;KACpD,CAAC;SACC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC;SAClB,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC;AAC7B,CAAC;AAED;;;;;;GAMG;AACH,KAAK,UAAU,OAAO,CAAC,OAAe;IACpC,IAAI,CAAC;QACH,OAAO,MAAM,IAAA,kBAAU,EAAC,OAAO,CAAC,CAAC,OAAO,CAAC;IAC3C,CAAC;IAAC,OAAO,KAAU,EAAE,CAAC;QACpB,MAAM,CAAC,KAAK,CAAC,KAAK,EAAE,OAAO,IAAI,KAAK,CAAC,CAAC;IACxC,CAAC;AACH,CAAC;AAED,6DAA6D;AAC7D,SAAS,gBAAgB,CAAC,KAAa;IACrC,OAAO,KAAK,CAAC,WAAW,EAAE,CAAC;AAC7B,CAAC;AAED;;;;;GAKG;AACH,SAAS,YAAY,CAAC,KAAY;IAChC,OAAO,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;AAC9C,CAAC;AAED;;;;;GAKG;AACH,6DAA6D;AAC7D,SAAS,eAAe,CAAC,KAAa;IACpC,OAAO,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,KAAiB,CAAC,CAAC;AAC7D,CAAC","sourcesContent":["import { Command } from \"commander\";\nimport { runCommand } from \"@decaf-ts/utils\";\nimport { Logging } from \"@decaf-ts/logging\";\n\nenum Projects {\n  NEST_PROJECT = \"nest-project\",\n}\n\nenum Types {\n  CONTROLLER = \"page\",\n  SCHEMATICS = \"schematics\",\n}\n\nconst logger = Logging.for(\"nestjs-cli\");\n\n/**\n * Creates and returns a Command object for the Angular CLI module in decaf-ts.\n * This function sets up a 'generate' command that can create various Angular artifacts.\n *\n * @returns {Command} A Command object configured with the 'generate' subcommand and its action.\n *\n * The command syntax is: generate <type> <name> [project]\n * @param {Types} type - The type of artifact to generate (e.g., service, component, directive, page).\n * @param {string} name - The name of the artifact to be generated.\n * @param {Projects} [project=Projects.FOR_ANGULAR] - The project for which to generate the artifact.\n *                   Defaults to the main Angular project if not specified.\n *\n * @throws {Error} If an invalid type is provided.\n *\n * @example\n * // Usage in CLI\n * // decaf-ts generate service my-service\n * // decaf-ts generate component my-component for-angular-app\n */\nexport default function nest() {\n  return new Command()\n    .name(\"nest\")\n    .command(\"generate <type> <name> [project]\")\n    .description(`decaf-ts NestJS CLI module`)\n    .action(\n      async (\n        type: Types,\n        name: string,\n        // eslint-disable-next-line @typescript-eslint/no-unused-vars\n        project: Projects = Projects.NEST_PROJECT\n      ) => {\n        if (!validateType(type))\n          return logger.error(\n            `${type} is not valid. Use service, component or directive.`\n          );\n        //\n        //   if (type === Types.SCHEMATICS) return await generateSchematics();\n        //\n        //   if (type === Types.CONTROLLER) {\n        //     logger.info(\n        //       `Pages can be only generate for app. Forcing project to: ${Projects.FOR_ANGULAR_APP}`\n        //     );\n        //     project = Projects.FOR_ANGULAR_APP;\n        //   }\n        //\n        //   (project as string) = parseProjectName(project);\n        //\n        //   if (!validateProject(project)) project = Projects.NEST_PROJECT;\n        //   const command =\n        //     project === Projects.FOR_ANGULAR_APP\n        //       ? \"ionic generate\"\n        //       : `ng generate --project=${Projects.NEST_PROJECT} --path=src/lib/${type}s`;\n        //\n        //   try {\n        //     const result = await execute(`${command} ${type} ${name}`);\n        //     logger.info(result as string);\n        //   } catch (error: any) {\n        //     logger.error(error?.message || error);\n        //   }\n      }\n    );\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nasync function generateSchematics() {\n  return Promise.all([\n    execute(`npm link schematics`),\n    execute(`cd schematics`),\n    execute(`npm install`),\n    execute(`npm run build`),\n    execute(`npx schematics .:schematics --name=decaf`),\n  ])\n    .then((res) => res)\n    .catch((error) => error);\n}\n\n/**\n * Executes a shell command asynchronously.\n *\n * @param command - The shell command to execute.\n * @returns A Promise that resolves with the command's stdout output as a string if successful,\n *          or rejects with an error message if the command fails or produces stderr output.\n */\nasync function execute(command: string): Promise<string | void> {\n  try {\n    return await runCommand(command).promise;\n  } catch (error: any) {\n    logger.error(error?.message || error);\n  }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nfunction parseProjectName(value: string): string {\n  return value.toLowerCase();\n}\n\n/**\n * Validates if the given type value is a valid enum member of Types.\n *\n * @param value - The type value to validate.\n * @returns A boolean indicating whether the value is a valid Types enum member.\n */\nfunction validateType(value: Types): boolean {\n  return Object.values(Types).includes(value);\n}\n\n/**\n * Validates if the given project value is a valid enum member of Projects.\n *\n * @param value - The project value to validate.\n * @returns A boolean indicating whether the value is a valid Projects enum member.\n */\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nfunction validateProject(value: string): boolean {\n  return Object.values(Projects).includes(value as Projects);\n}\n"]}
@@ -0,0 +1,48 @@
1
+ /**
2
+ * Creates and returns a Command object for the Angular CLI module in decaf-ts.
3
+ * This function sets up a 'generate' command that can create various Angular artifacts.
4
+ *
5
+ * @returns {Command} A Command object configured with the 'generate' subcommand and its action.
6
+ *
7
+ * The command syntax is: generate <type> <name> [project]
8
+ * @param {Types} type - The type of artifact to generate (e.g., service, component, directive, page).
9
+ * @param {string} name - The name of the artifact to be generated.
10
+ * @param {Projects} [project=Projects.FOR_ANGULAR] - The project for which to generate the artifact.
11
+ * Defaults to the main Angular project if not specified.
12
+ *
13
+ * @throws {Error} If an invalid type is provided.
14
+ *
15
+ * @example
16
+ * // Usage in CLI
17
+ * // decaf-ts generate service my-service
18
+ * // decaf-ts generate component my-component for-angular-app
19
+ */
20
+ export default function nest(): {
21
+ [key: string]: any;
22
+ args: string[];
23
+ version(str: string, flags?: string): /*elided*/ any;
24
+ command(name: string, desc?: string, opts?: import("commander").CommandOptions): /*elided*/ any;
25
+ arguments(desc: string): /*elided*/ any;
26
+ parseExpectedArgs(args: string[]): /*elided*/ any;
27
+ action(fn: (...args: any[]) => void): /*elided*/ any;
28
+ option(flags: string, description?: string, fn?: ((arg1: any, arg2: any) => void) | RegExp, defaultValue?: any): /*elided*/ any;
29
+ option(flags: string, description?: string, defaultValue?: any): /*elided*/ any;
30
+ allowUnknownOption(arg?: boolean): /*elided*/ any;
31
+ parse(argv: string[]): /*elided*/ any;
32
+ parseOptions(argv: string[]): import("commander").ParseOptionsResult;
33
+ opts(): {
34
+ [key: string]: any;
35
+ };
36
+ description(str: string, argsDescription?: {
37
+ [argName: string]: string;
38
+ }): /*elided*/ any;
39
+ description(): string;
40
+ alias(alias: string): /*elided*/ any;
41
+ alias(): string;
42
+ usage(str: string): /*elided*/ any;
43
+ usage(): string;
44
+ name(str: string): /*elided*/ any;
45
+ name(): string;
46
+ outputHelp(cb?: (str: string) => string): void;
47
+ help(cb?: (str: string) => string): never;
48
+ };
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DECAF_ADAPTER_ID = exports.DECAF_MODULE_OPTIONS = void 0;
4
+ exports.DECAF_MODULE_OPTIONS = "DecafModuleOptions";
5
+ exports.DECAF_ADAPTER_ID = "DecafAdapter";
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBYSxRQUFBLG9CQUFvQixHQUFHLG9CQUFvQixDQUFDO0FBQzVDLFFBQUEsZ0JBQWdCLEdBQUcsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IERFQ0FGX01PRFVMRV9PUFRJT05TID0gXCJEZWNhZk1vZHVsZU9wdGlvbnNcIjtcbmV4cG9ydCBjb25zdCBERUNBRl9BREFQVEVSX0lEID0gXCJEZWNhZkFkYXB0ZXJcIjtcbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export declare const DECAF_MODULE_OPTIONS = "DecafModuleOptions";
2
+ export declare const DECAF_ADAPTER_ID = "DecafAdapter";
@@ -0,0 +1,69 @@
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
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ var DecafCoreModule_1;
15
+ Object.defineProperty(exports, "__esModule", { value: true });
16
+ exports.DecafCoreModule = void 0;
17
+ const common_1 = require("@nestjs/common");
18
+ const core_1 = require("@nestjs/core");
19
+ const constants_1 = require("./constants.cjs");
20
+ const LoggedClass_1 = require("@decaf-ts/logging/lib/LoggedClass");
21
+ let DecafCoreModule = DecafCoreModule_1 = class DecafCoreModule extends LoggedClass_1.LoggedClass {
22
+ constructor(options, moduleRef) {
23
+ super();
24
+ this.options = options;
25
+ this.moduleRef = moduleRef;
26
+ }
27
+ static forRoot(options) {
28
+ const typeOrmModuleOptions = {
29
+ provide: constants_1.DECAF_MODULE_OPTIONS,
30
+ useValue: options,
31
+ };
32
+ const adapter = {
33
+ useFactory: async (opts) => {
34
+ return new opts.adapter(opts.conf, opts.alias);
35
+ },
36
+ provide: constants_1.DECAF_ADAPTER_ID,
37
+ durable: true,
38
+ scope: common_1.Scope.DEFAULT,
39
+ inject: [constants_1.DECAF_MODULE_OPTIONS],
40
+ };
41
+ const providers = [adapter, typeOrmModuleOptions];
42
+ const exports = [adapter];
43
+ return {
44
+ module: DecafCoreModule_1,
45
+ providers,
46
+ exports,
47
+ };
48
+ }
49
+ async onApplicationShutdown() {
50
+ const adapter = this.moduleRef.get(constants_1.DECAF_ADAPTER_ID);
51
+ try {
52
+ if (adapter) {
53
+ this.log.info("Shutting down");
54
+ await adapter.shutdown();
55
+ }
56
+ }
57
+ catch (e) {
58
+ this.log.error(`Failed to shutdown application`, e);
59
+ }
60
+ }
61
+ };
62
+ exports.DecafCoreModule = DecafCoreModule;
63
+ exports.DecafCoreModule = DecafCoreModule = DecafCoreModule_1 = __decorate([
64
+ (0, common_1.Global)(),
65
+ (0, common_1.Module)({}),
66
+ __param(0, (0, common_1.Inject)(constants_1.DECAF_MODULE_OPTIONS)),
67
+ __metadata("design:paramtypes", [Object, core_1.ModuleRef])
68
+ ], DecafCoreModule);
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29yZS1tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvY29yZS1tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDJDQU93QjtBQUN4Qix1Q0FBeUM7QUFFekMsK0NBQXFFO0FBR3JFLG1FQUFnRTtBQUl6RCxJQUFNLGVBQWUsdUJBQXJCLE1BQU0sZUFJWCxTQUFRLHlCQUFXO0lBR25CLFlBRW1CLE9BQTBDLEVBQzFDLFNBQW9CO1FBRXJDLEtBQUssRUFBRSxDQUFDO1FBSFMsWUFBTyxHQUFQLE9BQU8sQ0FBbUM7UUFDMUMsY0FBUyxHQUFULFNBQVMsQ0FBVztJQUd2QyxDQUFDO0lBRUQsTUFBTSxDQUFDLE9BQU8sQ0FBQyxPQUEyQjtRQUN4QyxNQUFNLG9CQUFvQixHQUFHO1lBQzNCLE9BQU8sRUFBRSxnQ0FBb0I7WUFDN0IsUUFBUSxFQUFFLE9BQU87U0FDbEIsQ0FBQztRQUVGLE1BQU0sT0FBTyxHQUF5QjtZQUNwQyxVQUFVLEVBQUUsS0FBSyxFQUFFLElBQXdCLEVBQUUsRUFBRTtnQkFDN0MsT0FBTyxJQUFJLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDakQsQ0FBQztZQUNELE9BQU8sRUFBRSw0QkFBZ0I7WUFDekIsT0FBTyxFQUFFLElBQUk7WUFDYixLQUFLLEVBQUUsY0FBSyxDQUFDLE9BQU87WUFDcEIsTUFBTSxFQUFFLENBQUMsZ0NBQW9CLENBQUM7U0FDL0IsQ0FBQztRQUVGLE1BQU0sU0FBUyxHQUFHLENBQUMsT0FBTyxFQUFFLG9CQUFvQixDQUFDLENBQUM7UUFDbEQsTUFBTSxPQUFPLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUUxQixPQUFPO1lBQ0wsTUFBTSxFQUFFLGlCQUFlO1lBQ3ZCLFNBQVM7WUFDVCxPQUFPO1NBQ1IsQ0FBQztJQUNKLENBQUM7SUFFRCxLQUFLLENBQUMscUJBQXFCO1FBQ3pCLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFVLDRCQUFnQixDQUFDLENBQUM7UUFDOUQsSUFBSSxDQUFDO1lBQ0gsSUFBSSxPQUFPLEVBQUUsQ0FBQztnQkFDWixJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQztnQkFDL0IsTUFBTSxPQUFPLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDM0IsQ0FBQztRQUNILENBQUM7UUFBQyxPQUFPLENBQVUsRUFBRSxDQUFDO1lBQ3BCLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLGdDQUFnQyxFQUFFLENBQVUsQ0FBQyxDQUFDO1FBQy9ELENBQUM7SUFDSCxDQUFDO0NBQ0YsQ0FBQTtBQXBEWSwwQ0FBZTswQkFBZixlQUFlO0lBRjNCLElBQUEsZUFBTSxHQUFFO0lBQ1IsSUFBQSxlQUFNLEVBQUMsRUFBRSxDQUFDO0lBU04sV0FBQSxJQUFBLGVBQU0sRUFBQyxnQ0FBb0IsQ0FBQyxDQUFBOzZDQUVELGdCQUFTO0dBVjVCLGVBQWUsQ0FvRDNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRHluYW1pY01vZHVsZSxcbiAgR2xvYmFsLFxuICBJbmplY3QsXG4gIE1vZHVsZSxcbiAgT25BcHBsaWNhdGlvblNodXRkb3duLFxuICBTY29wZSxcbn0gZnJvbSBcIkBuZXN0anMvY29tbW9uXCI7XG5pbXBvcnQgeyBNb2R1bGVSZWYgfSBmcm9tIFwiQG5lc3Rqcy9jb3JlXCI7XG5pbXBvcnQgdHlwZSB7IERlY2FmTW9kdWxlT3B0aW9ucyB9IGZyb20gXCIuL3R5cGVzXCI7XG5pbXBvcnQgeyBERUNBRl9BREFQVEVSX0lELCBERUNBRl9NT0RVTEVfT1BUSU9OUyB9IGZyb20gXCIuL2NvbnN0YW50c1wiO1xuaW1wb3J0IHsgRmFjdG9yeVByb3ZpZGVyIH0gZnJvbSBcIkBuZXN0anMvY29tbW9uL2ludGVyZmFjZXMvbW9kdWxlcy9wcm92aWRlci5pbnRlcmZhY2VcIjtcbmltcG9ydCB7IEFkYXB0ZXIgfSBmcm9tIFwiQGRlY2FmLXRzL2NvcmVcIjtcbmltcG9ydCB7IExvZ2dlZENsYXNzIH0gZnJvbSBcIkBkZWNhZi10cy9sb2dnaW5nL2xpYi9Mb2dnZWRDbGFzc1wiO1xuXG5AR2xvYmFsKClcbkBNb2R1bGUoe30pXG5leHBvcnQgY2xhc3MgRGVjYWZDb3JlTW9kdWxlPFxuICAgIENPTkYsXG4gICAgQURBUFRFUiBleHRlbmRzIEFkYXB0ZXI8Q09ORiwgYW55LCBhbnksIGFueSwgYW55PixcbiAgPlxuICBleHRlbmRzIExvZ2dlZENsYXNzXG4gIGltcGxlbWVudHMgT25BcHBsaWNhdGlvblNodXRkb3duXG57XG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoREVDQUZfTU9EVUxFX09QVElPTlMpXG4gICAgcHJpdmF0ZSByZWFkb25seSBvcHRpb25zOiBEZWNhZk1vZHVsZU9wdGlvbnM8Q09ORiwgQURBUFRFUj4sXG4gICAgcHJpdmF0ZSByZWFkb25seSBtb2R1bGVSZWY6IE1vZHVsZVJlZlxuICApIHtcbiAgICBzdXBlcigpO1xuICB9XG5cbiAgc3RhdGljIGZvclJvb3Qob3B0aW9uczogRGVjYWZNb2R1bGVPcHRpb25zKTogRHluYW1pY01vZHVsZSB7XG4gICAgY29uc3QgdHlwZU9ybU1vZHVsZU9wdGlvbnMgPSB7XG4gICAgICBwcm92aWRlOiBERUNBRl9NT0RVTEVfT1BUSU9OUyxcbiAgICAgIHVzZVZhbHVlOiBvcHRpb25zLFxuICAgIH07XG5cbiAgICBjb25zdCBhZGFwdGVyOiBGYWN0b3J5UHJvdmlkZXI8YW55PiA9IHtcbiAgICAgIHVzZUZhY3Rvcnk6IGFzeW5jIChvcHRzOiBEZWNhZk1vZHVsZU9wdGlvbnMpID0+IHtcbiAgICAgICAgcmV0dXJuIG5ldyBvcHRzLmFkYXB0ZXIob3B0cy5jb25mLCBvcHRzLmFsaWFzKTtcbiAgICAgIH0sXG4gICAgICBwcm92aWRlOiBERUNBRl9BREFQVEVSX0lELFxuICAgICAgZHVyYWJsZTogdHJ1ZSxcbiAgICAgIHNjb3BlOiBTY29wZS5ERUZBVUxULFxuICAgICAgaW5qZWN0OiBbREVDQUZfTU9EVUxFX09QVElPTlNdLFxuICAgIH07XG5cbiAgICBjb25zdCBwcm92aWRlcnMgPSBbYWRhcHRlciwgdHlwZU9ybU1vZHVsZU9wdGlvbnNdO1xuICAgIGNvbnN0IGV4cG9ydHMgPSBbYWRhcHRlcl07XG5cbiAgICByZXR1cm4ge1xuICAgICAgbW9kdWxlOiBEZWNhZkNvcmVNb2R1bGUsXG4gICAgICBwcm92aWRlcnMsXG4gICAgICBleHBvcnRzLFxuICAgIH07XG4gIH1cblxuICBhc3luYyBvbkFwcGxpY2F0aW9uU2h1dGRvd24oKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgY29uc3QgYWRhcHRlciA9IHRoaXMubW9kdWxlUmVmLmdldDxBREFQVEVSPihERUNBRl9BREFQVEVSX0lEKTtcbiAgICB0cnkge1xuICAgICAgaWYgKGFkYXB0ZXIpIHtcbiAgICAgICAgdGhpcy5sb2cuaW5mbyhcIlNodXR0aW5nIGRvd25cIik7XG4gICAgICAgIGF3YWl0IGFkYXB0ZXIuc2h1dGRvd24oKTtcbiAgICAgIH1cbiAgICB9IGNhdGNoIChlOiB1bmtub3duKSB7XG4gICAgICB0aGlzLmxvZy5lcnJvcihgRmFpbGVkIHRvIHNodXRkb3duIGFwcGxpY2F0aW9uYCwgZSBhcyBFcnJvcik7XG4gICAgfVxuICB9XG59XG4iXX0=