@openhi/platform 0.0.0

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 (38) hide show
  1. package/README.md +3 -0
  2. package/lib/index.d.ts +2 -0
  3. package/lib/index.js +19 -0
  4. package/lib/openhi.d.ts +88 -0
  5. package/lib/openhi.js +108 -0
  6. package/lib/service.d.ts +36 -0
  7. package/lib/service.js +203 -0
  8. package/lib/templates/generate-templates.d.ts +5 -0
  9. package/lib/templates/generate-templates.js +45 -0
  10. package/lib/templates/service-template.d.ts +33 -0
  11. package/lib/templates/service-template.js +42 -0
  12. package/lib/templates/src/README.md.d.ts +5 -0
  13. package/lib/templates/src/README.md.js +19 -0
  14. package/lib/templates/src/app-test.d.ts +5 -0
  15. package/lib/templates/src/app-test.js +61 -0
  16. package/lib/templates/src/app.d.ts +5 -0
  17. package/lib/templates/src/app.js +27 -0
  18. package/lib/templates/src/config.d.ts +5 -0
  19. package/lib/templates/src/config.js +23 -0
  20. package/lib/templates/src/data/README.md.d.ts +5 -0
  21. package/lib/templates/src/data/README.md.js +19 -0
  22. package/lib/templates/src/data/models/README.md.d.ts +5 -0
  23. package/lib/templates/src/data/models/README.md.js +19 -0
  24. package/lib/templates/src/infrastructure/README.md.d.ts +5 -0
  25. package/lib/templates/src/infrastructure/README.md.js +19 -0
  26. package/lib/templates/src/integrations/README.md.d.ts +5 -0
  27. package/lib/templates/src/integrations/README.md.js +19 -0
  28. package/lib/templates/src/main.d.ts +5 -0
  29. package/lib/templates/src/main.js +15 -0
  30. package/lib/templates/src/workflows/README.md.d.ts +5 -0
  31. package/lib/templates/src/workflows/README.md.js +19 -0
  32. package/lib/workflows/aws-teardown-workflow.d.ts +13 -0
  33. package/lib/workflows/aws-teardown-workflow.js +222 -0
  34. package/lib/workflows/build-dev-workflow.d.ts +12 -0
  35. package/lib/workflows/build-dev-workflow.js +48 -0
  36. package/lib/workflows/build-stage-workflow.d.ts +12 -0
  37. package/lib/workflows/build-stage-workflow.js +60 -0
  38. package/package.json +51 -0
