@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.
- package/README.md +3 -0
- package/lib/index.d.ts +2 -0
- package/lib/index.js +19 -0
- package/lib/openhi.d.ts +88 -0
- package/lib/openhi.js +108 -0
- package/lib/service.d.ts +36 -0
- package/lib/service.js +203 -0
- package/lib/templates/generate-templates.d.ts +5 -0
- package/lib/templates/generate-templates.js +45 -0
- package/lib/templates/service-template.d.ts +33 -0
- package/lib/templates/service-template.js +42 -0
- package/lib/templates/src/README.md.d.ts +5 -0
- package/lib/templates/src/README.md.js +19 -0
- package/lib/templates/src/app-test.d.ts +5 -0
- package/lib/templates/src/app-test.js +61 -0
- package/lib/templates/src/app.d.ts +5 -0
- package/lib/templates/src/app.js +27 -0
- package/lib/templates/src/config.d.ts +5 -0
- package/lib/templates/src/config.js +23 -0
- package/lib/templates/src/data/README.md.d.ts +5 -0
- package/lib/templates/src/data/README.md.js +19 -0
- package/lib/templates/src/data/models/README.md.d.ts +5 -0
- package/lib/templates/src/data/models/README.md.js +19 -0
- package/lib/templates/src/infrastructure/README.md.d.ts +5 -0
- package/lib/templates/src/infrastructure/README.md.js +19 -0
- package/lib/templates/src/integrations/README.md.d.ts +5 -0
- package/lib/templates/src/integrations/README.md.js +19 -0
- package/lib/templates/src/main.d.ts +5 -0
- package/lib/templates/src/main.js +15 -0
- package/lib/templates/src/workflows/README.md.d.ts +5 -0
- package/lib/templates/src/workflows/README.md.js +19 -0
- package/lib/workflows/aws-teardown-workflow.d.ts +13 -0
- package/lib/workflows/aws-teardown-workflow.js +222 -0
- package/lib/workflows/build-dev-workflow.d.ts +12 -0
- package/lib/workflows/build-dev-workflow.js +48 -0
- package/lib/workflows/build-stage-workflow.d.ts +12 -0
- package/lib/workflows/build-stage-workflow.js +60 -0
- package/package.json +51 -0
package/README.md
ADDED
package/lib/index.d.ts
ADDED
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==
|
package/lib/openhi.d.ts
ADDED
|
@@ -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"]}
|
package/lib/service.d.ts
ADDED
|
@@ -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,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
|
+
}
|