package/README.md ADDED
@@ -0,0 +1,3 @@
1
+ # @openhi/platform
2
+
3
+ Core framework for building platform services in OpenHI. The library provides templates, workflows, and utilities for creating consistent platform implementations and standardized service structure.
package/lib/index.d.ts ADDED
@@ -0,0 +1,2 @@
1
+ export * from "./openhi";
2
+ export * from "./service";
package/lib/index.js ADDED
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./openhi"), exports);
18
+ __exportStar(require("./service"), exports);
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDJDQUF5QjtBQUN6Qiw0Q0FBMEIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9vcGVuaGlcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3NlcnZpY2VcIjtcbiJdfQ==
@@ -0,0 +1,88 @@
1
+ import { MonorepoProject, MonorepoProjectOptions } from "@codedrifters/configulator";
2
+ import { OpenHiConfig } from "@openhi/config";
3
+ import { SetOptional } from "type-fest";
4
+ import { OpenHiService } from "./service";
5
+ export interface OpenHiOptions {
6
+ /*****************************************************************************
7
+ *
8
+ * Root Project Configuration Options
9
+ *
10
+ * Configuration options for the root monorepo project that contains all
11
+ * OpenHi services and coordinate releases and builds.
12
+ *
13
+ ****************************************************************************/
14
+ readonly rootProjectOptions?: SetOptional<MonorepoProjectOptions, "name">;
15
+ /**
16
+ * Monorepo root project, if using an existing project.
17
+ */
18
+ readonly rootProject?: MonorepoProject;
19
+ /*****************************************************************************
20
+ *
21
+ * Service Configuration Options
22
+ *
23
+ * These options are used to configure the various services within the OpenHi
24
+ * framework. Each service can have its own configuration settings, which will
25
+ * be merged with the default configuration.
26
+ *
27
+ ****************************************************************************/
28
+ /**
29
+ * Default configuration used in all services with undefined configs.
30
+ */
31
+ readonly defaultConfig?: OpenHiConfig;
32
+ /**
33
+ * Global Service Config
34
+ */
35
+ readonly globalServiceConfig?: OpenHiConfig;
36
+ /**
37
+ * Auth Service Config
38
+ */
39
+ readonly authServiceConfig?: OpenHiConfig;
40
+ /**
41
+ * Rest API Service Config
42
+ */
43
+ readonly restApiServiceConfig?: OpenHiConfig;
44
+ /**
45
+ * Core Service Config
46
+ */
47
+ readonly coreServiceConfig?: OpenHiConfig;
48
+ /**
49
+ * Data Service Config (DynamoDB FHIR store, S3, etc.)
50
+ */
51
+ readonly dataServiceConfig?: OpenHiConfig;
52
+ }
53
+ export declare class OpenHi {
54
+ /**
55
+ * Final options used to build this instance.
56
+ */
57
+ options: OpenHiOptions;
58
+ /**
59
+ * Monorepo root project, either passed in as an argument or generated in
60
+ * this component
61
+ */
62
+ readonly rootProject?: MonorepoProject;
63
+ /**
64
+ * Test identifier for this instance.
65
+ */
66
+ readonly id: string;
67
+ /**
68
+ * Global service (deployed first; Core and data services depend on it).
69
+ */
70
+ readonly global: OpenHiService;
71
+ /**
72
+ * Auth service (deployed before Core; Core and data services depend on it).
73
+ */
74
+ readonly auth: OpenHiService;
75
+ /**
76
+ * Rest API service
77
+ */
78
+ readonly restApi: OpenHiService;
79
+ /**
80
+ * Core service
81
+ */
82
+ readonly core: OpenHiService;
83
+ /**
84
+ * Data service (DynamoDB FHIR store, S3, and other persistence).
85
+ */
86
+ readonly data: OpenHiService;
87
+ constructor(options?: OpenHiOptions);
88
+ }
package/lib/openhi.js ADDED
@@ -0,0 +1,108 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.OpenHi = void 0;
4
+ const ts_deepmerge_1 = require("ts-deepmerge");
5
+ const service_1 = require("./service");
6
+ const aws_teardown_workflow_1 = require("./workflows/aws-teardown-workflow");
7
+ const build_dev_workflow_1 = require("./workflows/build-dev-workflow");
8
+ const build_stage_workflow_1 = require("./workflows/build-stage-workflow");
9
+ class OpenHi {
10
+ constructor(options = {}) {
11
+ /***************************************************************************
12
+ *
13
+ * Options
14
+ *
15
+ * Combine input options with defaults.
16
+ *
17
+ **************************************************************************/
18
+ this.options = (0, ts_deepmerge_1.merge)({ name: "openhi" }, options);
19
+ this.rootProject = this.options.rootProject;
20
+ this.id = this.options.rootProject?.name ?? "openhi";
21
+ /**
22
+ * In future we would create root project here. For now, require it to be
23
+ * passed in.
24
+ */
25
+ if (!this.rootProject) {
26
+ throw new Error("OpenHi requires a MonorepoProject to be passed in via the rootProject option");
27
+ }
28
+ const rootProject = this.rootProject;
29
+ /***************************************************************************
30
+ *
31
+ * Global Service
32
+ *
33
+ * Authentication (Cognito user pool, client, domain, KMS). Deployed before
34
+ * Core so that Core can consume auth via SSM parameters.
35
+ *
36
+ **************************************************************************/
37
+ this.global = new service_1.OpenHiService(this, "global", {
38
+ type: service_1.OPEN_HI_SERVICE_TYPE.GLOBAL,
39
+ config: (0, ts_deepmerge_1.merge)(this.options?.defaultConfig ?? {}, this.options?.globalServiceConfig ?? {}),
40
+ });
41
+ /***************************************************************************
42
+ *
43
+ * Auth Service
44
+ *
45
+ * Authentication (Cognito user pool, client, domain, KMS). Deployed before
46
+ * Core so that Core can consume auth via SSM parameters.
47
+ *
48
+ **************************************************************************/
49
+ this.auth = new service_1.OpenHiService(this, "auth", {
50
+ type: service_1.OPEN_HI_SERVICE_TYPE.AUTH,
51
+ config: (0, ts_deepmerge_1.merge)(this.options?.defaultConfig ?? {}, this.options?.authServiceConfig ?? {}),
52
+ });
53
+ /***************************************************************************
54
+ *
55
+ * Rest API service
56
+ *
57
+ * This contains the REST API for the OpenHi platform.
58
+ *
59
+ **************************************************************************/
60
+ this.restApi = new service_1.OpenHiService(this, "rest-api", {
61
+ type: service_1.OPEN_HI_SERVICE_TYPE.REST_API,
62
+ config: (0, ts_deepmerge_1.merge)(this.options?.defaultConfig ?? {}, this.options?.restApiServiceConfig ?? {}),
63
+ });
64
+ /***************************************************************************
65
+ *
66
+ * Core Service
67
+ *
68
+ * This contains resources that are common across multiple enterprise use
69
+ * cases.
70
+ *
71
+ **************************************************************************/
72
+ this.core = new service_1.OpenHiService(this, "core", {
73
+ type: service_1.OPEN_HI_SERVICE_TYPE.CORE,
74
+ config: (0, ts_deepmerge_1.merge)(this.options?.defaultConfig ?? {}, this.options?.coreServiceConfig ?? {}),
75
+ });
76
+ /***************************************************************************
77
+ *
78
+ * Data Service
79
+ *
80
+ * Data storage stack (DynamoDB FHIR store, S3, etc.). Deployed so that
81
+ * REST API and other services can reference the table via cross-stack.
82
+ *
83
+ **************************************************************************/
84
+ this.data = new service_1.OpenHiService(this, "data", {
85
+ type: service_1.OPEN_HI_SERVICE_TYPE.DATA_SERVICE,
86
+ config: (0, ts_deepmerge_1.merge)(this.options?.defaultConfig ?? {}, this.options?.dataServiceConfig ?? {}),
87
+ });
88
+ /***************************************************************************
89
+ *
90
+ * Integrations
91
+ *
92
+ * Various purpose specific integrations.
93
+ *
94
+ **************************************************************************/
95
+ /***************************************************************************
96
+ *
97
+ * Workflows
98
+ *
99
+ * Workflows for each environment.
100
+ *
101
+ **************************************************************************/
102
+ new build_dev_workflow_1.BuildDevelopmentWorkflow(rootProject, { openhi: this });
103
+ new build_stage_workflow_1.BuildStageWorkflow(rootProject, { openhi: this });
104
+ new aws_teardown_workflow_1.AwsTeardownWorkflow(rootProject, { openhi: this });
105
+ }
106
+ }
107
+ exports.OpenHi = OpenHi;
108
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"openhi.js","sourceRoot":"","sources":["../src/openhi.ts"],"names":[],"mappings":";;;AAKA,+CAAqC;AAErC,uCAAgE;AAChE,6EAAwE;AACxE,uEAA0E;AAC1E,2EAAsE;AA4DtE,MAAa,MAAM;IA0CjB,YAAY,UAAyB,EAAE;QACrC;;;;;;oFAM4E;QAE5E,IAAI,CAAC,OAAO,GAAG,IAAA,oBAAK,EAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,OAAO,CAAC,CAAC;QAClD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC;QAC5C,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,IAAI,QAAQ,CAAC;QAErD;;;WAGG;QACH,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,MAAM,IAAI,KAAK,CACb,8EAA8E,CAC/E,CAAC;QACJ,CAAC;QAED,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;QAErC;;;;;;;oFAO4E;QAE5E,IAAI,CAAC,MAAM,GAAG,IAAI,uBAAa,CAAC,IAAI,EAAE,QAAQ,EAAE;YAC9C,IAAI,EAAE,8BAAoB,CAAC,MAAM;YACjC,MAAM,EAAE,IAAA,oBAAK,EACX,IAAI,CAAC,OAAO,EAAE,aAAa,IAAI,EAAE,EACjC,IAAI,CAAC,OAAO,EAAE,mBAAmB,IAAI,EAAE,CACxC;SACF,CAAC,CAAC;QAEH;;;;;;;oFAO4E;QAE5E,IAAI,CAAC,IAAI,GAAG,IAAI,uBAAa,CAAC,IAAI,EAAE,MAAM,EAAE;YAC1C,IAAI,EAAE,8BAAoB,CAAC,IAAI;YAC/B,MAAM,EAAE,IAAA,oBAAK,EACX,IAAI,CAAC,OAAO,EAAE,aAAa,IAAI,EAAE,EACjC,IAAI,CAAC,OAAO,EAAE,iBAAiB,IAAI,EAAE,CACtC;SACF,CAAC,CAAC;QAEH;;;;;;oFAM4E;QAE5E,IAAI,CAAC,OAAO,GAAG,IAAI,uBAAa,CAAC,IAAI,EAAE,UAAU,EAAE;YACjD,IAAI,EAAE,8BAAoB,CAAC,QAAQ;YACnC,MAAM,EAAE,IAAA,oBAAK,EACX,IAAI,CAAC,OAAO,EAAE,aAAa,IAAI,EAAE,EACjC,IAAI,CAAC,OAAO,EAAE,oBAAoB,IAAI,EAAE,CACzC;SACF,CAAC,CAAC;QAEH;;;;;;;oFAO4E;QAE5E,IAAI,CAAC,IAAI,GAAG,IAAI,uBAAa,CAAC,IAAI,EAAE,MAAM,EAAE;YAC1C,IAAI,EAAE,8BAAoB,CAAC,IAAI;YAC/B,MAAM,EAAE,IAAA,oBAAK,EACX,IAAI,CAAC,OAAO,EAAE,aAAa,IAAI,EAAE,EACjC,IAAI,CAAC,OAAO,EAAE,iBAAiB,IAAI,EAAE,CACtC;SACF,CAAC,CAAC;QAEH;;;;;;;oFAO4E;QAE5E,IAAI,CAAC,IAAI,GAAG,IAAI,uBAAa,CAAC,IAAI,EAAE,MAAM,EAAE;YAC1C,IAAI,EAAE,8BAAoB,CAAC,YAAY;YACvC,MAAM,EAAE,IAAA,oBAAK,EACX,IAAI,CAAC,OAAO,EAAE,aAAa,IAAI,EAAE,EACjC,IAAI,CAAC,OAAO,EAAE,iBAAiB,IAAI,EAAE,CACtC;SACF,CAAC,CAAC;QAEH;;;;;;oFAM4E;QAE5E;;;;;;oFAM4E;QAE5E,IAAI,6CAAwB,CAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;QAC5D,IAAI,yCAAkB,CAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;QAEtD,IAAI,2CAAmB,CAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;IACzD,CAAC;CACF;AA5KD,wBA4KC","sourcesContent":["import {\n  MonorepoProject,\n  MonorepoProjectOptions,\n} from \"@codedrifters/configulator\";\nimport { OpenHiConfig } from \"@openhi/config\";\nimport { merge } from \"ts-deepmerge\";\nimport { SetOptional } from \"type-fest\";\nimport { OPEN_HI_SERVICE_TYPE, OpenHiService } from \"./service\";\nimport { AwsTeardownWorkflow } from \"./workflows/aws-teardown-workflow\";\nimport { BuildDevelopmentWorkflow } from \"./workflows/build-dev-workflow\";\nimport { BuildStageWorkflow } from \"./workflows/build-stage-workflow\";\n\nexport interface OpenHiOptions {\n  /*****************************************************************************\n   *\n   * Root Project Configuration Options\n   *\n   * Configuration options for the root monorepo project that contains all\n   * OpenHi services and coordinate releases and builds.\n   *\n   ****************************************************************************/\n\n  readonly rootProjectOptions?: SetOptional<MonorepoProjectOptions, \"name\">;\n\n  /**\n   * Monorepo root project, if using an existing project.\n   */\n  readonly rootProject?: MonorepoProject;\n\n  /*****************************************************************************\n   *\n   * Service Configuration Options\n   *\n   * These options are used to configure the various services within the OpenHi\n   * framework. Each service can have its own configuration settings, which will\n   * be merged with the default configuration.\n   *\n   ****************************************************************************/\n\n  /**\n   * Default configuration used in all services with undefined configs.\n   */\n  readonly defaultConfig?: OpenHiConfig;\n\n  /**\n   * Global Service Config\n   */\n  readonly globalServiceConfig?: OpenHiConfig;\n\n  /**\n   * Auth Service Config\n   */\n  readonly authServiceConfig?: OpenHiConfig;\n\n  /**\n   * Rest API Service Config\n   */\n  readonly restApiServiceConfig?: OpenHiConfig;\n\n  /**\n   * Core Service Config\n   */\n  readonly coreServiceConfig?: OpenHiConfig;\n\n  /**\n   * Data Service Config (DynamoDB FHIR store, S3, etc.)\n   */\n  readonly dataServiceConfig?: OpenHiConfig;\n}\n\nexport class OpenHi {\n  /**\n   * Final options used to build this instance.\n   */\n  public options: OpenHiOptions;\n\n  /**\n   * Monorepo root project, either passed in as an argument or generated in\n   * this component\n   */\n  public readonly rootProject?: MonorepoProject;\n\n  /**\n   * Test identifier for this instance.\n   */\n  public readonly id: string;\n\n  /**\n   * Global service (deployed first; Core and data services depend on it).\n   */\n  public readonly global: OpenHiService;\n\n  /**\n   * Auth service (deployed before Core; Core and data services depend on it).\n   */\n  public readonly auth: OpenHiService;\n\n  /**\n   * Rest API service\n   */\n  public readonly restApi: OpenHiService;\n\n  /**\n   * Core service\n   */\n  public readonly core: OpenHiService;\n\n  /**\n   * Data service (DynamoDB FHIR store, S3, and other persistence).\n   */\n  public readonly data: OpenHiService;\n\n  constructor(options: OpenHiOptions = {}) {\n    /***************************************************************************\n     *\n     * Options\n     *\n     * Combine input options with defaults.\n     *\n     **************************************************************************/\n\n    this.options = merge({ name: \"openhi\" }, options);\n    this.rootProject = this.options.rootProject;\n    this.id = this.options.rootProject?.name ?? \"openhi\";\n\n    /**\n     * In future we would create root project here. For now, require it to be\n     * passed in.\n     */\n    if (!this.rootProject) {\n      throw new Error(\n        \"OpenHi requires a MonorepoProject to be passed in via the rootProject option\",\n      );\n    }\n\n    const rootProject = this.rootProject;\n\n    /***************************************************************************\n     *\n     * Global Service\n     *\n     * Authentication (Cognito user pool, client, domain, KMS). Deployed before\n     * Core so that Core can consume auth via SSM parameters.\n     *\n     **************************************************************************/\n\n    this.global = new OpenHiService(this, \"global\", {\n      type: OPEN_HI_SERVICE_TYPE.GLOBAL,\n      config: merge(\n        this.options?.defaultConfig ?? {},\n        this.options?.globalServiceConfig ?? {},\n      ),\n    });\n\n    /***************************************************************************\n     *\n     * Auth Service\n     *\n     * Authentication (Cognito user pool, client, domain, KMS). Deployed before\n     * Core so that Core can consume auth via SSM parameters.\n     *\n     **************************************************************************/\n\n    this.auth = new OpenHiService(this, \"auth\", {\n      type: OPEN_HI_SERVICE_TYPE.AUTH,\n      config: merge(\n        this.options?.defaultConfig ?? {},\n        this.options?.authServiceConfig ?? {},\n      ),\n    });\n\n    /***************************************************************************\n     *\n     * Rest API service\n     *\n     * This contains the REST API for the OpenHi platform.\n     *\n     **************************************************************************/\n\n    this.restApi = new OpenHiService(this, \"rest-api\", {\n      type: OPEN_HI_SERVICE_TYPE.REST_API,\n      config: merge(\n        this.options?.defaultConfig ?? {},\n        this.options?.restApiServiceConfig ?? {},\n      ),\n    });\n\n    /***************************************************************************\n     *\n     * Core Service\n     *\n     * This contains resources that are common across multiple enterprise use\n     * cases.\n     *\n     **************************************************************************/\n\n    this.core = new OpenHiService(this, \"core\", {\n      type: OPEN_HI_SERVICE_TYPE.CORE,\n      config: merge(\n        this.options?.defaultConfig ?? {},\n        this.options?.coreServiceConfig ?? {},\n      ),\n    });\n\n    /***************************************************************************\n     *\n     * Data Service\n     *\n     * Data storage stack (DynamoDB FHIR store, S3, etc.). Deployed so that\n     * REST API and other services can reference the table via cross-stack.\n     *\n     **************************************************************************/\n\n    this.data = new OpenHiService(this, \"data\", {\n      type: OPEN_HI_SERVICE_TYPE.DATA_SERVICE,\n      config: merge(\n        this.options?.defaultConfig ?? {},\n        this.options?.dataServiceConfig ?? {},\n      ),\n    });\n\n    /***************************************************************************\n     *\n     * Integrations\n     *\n     * Various purpose specific integrations.\n     *\n     **************************************************************************/\n\n    /***************************************************************************\n     *\n     * Workflows\n     *\n     * Workflows for each environment.\n     *\n     **************************************************************************/\n\n    new BuildDevelopmentWorkflow(rootProject, { openhi: this });\n    new BuildStageWorkflow(rootProject, { openhi: this });\n\n    new AwsTeardownWorkflow(rootProject, { openhi: this });\n  }\n}\n"]}
@@ -0,0 +1,36 @@
1
+ import { OpenHiConfig } from "@openhi/config";
2
+ import { awscdk } from "projen";
3
+ import { ValueOf } from "type-fest";
4
+ import { OpenHi } from "./openhi";
5
+ export declare const OPEN_HI_SERVICE_TYPE: {
6
+ readonly AUTH: "auth";
7
+ readonly CORE: "core";
8
+ readonly DATA_SERVICE: "data";
9
+ readonly GLOBAL: "global";
10
+ readonly INTEGRATION: "integration";
11
+ readonly REST_API: "rest-api";
12
+ };
13
+ export interface OpenHiServiceOptions {
14
+ /**
15
+ * Configuration for this service.
16
+ *
17
+ * @default uses the global default config.
18
+ */
19
+ readonly config: OpenHiConfig;
20
+ /**
21
+ * What type of service is this?
22
+ */
23
+ readonly type: ValueOf<typeof OPEN_HI_SERVICE_TYPE>;
24
+ }
25
+ export declare class OpenHiService {
26
+ openHi: OpenHi;
27
+ id: string;
28
+ options: OpenHiServiceOptions;
29
+ readonly project: awscdk.AwsCdkTypeScriptApp;
30
+ constructor(openHi: OpenHi, id: string, options: OpenHiServiceOptions);
31
+ private addDeploymentTarget;
32
+ get constructName(): string;
33
+ get outDir(): string;
34
+ get serviceName(): string;
35
+ get typeDir(): Array<string>;
36
+ }
package/lib/service.js ADDED
@@ -0,0 +1,203 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.OpenHiService = exports.OPEN_HI_SERVICE_TYPE = void 0;
4
+ const path_1 = require("path");
5
+ const configulator_1 = require("@codedrifters/configulator");
6
+ const config_1 = require("@openhi/config");
7
+ const change_case_1 = require("change-case");
8
+ const projen_1 = require("projen");
9
+ const javascript_1 = require("projen/lib/javascript");
10
+ const generate_templates_1 = require("./templates/generate-templates");
11
+ exports.OPEN_HI_SERVICE_TYPE = {
12
+ AUTH: "auth",
13
+ CORE: "core",
14
+ DATA_SERVICE: "data",
15
+ GLOBAL: "global",
16
+ INTEGRATION: "integration",
17
+ REST_API: "rest-api",
18
+ };
19
+ class OpenHiService {
20
+ constructor(openHi, id, options) {
21
+ /**
22
+ * Build the construct name we expect to use in this service.
23
+ */
24
+ this.openHi = openHi;
25
+ this.id = id;
26
+ this.options = options;
27
+ this.addDeploymentTarget = (awsStageType, awsEnvironmentType, envConfig) => {
28
+ new configulator_1.AwsDeploymentTarget(this.project, {
29
+ account: envConfig.account,
30
+ region: envConfig.region,
31
+ awsStageType,
32
+ awsEnvironmentType,
33
+ localDeployment: true,
34
+ localDeploymentConfig: {
35
+ stackPattern: `${awsStageType}/${awsEnvironmentType}/*-${envConfig.account}-${envConfig.region}`,
36
+ roleName: "poweruseraccess",
37
+ },
38
+ ciDeployment: true,
39
+ ciDeploymentConfig: {
40
+ roleArn: `arn:aws:iam::${envConfig.account}:role/GitHubOpenHiDeployer`,
41
+ stackPattern: `${awsStageType}/${awsEnvironmentType}/*-${envConfig.account}-${envConfig.region}`,
42
+ },
43
+ branches: awsStageType === config_1.OPEN_HI_STAGE.DEV
44
+ ? [
45
+ {
46
+ branch: "feat/*",
47
+ description: [
48
+ "Feature branches for OpenHI (short form).",
49
+ "These branches are used for developing new features.",
50
+ ],
51
+ },
52
+ {
53
+ branch: "feature/*",
54
+ description: [
55
+ "Feature branches for OpenHI.",
56
+ "These branches are used for developing new features.",
57
+ ],
58
+ },
59
+ {
60
+ branch: "fix/*",
61
+ description: [
62
+ "Fix branches for OpenHI.",
63
+ "This branch pattern is used when a developer is working on a fix on the project.",
64
+ ],
65
+ },
66
+ ]
67
+ : [
68
+ {
69
+ branch: "main",
70
+ description: [
71
+ "Main branch for OpenHI.",
72
+ "This branch is used for the main branch.",
73
+ ],
74
+ },
75
+ ],
76
+ });
77
+ };
78
+ /***************************************************************************
79
+ *
80
+ * Projen based CDK build
81
+ *
82
+ **************************************************************************/
83
+ this.project = new projen_1.awscdk.AwsCdkTypeScriptApp({
84
+ /**
85
+ * Top level project config options
86
+ */
87
+ defaultReleaseBranch: "main",
88
+ name: this.serviceName,
89
+ outdir: this.outDir,
90
+ parent: this.openHi.rootProject,
91
+ cdkVersion: this.options?.config?.versions?.cdk?.cdkLibVersion ??
92
+ configulator_1.VERSION.AWS_CDK_LIB_VERSION,
93
+ cdkCliVersion: this.options?.config?.versions?.cdk?.cdkCliVersion ??
94
+ configulator_1.VERSION.AWS_CDK_CLI_VERSION,
95
+ /**
96
+ * Packaging options
97
+ *
98
+ * TODO: Figure out license for monorepo vs per package?
99
+ */
100
+ licensed: false,
101
+ /**
102
+ * Node configs
103
+ */
104
+ packageManager: javascript_1.NodePackageManager.PNPM,
105
+ /**
106
+ * Turn on prettier formatting
107
+ */
108
+ prettier: true,
109
+ /**
110
+ * Don't generate sample code.
111
+ */
112
+ sampleCode: false,
113
+ /**
114
+ * Make sure jest config is stored outside of package.json and use SWC
115
+ * for faster tests.
116
+ */
117
+ jestOptions: {
118
+ configFilePath: "jest.config.json",
119
+ jestConfig: {
120
+ transform: {
121
+ ["^.+\\.[t]sx?$"]: new javascript_1.Transform("@swc/jest"),
122
+ },
123
+ },
124
+ },
125
+ /**
126
+ * SWC for faster testing
127
+ */
128
+ devDeps: ["@swc/jest", "@swc/core"],
129
+ /**
130
+ * Don't package test files.
131
+ */
132
+ npmIgnoreOptions: {
133
+ ignorePatterns: ["*.spec.*", "*.test.*"],
134
+ },
135
+ });
136
+ /**
137
+ * We're using SWC now, remove ts-jest which is included by default.
138
+ */
139
+ this.project.deps.removeDependency("ts-jest");
140
+ /***************************************************************************
141
+ *
142
+ * Workspace Dependencies
143
+ *
144
+ * - Constructs are used to build out the AWS CDK environments.
145
+ *
146
+ **************************************************************************/
147
+ this.project.addDeps("@openhi/config@workspace:*", "@openhi/constructs@workspace:*");
148
+ /***************************************************************************
149
+ *
150
+ * Turbo Configuration
151
+ *
152
+ * - Activate turborepo for the project.
153
+ *
154
+ **************************************************************************/
155
+ new configulator_1.TurboRepo(this.project);
156
+ /***************************************************************************
157
+ *
158
+ * Define some basic Service Structure
159
+ *
160
+ **************************************************************************/
161
+ new generate_templates_1.GenerateTemplates(this);
162
+ /***************************************************************************
163
+ *
164
+ * Deployment Targets
165
+ *
166
+ **************************************************************************/
167
+ [config_1.OPEN_HI_STAGE.DEV, config_1.OPEN_HI_STAGE.STAGE, config_1.OPEN_HI_STAGE.PROD].forEach((stage) => {
168
+ const targets = this.options?.config?.deploymentTargets?.[stage];
169
+ if (targets?.primary) {
170
+ this.addDeploymentTarget(stage, config_1.OPEN_HI_DEPLOYMENT_TARGET_ROLE.PRIMARY, targets.primary);
171
+ }
172
+ targets?.secondary?.forEach((env) => {
173
+ this.addDeploymentTarget(stage, config_1.OPEN_HI_DEPLOYMENT_TARGET_ROLE.SECONDARY, env);
174
+ });
175
+ });
176
+ }
177
+ get constructName() {
178
+ return (0, change_case_1.pascalCase)(["open", "hi", this.id, "service"].join("-"));
179
+ }
180
+ get outDir() {
181
+ return [
182
+ (0, change_case_1.paramCase)(this.openHi.id),
183
+ ...this.typeDir.map((x) => (0, change_case_1.paramCase)(x)),
184
+ (0, change_case_1.paramCase)(this.id),
185
+ ].join(path_1.sep);
186
+ }
187
+ get serviceName() {
188
+ return [(0, change_case_1.paramCase)(this.openHi.id), (0, change_case_1.paramCase)(this.id)].join("-");
189
+ }
190
+ get typeDir() {
191
+ return [];
192
+ /*
193
+ return this.options.type === OPEN_HI_SERVICE_TYPE.AUTH ||
194
+ this.options.type === OPEN_HI_SERVICE_TYPE.CORE ||
195
+ this.options.type === OPEN_HI_SERVICE_TYPE.GLOBAL
196
+ ? []
197
+ : this.options.type === OPEN_HI_SERVICE_TYPE.DATA_SERVICE
198
+ ? ["data"]
199
+ : ["integration"];*/
200
+ }
201
+ }
202
+ exports.OpenHiService = OpenHiService;
203
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"service.js","sourceRoot":"","sources":["../src/service.ts"],"names":[],"mappings":"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","sourcesContent":["import { sep } from \"path\";\nimport {\n  AwsDeploymentTarget,\n  TurboRepo,\n  VERSION,\n} from \"@codedrifters/configulator\";\nimport {\n  OPEN_HI_DEPLOYMENT_TARGET_ROLE,\n  OPEN_HI_STAGE,\n  OpenHiConfig,\n  OpenHiEnvironmentConfig,\n} from \"@openhi/config\";\nimport { paramCase, pascalCase } from \"change-case\";\nimport { awscdk } from \"projen\";\nimport { NodePackageManager, Transform } from \"projen/lib/javascript\";\nimport { ValueOf } from \"type-fest\";\nimport { OpenHi } from \"./openhi\";\nimport { GenerateTemplates } from \"./templates/generate-templates\";\n\nexport const OPEN_HI_SERVICE_TYPE = {\n  AUTH: \"auth\",\n  CORE: \"core\",\n  DATA_SERVICE: \"data\",\n  GLOBAL: \"global\",\n  INTEGRATION: \"integration\",\n  REST_API: \"rest-api\",\n} as const;\n\nexport interface OpenHiServiceOptions {\n  /**\n   * Configuration for this service.\n   *\n   * @default uses the global default config.\n   */\n  readonly config: OpenHiConfig;\n\n  /**\n   * What type of service is this?\n   */\n  readonly type: ValueOf<typeof OPEN_HI_SERVICE_TYPE>;\n}\n\nexport class OpenHiService {\n  public readonly project: awscdk.AwsCdkTypeScriptApp;\n\n  constructor(\n    public openHi: OpenHi,\n    public id: string,\n    public options: OpenHiServiceOptions,\n  ) {\n    /**\n     * Build the construct name we expect to use in this service.\n     */\n\n    /***************************************************************************\n     *\n     * Projen based CDK build\n     *\n     **************************************************************************/\n\n    this.project = new awscdk.AwsCdkTypeScriptApp({\n      /**\n       * Top level project config options\n       */\n      defaultReleaseBranch: \"main\",\n      name: this.serviceName,\n      outdir: this.outDir,\n      parent: this.openHi.rootProject,\n      cdkVersion:\n        this.options?.config?.versions?.cdk?.cdkLibVersion ??\n        VERSION.AWS_CDK_LIB_VERSION,\n      cdkCliVersion:\n        this.options?.config?.versions?.cdk?.cdkCliVersion ??\n        VERSION.AWS_CDK_CLI_VERSION,\n\n      /**\n       * Packaging options\n       *\n       * TODO: Figure out license for monorepo vs per package?\n       */\n      licensed: false,\n\n      /**\n       * Node configs\n       */\n      packageManager: NodePackageManager.PNPM,\n\n      /**\n       * Turn on prettier formatting\n       */\n      prettier: true,\n\n      /**\n       * Don't generate sample code.\n       */\n      sampleCode: false,\n\n      /**\n       * Make sure jest config is stored outside of package.json and use SWC\n       * for faster tests.\n       */\n      jestOptions: {\n        configFilePath: \"jest.config.json\",\n        jestConfig: {\n          transform: {\n            [\"^.+\\\\.[t]sx?$\"]: new Transform(\"@swc/jest\"),\n          },\n        },\n      },\n\n      /**\n       * SWC for faster testing\n       */\n      devDeps: [\"@swc/jest\", \"@swc/core\"],\n\n      /**\n       * Don't package test files.\n       */\n      npmIgnoreOptions: {\n        ignorePatterns: [\"*.spec.*\", \"*.test.*\"],\n      },\n    });\n\n    /**\n     * We're using SWC now, remove ts-jest which is included by default.\n     */\n    this.project.deps.removeDependency(\"ts-jest\");\n\n    /***************************************************************************\n     *\n     * Workspace Dependencies\n     *\n     * - Constructs are used to build out the AWS CDK environments.\n     *\n     **************************************************************************/\n\n    this.project.addDeps(\n      \"@openhi/config@workspace:*\",\n      \"@openhi/constructs@workspace:*\",\n    );\n\n    /***************************************************************************\n     *\n     * Turbo Configuration\n     *\n     * - Activate turborepo for the project.\n     *\n     **************************************************************************/\n\n    new TurboRepo(this.project);\n\n    /***************************************************************************\n     *\n     * Define some basic Service Structure\n     *\n     **************************************************************************/\n\n    new GenerateTemplates(this);\n\n    /***************************************************************************\n     *\n     * Deployment Targets\n     *\n     **************************************************************************/\n\n    [OPEN_HI_STAGE.DEV, OPEN_HI_STAGE.STAGE, OPEN_HI_STAGE.PROD].forEach(\n      (stage) => {\n        const targets = this.options?.config?.deploymentTargets?.[stage];\n        if (targets?.primary) {\n          this.addDeploymentTarget(\n            stage,\n            OPEN_HI_DEPLOYMENT_TARGET_ROLE.PRIMARY,\n            targets.primary,\n          );\n        }\n        targets?.secondary?.forEach((env) => {\n          this.addDeploymentTarget(\n            stage,\n            OPEN_HI_DEPLOYMENT_TARGET_ROLE.SECONDARY,\n            env,\n          );\n        });\n      },\n    );\n  }\n\n  private addDeploymentTarget = (\n    awsStageType: ValueOf<typeof OPEN_HI_STAGE>,\n    awsEnvironmentType: ValueOf<typeof OPEN_HI_DEPLOYMENT_TARGET_ROLE>,\n    envConfig: OpenHiEnvironmentConfig,\n  ) => {\n    new AwsDeploymentTarget(this.project, {\n      account: envConfig.account,\n      region: envConfig.region,\n      awsStageType,\n      awsEnvironmentType,\n      localDeployment: true,\n      localDeploymentConfig: {\n        stackPattern: `${awsStageType}/${awsEnvironmentType}/*-${envConfig.account}-${envConfig.region}`,\n        roleName: \"poweruseraccess\",\n      },\n      ciDeployment: true,\n      ciDeploymentConfig: {\n        roleArn: `arn:aws:iam::${envConfig.account}:role/GitHubOpenHiDeployer`,\n        stackPattern: `${awsStageType}/${awsEnvironmentType}/*-${envConfig.account}-${envConfig.region}`,\n      },\n\n      branches:\n        awsStageType === OPEN_HI_STAGE.DEV\n          ? [\n              {\n                branch: \"feat/*\",\n                description: [\n                  \"Feature branches for OpenHI (short form).\",\n                  \"These branches are used for developing new features.\",\n                ],\n              },\n              {\n                branch: \"feature/*\",\n                description: [\n                  \"Feature branches for OpenHI.\",\n                  \"These branches are used for developing new features.\",\n                ],\n              },\n              {\n                branch: \"fix/*\",\n                description: [\n                  \"Fix branches for OpenHI.\",\n                  \"This branch pattern is used when a developer is working on a fix on the project.\",\n                ],\n              },\n            ]\n          : [\n              {\n                branch: \"main\",\n                description: [\n                  \"Main branch for OpenHI.\",\n                  \"This branch is used for the main branch.\",\n                ],\n              },\n            ],\n    });\n  };\n\n  get constructName(): string {\n    return pascalCase([\"open\", \"hi\", this.id, \"service\"].join(\"-\"));\n  }\n\n  get outDir() {\n    return [\n      paramCase(this.openHi.id),\n      ...this.typeDir.map((x) => paramCase(x)),\n      paramCase(this.id),\n    ].join(sep);\n  }\n\n  get serviceName() {\n    return [paramCase(this.openHi.id), paramCase(this.id)].join(\"-\");\n  }\n\n  get typeDir(): Array<string> {\n    return [];\n    /*\n    return this.options.type === OPEN_HI_SERVICE_TYPE.AUTH ||\n      this.options.type === OPEN_HI_SERVICE_TYPE.CORE ||\n      this.options.type === OPEN_HI_SERVICE_TYPE.GLOBAL\n      ? []\n      : this.options.type === OPEN_HI_SERVICE_TYPE.DATA_SERVICE\n        ? [\"data\"]\n        : [\"integration\"];*/\n  }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ import { OpenHiService } from "../service";
2
+ export declare class GenerateTemplates {
3
+ private service;
4
+ constructor(service: OpenHiService);
5
+ }
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.GenerateTemplates = void 0;
4
+ const app_1 = require("./src/app");
5
+ const app_test_1 = require("./src/app-test");
6
+ const config_1 = require("./src/config");
7
+ const README_md_1 = require("./src/data/models/README.md");
8
+ const README_md_2 = require("./src/data/README.md");
9
+ const README_md_3 = require("./src/infrastructure/README.md");
10
+ const README_md_4 = require("./src/integrations/README.md");
11
+ const main_1 = require("./src/main");
12
+ const README_md_5 = require("./src/README.md");
13
+ const README_md_6 = require("./src/workflows/README.md");
14
+ class GenerateTemplates {
15
+ constructor(service) {
16
+ this.service = service;
17
+ /**
18
+ * Root src templates
19
+ */
20
+ new app_1.SrcApp(this.service);
21
+ new app_test_1.SrcAppTest(this.service);
22
+ new config_1.SrcConfig(this.service);
23
+ new main_1.SrcMain(this.service);
24
+ new README_md_5.SrcReadMe(this.service);
25
+ /**
26
+ * Data
27
+ */
28
+ new README_md_2.DataReadMe(this.service);
29
+ new README_md_1.DataModelsReadMe(this.service);
30
+ /**
31
+ * Infrastructure
32
+ */
33
+ new README_md_3.InfrastructureReadMe(this.service);
34
+ /**
35
+ * Integrations
36
+ */
37
+ new README_md_4.IntegrationsReadMe(this.service);
38
+ /**
39
+ * Workflows
40
+ */
41
+ new README_md_6.WorkflowsReadMe(this.service);
42
+ }
43
+ }
44
+ exports.GenerateTemplates = GenerateTemplates;
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJhdGUtdGVtcGxhdGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3RlbXBsYXRlcy9nZW5lcmF0ZS10ZW1wbGF0ZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQ0EsbUNBQW1DO0FBQ25DLDZDQUE0QztBQUM1Qyx5Q0FBeUM7QUFDekMsMkRBQStEO0FBQy9ELG9EQUFrRDtBQUNsRCw4REFBc0U7QUFDdEUsNERBQWtFO0FBQ2xFLHFDQUFxQztBQUNyQywrQ0FBNEM7QUFDNUMseURBQTREO0FBRTVELE1BQWEsaUJBQWlCO0lBQzVCLFlBQW9CLE9BQXNCO1FBQXRCLFlBQU8sR0FBUCxPQUFPLENBQWU7UUFDeEM7O1dBRUc7UUFDSCxJQUFJLFlBQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDekIsSUFBSSxxQkFBVSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUM3QixJQUFJLGtCQUFTLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzVCLElBQUksY0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUMxQixJQUFJLHFCQUFTLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRTVCOztXQUVHO1FBQ0gsSUFBSSxzQkFBVSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUM3QixJQUFJLDRCQUFnQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVuQzs7V0FFRztRQUNILElBQUksZ0NBQW9CLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBRXZDOztXQUVHO1FBQ0gsSUFBSSw4QkFBa0IsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7UUFFckM7O1dBRUc7UUFDSCxJQUFJLDJCQUFlLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3BDLENBQUM7Q0FDRjtBQWhDRCw4Q0FnQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPcGVuSGlTZXJ2aWNlIH0gZnJvbSBcIi4uL3NlcnZpY2VcIjtcbmltcG9ydCB7IFNyY0FwcCB9IGZyb20gXCIuL3NyYy9hcHBcIjtcbmltcG9ydCB7IFNyY0FwcFRlc3QgfSBmcm9tIFwiLi9zcmMvYXBwLXRlc3RcIjtcbmltcG9ydCB7IFNyY0NvbmZpZyB9IGZyb20gXCIuL3NyYy9jb25maWdcIjtcbmltcG9ydCB7IERhdGFNb2RlbHNSZWFkTWUgfSBmcm9tIFwiLi9zcmMvZGF0YS9tb2RlbHMvUkVBRE1FLm1kXCI7XG5pbXBvcnQgeyBEYXRhUmVhZE1lIH0gZnJvbSBcIi4vc3JjL2RhdGEvUkVBRE1FLm1kXCI7XG5pbXBvcnQgeyBJbmZyYXN0cnVjdHVyZVJlYWRNZSB9IGZyb20gXCIuL3NyYy9pbmZyYXN0cnVjdHVyZS9SRUFETUUubWRcIjtcbmltcG9ydCB7IEludGVncmF0aW9uc1JlYWRNZSB9IGZyb20gXCIuL3NyYy9pbnRlZ3JhdGlvbnMvUkVBRE1FLm1kXCI7XG5pbXBvcnQgeyBTcmNNYWluIH0gZnJvbSBcIi4vc3JjL21haW5cIjtcbmltcG9ydCB7IFNyY1JlYWRNZSB9IGZyb20gXCIuL3NyYy9SRUFETUUubWRcIjtcbmltcG9ydCB7IFdvcmtmbG93c1JlYWRNZSB9IGZyb20gXCIuL3NyYy93b3JrZmxvd3MvUkVBRE1FLm1kXCI7XG5cbmV4cG9ydCBjbGFzcyBHZW5lcmF0ZVRlbXBsYXRlcyB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc2VydmljZTogT3BlbkhpU2VydmljZSkge1xuICAgIC8qKlxuICAgICAqIFJvb3Qgc3JjIHRlbXBsYXRlc1xuICAgICAqL1xuICAgIG5ldyBTcmNBcHAodGhpcy5zZXJ2aWNlKTtcbiAgICBuZXcgU3JjQXBwVGVzdCh0aGlzLnNlcnZpY2UpO1xuICAgIG5ldyBTcmNDb25maWcodGhpcy5zZXJ2aWNlKTtcbiAgICBuZXcgU3JjTWFpbih0aGlzLnNlcnZpY2UpO1xuICAgIG5ldyBTcmNSZWFkTWUodGhpcy5zZXJ2aWNlKTtcblxuICAgIC8qKlxuICAgICAqIERhdGFcbiAgICAgKi9cbiAgICBuZXcgRGF0YVJlYWRNZSh0aGlzLnNlcnZpY2UpO1xuICAgIG5ldyBEYXRhTW9kZWxzUmVhZE1lKHRoaXMuc2VydmljZSk7XG5cbiAgICAvKipcbiAgICAgKiBJbmZyYXN0cnVjdHVyZVxuICAgICAqL1xuICAgIG5ldyBJbmZyYXN0cnVjdHVyZVJlYWRNZSh0aGlzLnNlcnZpY2UpO1xuXG4gICAgLyoqXG4gICAgICogSW50ZWdyYXRpb25zXG4gICAgICovXG4gICAgbmV3IEludGVncmF0aW9uc1JlYWRNZSh0aGlzLnNlcnZpY2UpO1xuXG4gICAgLyoqXG4gICAgICogV29ya2Zsb3dzXG4gICAgICovXG4gICAgbmV3IFdvcmtmbG93c1JlYWRNZSh0aGlzLnNlcnZpY2UpO1xuICB9XG59XG4iXX0=
@@ -0,0 +1,33 @@
1
+ import { SampleFile } from "projen";
2
+ import { OpenHiService } from "../service";
3
+ export interface ServiceTemplateOptions {
4
+ /**
5
+ * The content of the sample file, as an array.
6
+ */
7
+ readonly contents: Array<string>;
8
+ /**
9
+ * The relative file path from the project root.
10
+ */
11
+ readonly filePath: string;
12
+ /**
13
+ * Overwrite this template file to it's original state?
14
+ *
15
+ * @default false
16
+ */
17
+ readonly overwrite?: boolean;
18
+ }
19
+ export declare class ServiceTemplate {
20
+ service: OpenHiService;
21
+ options: ServiceTemplateOptions;
22
+ /**
23
+ * The file being generated.
24
+ */
25
+ file?: SampleFile;
26
+ /**
27
+ * Absolute Filepath, including the project path.
28
+ */
29
+ fullFilePath: string;
30
+ constructor(service: OpenHiService, options: ServiceTemplateOptions);
31
+ protected createTemplate(): void;
32
+ overwriteTemplate(): void;
33
+ }