@studion/infra-code-blocks 0.8.0-next.2 → 2.0.0-alpha.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 (183) hide show
  1. package/dist/components/acm-certificate/index.d.ts +20 -0
  2. package/dist/components/acm-certificate/index.d.ts.map +1 -0
  3. package/dist/components/acm-certificate/index.js +40 -0
  4. package/dist/components/cloudfront/index.d.ts +92 -0
  5. package/dist/components/cloudfront/index.d.ts.map +1 -0
  6. package/dist/components/cloudfront/index.js +208 -0
  7. package/dist/components/cloudfront/lb-cache-strategy.d.ts +21 -0
  8. package/dist/components/cloudfront/lb-cache-strategy.d.ts.map +1 -0
  9. package/dist/components/cloudfront/lb-cache-strategy.js +93 -0
  10. package/dist/components/cloudfront/s3-cache-strategy.d.ts +21 -0
  11. package/dist/components/cloudfront/s3-cache-strategy.d.ts.map +1 -0
  12. package/dist/components/cloudfront/s3-cache-strategy.js +78 -0
  13. package/dist/components/cloudfront/types.d.ts +10 -0
  14. package/dist/components/cloudfront/types.d.ts.map +1 -0
  15. package/dist/components/database/builder.d.ts +32 -0
  16. package/dist/components/database/builder.d.ts.map +1 -0
  17. package/dist/components/database/builder.js +82 -0
  18. package/dist/components/database/database-replica.d.ts +35 -0
  19. package/dist/components/database/database-replica.d.ts.map +1 -0
  20. package/dist/components/database/database-replica.js +40 -0
  21. package/dist/components/database/ec2-ssm-connect.d.ts +26 -0
  22. package/dist/components/database/ec2-ssm-connect.d.ts.map +1 -0
  23. package/dist/components/{ec2-ssm-connect.js → database/ec2-ssm-connect.js} +42 -34
  24. package/dist/components/database/index.d.ts +67 -0
  25. package/dist/components/database/index.d.ts.map +1 -0
  26. package/dist/components/database/index.js +144 -0
  27. package/dist/{v2/components → components}/ecs-service/index.d.ts +6 -5
  28. package/dist/components/ecs-service/index.d.ts.map +1 -0
  29. package/dist/{v2/components → components}/ecs-service/index.js +19 -30
  30. package/dist/components/ecs-service/policies.d.ts +3 -0
  31. package/dist/components/ecs-service/policies.d.ts.map +1 -0
  32. package/dist/components/ecs-service/task-size.d.ts +37 -0
  33. package/dist/components/ecs-service/task-size.d.ts.map +1 -0
  34. package/dist/{constants.js → components/ecs-service/task-size.js} +17 -7
  35. package/dist/components/grafana/dashboards/index.d.ts.map +1 -0
  36. package/dist/components/grafana/dashboards/panels.d.ts.map +1 -0
  37. package/dist/components/grafana/dashboards/types.d.ts.map +1 -0
  38. package/dist/components/grafana/dashboards/web-server-slo.d.ts.map +1 -0
  39. package/dist/components/grafana/index.d.ts.map +1 -0
  40. package/dist/components/password/index.d.ts +15 -0
  41. package/dist/components/password/index.d.ts.map +1 -0
  42. package/dist/components/{password.js → password/index.js} +6 -9
  43. package/dist/components/prometheus/index.d.ts.map +1 -0
  44. package/dist/components/prometheus/queries.d.ts.map +1 -0
  45. package/dist/components/prometheus/queries.test.d.ts.map +1 -0
  46. package/dist/components/redis/elasticache-redis.d.ts +38 -0
  47. package/dist/components/redis/elasticache-redis.d.ts.map +1 -0
  48. package/dist/components/redis/elasticache-redis.js +58 -0
  49. package/dist/components/redis/upstash-redis.d.ts +20 -0
  50. package/dist/components/redis/upstash-redis.d.ts.map +1 -0
  51. package/dist/components/redis/upstash-redis.js +29 -0
  52. package/dist/components/static-site/index.d.ts +23 -0
  53. package/dist/components/static-site/index.d.ts.map +1 -0
  54. package/dist/components/static-site/index.js +32 -0
  55. package/dist/components/static-site/s3-assets.d.ts +20 -0
  56. package/dist/components/static-site/s3-assets.d.ts.map +1 -0
  57. package/dist/components/static-site/s3-assets.js +63 -0
  58. package/dist/components/vpc/index.d.ts +20 -0
  59. package/dist/components/vpc/index.d.ts.map +1 -0
  60. package/dist/components/vpc/index.js +31 -0
  61. package/dist/{v2/components → components}/web-server/builder.d.ts +6 -2
  62. package/dist/components/web-server/builder.d.ts.map +1 -0
  63. package/dist/{v2/components → components}/web-server/builder.js +11 -1
  64. package/dist/{v2/components → components}/web-server/index.d.ts +30 -8
  65. package/dist/components/web-server/index.d.ts.map +1 -0
  66. package/dist/{v2/components → components}/web-server/index.js +49 -40
  67. package/dist/{v2/components → components}/web-server/load-balancer.d.ts +4 -3
  68. package/dist/components/web-server/load-balancer.d.ts.map +1 -0
  69. package/dist/{v2/components → components}/web-server/load-balancer.js +17 -14
  70. package/dist/index.d.ts +24 -11
  71. package/dist/index.d.ts.map +1 -1
  72. package/dist/index.js +38 -26
  73. package/dist/otel/batch-processor.d.ts.map +1 -0
  74. package/dist/{v2/otel → otel}/builder.d.ts +15 -2
  75. package/dist/otel/builder.d.ts.map +1 -0
  76. package/dist/{v2/otel → otel}/builder.js +47 -2
  77. package/dist/{v2/otel → otel}/config.d.ts +13 -1
  78. package/dist/otel/config.d.ts.map +1 -0
  79. package/dist/{v2/otel → otel}/config.js +20 -3
  80. package/dist/{v2/otel → otel}/index.d.ts +8 -0
  81. package/dist/otel/index.d.ts.map +1 -0
  82. package/dist/otel/memory-limiter-processor.d.ts.map +1 -0
  83. package/dist/otel/otlp-receiver.d.ts.map +1 -0
  84. package/dist/otel/prometheus-remote-write-exporter.d.ts.map +1 -0
  85. package/dist/shared/common-tags.d.ts +5 -0
  86. package/dist/shared/common-tags.d.ts.map +1 -0
  87. package/dist/shared/common-tags.js +8 -0
  88. package/dist/shared/merge-with-defaults.d.ts +2 -0
  89. package/dist/shared/merge-with-defaults.d.ts.map +1 -0
  90. package/dist/shared/merge-with-defaults.js +7 -0
  91. package/package.json +32 -14
  92. package/dist/components/acm-certificate.d.ts +0 -11
  93. package/dist/components/acm-certificate.d.ts.map +0 -1
  94. package/dist/components/acm-certificate.js +0 -30
  95. package/dist/components/database-replica.d.ts +0 -69
  96. package/dist/components/database-replica.d.ts.map +0 -1
  97. package/dist/components/database-replica.js +0 -40
  98. package/dist/components/database.d.ts +0 -99
  99. package/dist/components/database.d.ts.map +0 -1
  100. package/dist/components/database.js +0 -118
  101. package/dist/components/ec2-ssm-connect.d.ts +0 -22
  102. package/dist/components/ec2-ssm-connect.d.ts.map +0 -1
  103. package/dist/components/ecs-service.d.ts +0 -143
  104. package/dist/components/ecs-service.d.ts.map +0 -1
  105. package/dist/components/ecs-service.js +0 -357
  106. package/dist/components/mongo.d.ts +0 -39
  107. package/dist/components/mongo.d.ts.map +0 -1
  108. package/dist/components/mongo.js +0 -54
  109. package/dist/components/nuxt-ssr.d.ts +0 -44
  110. package/dist/components/nuxt-ssr.d.ts.map +0 -1
  111. package/dist/components/nuxt-ssr.js +0 -277
  112. package/dist/components/password.d.ts +0 -13
  113. package/dist/components/password.d.ts.map +0 -1
  114. package/dist/components/project.d.ts +0 -77
  115. package/dist/components/project.d.ts.map +0 -1
  116. package/dist/components/project.js +0 -171
  117. package/dist/components/redis.d.ts +0 -23
  118. package/dist/components/redis.d.ts.map +0 -1
  119. package/dist/components/redis.js +0 -35
  120. package/dist/components/static-site.d.ts +0 -36
  121. package/dist/components/static-site.d.ts.map +0 -1
  122. package/dist/components/static-site.js +0 -138
  123. package/dist/components/web-server.d.ts +0 -38
  124. package/dist/components/web-server.d.ts.map +0 -1
  125. package/dist/components/web-server.js +0 -185
  126. package/dist/constants.d.ts +0 -23
  127. package/dist/constants.d.ts.map +0 -1
  128. package/dist/types/pulumi.d.ts +0 -5
  129. package/dist/types/pulumi.d.ts.map +0 -1
  130. package/dist/types/size.d.ts +0 -8
  131. package/dist/types/size.d.ts.map +0 -1
  132. package/dist/types/size.js +0 -2
  133. package/dist/v2/components/ecs-service/index.d.ts.map +0 -1
  134. package/dist/v2/components/ecs-service/policies.d.ts +0 -3
  135. package/dist/v2/components/ecs-service/policies.d.ts.map +0 -1
  136. package/dist/v2/components/grafana/dashboards/index.d.ts.map +0 -1
  137. package/dist/v2/components/grafana/dashboards/panels.d.ts.map +0 -1
  138. package/dist/v2/components/grafana/dashboards/types.d.ts.map +0 -1
  139. package/dist/v2/components/grafana/dashboards/web-server-slo.d.ts.map +0 -1
  140. package/dist/v2/components/grafana/index.d.ts.map +0 -1
  141. package/dist/v2/components/prometheus/index.d.ts.map +0 -1
  142. package/dist/v2/components/prometheus/queries.d.ts.map +0 -1
  143. package/dist/v2/components/prometheus/queries.test.d.ts.map +0 -1
  144. package/dist/v2/components/web-server/builder.d.ts.map +0 -1
  145. package/dist/v2/components/web-server/index.d.ts.map +0 -1
  146. package/dist/v2/components/web-server/load-balancer.d.ts.map +0 -1
  147. package/dist/v2/index.d.ts +0 -13
  148. package/dist/v2/index.d.ts.map +0 -1
  149. package/dist/v2/index.js +0 -16
  150. package/dist/v2/otel/batch-processor.d.ts.map +0 -1
  151. package/dist/v2/otel/builder.d.ts.map +0 -1
  152. package/dist/v2/otel/config.d.ts.map +0 -1
  153. package/dist/v2/otel/index.d.ts.map +0 -1
  154. package/dist/v2/otel/memory-limiter-processor.d.ts.map +0 -1
  155. package/dist/v2/otel/otlp-receiver.d.ts.map +0 -1
  156. package/dist/v2/otel/prometheus-remote-write-exporter.d.ts.map +0 -1
  157. /package/dist/{v2/components/grafana/dashboards → components/cloudfront}/types.js +0 -0
  158. /package/dist/{v2/components → components}/ecs-service/policies.js +0 -0
  159. /package/dist/{v2/components → components}/grafana/dashboards/index.d.ts +0 -0
  160. /package/dist/{v2/components → components}/grafana/dashboards/index.js +0 -0
  161. /package/dist/{v2/components → components}/grafana/dashboards/panels.d.ts +0 -0
  162. /package/dist/{v2/components → components}/grafana/dashboards/panels.js +0 -0
  163. /package/dist/{v2/components → components}/grafana/dashboards/types.d.ts +0 -0
  164. /package/dist/{types/pulumi.js → components/grafana/dashboards/types.js} +0 -0
  165. /package/dist/{v2/components → components}/grafana/dashboards/web-server-slo.d.ts +0 -0
  166. /package/dist/{v2/components → components}/grafana/dashboards/web-server-slo.js +0 -0
  167. /package/dist/{v2/components → components}/grafana/index.d.ts +0 -0
  168. /package/dist/{v2/components → components}/grafana/index.js +0 -0
  169. /package/dist/{v2/components → components}/prometheus/index.d.ts +0 -0
  170. /package/dist/{v2/components → components}/prometheus/index.js +0 -0
  171. /package/dist/{v2/components → components}/prometheus/queries.d.ts +0 -0
  172. /package/dist/{v2/components → components}/prometheus/queries.js +0 -0
  173. /package/dist/{v2/components → components}/prometheus/queries.test.d.ts +0 -0
  174. /package/dist/{v2/components → components}/prometheus/queries.test.js +0 -0
  175. /package/dist/{v2/otel → otel}/batch-processor.d.ts +0 -0
  176. /package/dist/{v2/otel → otel}/batch-processor.js +0 -0
  177. /package/dist/{v2/otel → otel}/index.js +0 -0
  178. /package/dist/{v2/otel → otel}/memory-limiter-processor.d.ts +0 -0
  179. /package/dist/{v2/otel → otel}/memory-limiter-processor.js +0 -0
  180. /package/dist/{v2/otel → otel}/otlp-receiver.d.ts +0 -0
  181. /package/dist/{v2/otel → otel}/otlp-receiver.js +0 -0
  182. /package/dist/{v2/otel → otel}/prometheus-remote-write-exporter.d.ts +0 -0
  183. /package/dist/{v2/otel → otel}/prometheus-remote-write-exporter.js +0 -0
@@ -1,39 +0,0 @@
1
- import * as pulumi from '@pulumi/pulumi';
2
- import { EcsService, EcsServiceArgs } from './ecs-service';
3
- import { Password } from './password';
4
- export type MongoArgs = Pick<EcsServiceArgs, 'size' | 'clusterId' | 'clusterName' | 'vpcId' | 'vpcCidrBlock' | 'tags'> & {
5
- privateSubnetIds: pulumi.Input<pulumi.Input<string>[]>;
6
- /**
7
- * Username for the master DB user.
8
- */
9
- username: pulumi.Input<string>;
10
- /**
11
- * Password for the master DB user. If not specified it will be autogenerated.
12
- * The value will be stored as a secret in AWS Secret Manager.
13
- */
14
- password?: pulumi.Input<string>;
15
- /**
16
- * Mongo Docker image. Defaults to mongo:7.0.3.
17
- */
18
- image?: pulumi.Input<string>;
19
- /**
20
- * Exposed service port. Defaults to 27017.
21
- */
22
- port?: pulumi.Input<number>;
23
- /**
24
- * Configuration for persistent storage using EFS volumes.
25
- * By default, creates a volume named 'mongo' mounted at '/data/db'.
26
- * You can override this by providing your own volume and mount point configuration.
27
- */
28
- persistentStorageConfig?: EcsServiceArgs['persistentStorageConfig'];
29
- };
30
- export declare class Mongo extends pulumi.ComponentResource {
31
- readonly name: string;
32
- readonly username: pulumi.Output<string>;
33
- readonly port: pulumi.Output<number>;
34
- readonly host: pulumi.Output<string>;
35
- readonly service: EcsService;
36
- readonly password: Password;
37
- constructor(name: string, args: MongoArgs, opts?: pulumi.ComponentResourceOptions);
38
- }
39
- //# sourceMappingURL=mongo.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"mongo.d.ts","sourceRoot":"","sources":["../../src/components/mongo.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,gBAAgB,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC3D,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEtC,MAAM,MAAM,SAAS,GAAG,IAAI,CAC1B,cAAc,EACd,MAAM,GAAG,WAAW,GAAG,aAAa,GAAG,OAAO,GAAG,cAAc,GAAG,MAAM,CACzE,GAAG;IACF,gBAAgB,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IACvD;;OAEG;IACH,QAAQ,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAC/B;;;OAGG;IACH,QAAQ,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAChC;;OAEG;IACH,KAAK,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAC7B;;OAEG;IACH,IAAI,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAC5B;;;;OAIG;IACH,uBAAuB,CAAC,EAAE,cAAc,CAAC,yBAAyB,CAAC,CAAC;CACrE,CAAC;AAEF,qBAAa,KAAM,SAAQ,MAAM,CAAC,iBAAiB;IACjD,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IACzC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IACrC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IACrC,QAAQ,CAAC,OAAO,EAAE,UAAU,CAAC;IAC7B,QAAQ,CAAC,QAAQ,EAAE,QAAQ,CAAC;gBAG1B,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,SAAS,EACf,IAAI,GAAE,MAAM,CAAC,wBAA6B;CA8D7C"}
@@ -1,54 +0,0 @@
1
- "use strict";
2
- var __rest = (this && this.__rest) || function (s, e) {
3
- var t = {};
4
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
5
- t[p] = s[p];
6
- if (s != null && typeof Object.getOwnPropertySymbols === "function")
7
- for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
8
- if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
9
- t[p[i]] = s[p[i]];
10
- }
11
- return t;
12
- };
13
- Object.defineProperty(exports, "__esModule", { value: true });
14
- exports.Mongo = void 0;
15
- const pulumi = require("@pulumi/pulumi");
16
- const ecs_service_1 = require("./ecs-service");
17
- const password_1 = require("./password");
18
- class Mongo extends pulumi.ComponentResource {
19
- constructor(name, args, opts = {}) {
20
- super('studion:Mongo', name, args, opts);
21
- const image = args.image ||
22
- 'mongo:7.0.3@sha256:238b1636bdd7820c752b91bec8a669f92568eb313ad89a1fc4a92903c1b40489';
23
- const port = args.port || 27017;
24
- const persistentStorageConfig = args.persistentStorageConfig || {
25
- volumes: [{ name: 'mongo' }],
26
- mountPoints: [
27
- {
28
- sourceVolume: 'mongo',
29
- containerPath: '/data/db',
30
- },
31
- ],
32
- };
33
- const { username, password, privateSubnetIds } = args, ecsServiceArgs = __rest(args, ["username", "password", "privateSubnetIds"]);
34
- this.name = name;
35
- this.host = pulumi.output(`${name}.${name}`);
36
- this.username = pulumi.output(username);
37
- this.port = pulumi.output(port);
38
- this.password = new password_1.Password(`${this.name}-mongo-password`, { value: password }, { parent: this });
39
- this.service = new ecs_service_1.EcsService(name, Object.assign(Object.assign({}, ecsServiceArgs), { port,
40
- image, desiredCount: 1, autoscaling: { enabled: false }, enableServiceAutoDiscovery: true, persistentStorageConfig, dockerCommand: ['mongod', '--port', port.toString()], assignPublicIp: false, subnetIds: privateSubnetIds, environment: [
41
- {
42
- name: 'MONGO_INITDB_ROOT_USERNAME',
43
- value: username,
44
- },
45
- ], secrets: [
46
- {
47
- name: 'MONGO_INITDB_ROOT_PASSWORD',
48
- valueFrom: this.password.secret.arn,
49
- },
50
- ] }), Object.assign(Object.assign({}, opts), { parent: this }));
51
- this.registerOutputs();
52
- }
53
- }
54
- exports.Mongo = Mongo;
@@ -1,44 +0,0 @@
1
- import * as pulumi from '@pulumi/pulumi';
2
- import * as aws from '@pulumi/aws';
3
- import { AcmCertificate } from './acm-certificate';
4
- import { EcsService, EcsServiceArgs } from './ecs-service';
5
- export type NuxtSSRArgs = Pick<EcsServiceArgs, 'image' | 'port' | 'clusterId' | 'clusterName' | 'vpcId' | 'vpcCidrBlock' | 'desiredCount' | 'autoscaling' | 'size' | 'environment' | 'secrets' | 'tags'> & {
6
- publicSubnetIds: pulumi.Input<pulumi.Input<string>[]>;
7
- /**
8
- * The domain which will be used to access the service.
9
- * The domain or subdomain must belong to the provided hostedZone.
10
- */
11
- domain?: pulumi.Input<string>;
12
- /**
13
- * The ID of the hosted zone.
14
- */
15
- hostedZoneId?: pulumi.Input<string>;
16
- /**
17
- * Path for the health check request. Defaults to "/".
18
- */
19
- healthCheckPath?: pulumi.Input<string>;
20
- };
21
- export declare class NuxtSSR extends pulumi.ComponentResource {
22
- name: string;
23
- service: EcsService;
24
- certificate?: AcmCertificate;
25
- lbSecurityGroup: aws.ec2.SecurityGroup;
26
- serviceSecurityGroup: aws.ec2.SecurityGroup;
27
- customCFHeader: {
28
- name: pulumi.Output<string>;
29
- value: pulumi.Output<string>;
30
- };
31
- lb: aws.lb.LoadBalancer;
32
- lbTargetGroup: aws.lb.TargetGroup;
33
- lbHttpListener: aws.lb.Listener;
34
- cloudfront: aws.cloudfront.Distribution;
35
- constructor(name: string, args: NuxtSSRArgs, opts?: pulumi.ComponentResourceOptions);
36
- private createTlsCertificate;
37
- private createCustomCFHeader;
38
- private createLoadBalancer;
39
- private createSecurityGroup;
40
- private createEcsService;
41
- private createCloudfrontDistribution;
42
- private createDnsRecord;
43
- }
44
- //# sourceMappingURL=nuxt-ssr.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"nuxt-ssr.d.ts","sourceRoot":"","sources":["../../src/components/nuxt-ssr.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,gBAAgB,CAAC;AACzC,OAAO,KAAK,GAAG,MAAM,aAAa,CAAC;AAGnC,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAE3D,MAAM,MAAM,WAAW,GAAG,IAAI,CAC5B,cAAc,EACZ,OAAO,GACP,MAAM,GACN,WAAW,GACX,aAAa,GACb,OAAO,GACP,cAAc,GACd,cAAc,GACd,aAAa,GACb,MAAM,GACN,aAAa,GACb,SAAS,GACT,MAAM,CACT,GAAG;IACF,eAAe,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IACtD;;;OAGG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAC9B;;OAEG;IACH,YAAY,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACpC;;OAEG;IACH,eAAe,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;CACxC,CAAC;AAMF,qBAAa,OAAQ,SAAQ,MAAM,CAAC,iBAAiB;IACnD,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,UAAU,CAAC;IACpB,WAAW,CAAC,EAAE,cAAc,CAAC;IAC7B,eAAe,EAAE,GAAG,CAAC,GAAG,CAAC,aAAa,CAAC;IACvC,oBAAoB,EAAE,GAAG,CAAC,GAAG,CAAC,aAAa,CAAC;IAC5C,cAAc,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;KAAE,CAAC;IAC9E,EAAE,EAAE,GAAG,CAAC,EAAE,CAAC,YAAY,CAAC;IACxB,aAAa,EAAE,GAAG,CAAC,EAAE,CAAC,WAAW,CAAC;IAClC,cAAc,EAAE,GAAG,CAAC,EAAE,CAAC,QAAQ,CAAC;IAChC,UAAU,EAAE,GAAG,CAAC,UAAU,CAAC,YAAY,CAAC;gBAGtC,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,WAAW,EACjB,IAAI,GAAE,MAAM,CAAC,wBAA6B;IAoC5C,OAAO,CAAC,oBAAoB;IAe5B,OAAO,CAAC,oBAAoB;IAqC5B,OAAO,CAAC,kBAAkB;IAuH1B,OAAO,CAAC,mBAAmB;IA4B3B,OAAO,CAAC,gBAAgB;IAmBxB,OAAO,CAAC,4BAA4B;IA0GpC,OAAO,CAAC,eAAe;CAsBxB"}
@@ -1,277 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.NuxtSSR = void 0;
4
- const pulumi = require("@pulumi/pulumi");
5
- const aws = require("@pulumi/aws");
6
- const random = require("@pulumi/random");
7
- const constants_1 = require("../constants");
8
- const acm_certificate_1 = require("./acm-certificate");
9
- const ecs_service_1 = require("./ecs-service");
10
- const defaults = {
11
- healthCheckPath: '/',
12
- };
13
- class NuxtSSR extends pulumi.ComponentResource {
14
- constructor(name, args, opts = {}) {
15
- super('studion:NuxtSSR', name, args, opts);
16
- const { vpcId, domain, hostedZoneId, tags } = args;
17
- const hasCustomDomain = domain && hostedZoneId;
18
- if (domain && !hostedZoneId) {
19
- throw new Error('NuxtSSR:hostedZoneId must be provided when the domain is specified');
20
- }
21
- this.name = name;
22
- if (hasCustomDomain) {
23
- this.certificate = this.createTlsCertificate({ domain, hostedZoneId });
24
- }
25
- this.customCFHeader = this.createCustomCFHeader();
26
- const { lb, lbTargetGroup, lbHttpListener, lbSecurityGroup } = this.createLoadBalancer(args);
27
- this.lb = lb;
28
- this.lbTargetGroup = lbTargetGroup;
29
- this.lbHttpListener = lbHttpListener;
30
- this.lbSecurityGroup = lbSecurityGroup;
31
- this.serviceSecurityGroup = this.createSecurityGroup(vpcId);
32
- this.service = this.createEcsService(args);
33
- this.cloudfront = this.createCloudfrontDistribution({ domain, tags });
34
- if (hasCustomDomain) {
35
- this.createDnsRecord({ domain, hostedZoneId });
36
- }
37
- this.registerOutputs();
38
- }
39
- createTlsCertificate({ domain, hostedZoneId, }) {
40
- const certificate = new acm_certificate_1.AcmCertificate(`${domain}-acm-certificate`, {
41
- domain,
42
- hostedZoneId,
43
- }, { parent: this });
44
- return certificate;
45
- }
46
- createCustomCFHeader() {
47
- const headerNameOpts = {
48
- length: 4,
49
- special: false,
50
- numeric: false,
51
- lower: false,
52
- upper: true,
53
- };
54
- const headerNameSegment1 = new random.RandomString(`${this.name}-cf-header-name-segment1`, headerNameOpts, { parent: this });
55
- const headerNameSegment2 = new random.RandomString(`${this.name}-cf-header-name-segment2`, headerNameOpts, { parent: this });
56
- const headerValue = new random.RandomString(`${this.name}-cf-header-value`, {
57
- length: 36,
58
- special: false,
59
- numeric: true,
60
- lower: true,
61
- upper: true,
62
- }, { parent: this });
63
- const headerName = pulumi
64
- .all([headerNameSegment1.result, headerNameSegment2.result])
65
- .apply(([segment1, segment2]) => {
66
- return `X-${segment1}-${segment2}`;
67
- });
68
- return { name: headerName, value: headerValue.result };
69
- }
70
- createLoadBalancer({ vpcId, publicSubnetIds, port, healthCheckPath, }) {
71
- const lbSecurityGroup = new aws.ec2.SecurityGroup(`${this.name}-lb-security-group`, {
72
- vpcId,
73
- ingress: [
74
- {
75
- protocol: 'tcp',
76
- fromPort: 80,
77
- toPort: 80,
78
- cidrBlocks: ['0.0.0.0/0'],
79
- },
80
- ],
81
- egress: [
82
- {
83
- fromPort: 0,
84
- toPort: 0,
85
- protocol: '-1',
86
- cidrBlocks: ['0.0.0.0/0'],
87
- },
88
- ],
89
- tags: constants_1.commonTags,
90
- }, { parent: this });
91
- const lb = new aws.lb.LoadBalancer(`${this.name}-lb`, {
92
- namePrefix: 'lb-',
93
- loadBalancerType: 'application',
94
- subnets: publicSubnetIds,
95
- securityGroups: [lbSecurityGroup.id],
96
- internal: false,
97
- ipAddressType: 'ipv4',
98
- tags: Object.assign(Object.assign({}, constants_1.commonTags), { Name: `${this.name}-lb` }),
99
- }, { parent: this });
100
- const lbTargetGroup = new aws.lb.TargetGroup(`${this.name}-lb-tg`, {
101
- namePrefix: 'lb-tg-',
102
- port,
103
- protocol: 'HTTP',
104
- targetType: 'ip',
105
- vpcId,
106
- healthCheck: {
107
- healthyThreshold: 3,
108
- unhealthyThreshold: 2,
109
- interval: 60,
110
- timeout: 5,
111
- path: healthCheckPath || defaults.healthCheckPath,
112
- },
113
- tags: Object.assign(Object.assign({}, constants_1.commonTags), { Name: `${this.name}-lb-target-group` }),
114
- }, { parent: this, dependsOn: [this.lb] });
115
- const lbHttpListener = new aws.lb.Listener(`${this.name}-lb-listener-80`, {
116
- loadBalancerArn: lb.arn,
117
- port: 80,
118
- defaultActions: [
119
- {
120
- type: 'fixed-response',
121
- fixedResponse: {
122
- statusCode: '403',
123
- messageBody: 'Not Allowed',
124
- contentType: 'text/plain',
125
- },
126
- },
127
- ],
128
- tags: constants_1.commonTags,
129
- }, { parent: this });
130
- const lbHttpListenerRule = new aws.lb.ListenerRule(`${this.name}-lb-listener-rule`, {
131
- listenerArn: lbHttpListener.arn,
132
- priority: 1,
133
- actions: [
134
- {
135
- type: 'forward',
136
- targetGroupArn: lbTargetGroup.arn,
137
- },
138
- ],
139
- conditions: [
140
- {
141
- httpHeader: {
142
- httpHeaderName: this.customCFHeader.name,
143
- values: [this.customCFHeader.value],
144
- },
145
- },
146
- ],
147
- }, { parent: this });
148
- return {
149
- lb,
150
- lbTargetGroup,
151
- lbHttpListener,
152
- lbSecurityGroup,
153
- };
154
- }
155
- createSecurityGroup(vpcId) {
156
- const securityGroup = new aws.ec2.SecurityGroup(`${this.name}-security-group`, {
157
- vpcId,
158
- ingress: [
159
- {
160
- fromPort: 0,
161
- toPort: 0,
162
- protocol: '-1',
163
- securityGroups: [this.lbSecurityGroup.id],
164
- },
165
- ],
166
- egress: [
167
- {
168
- fromPort: 0,
169
- toPort: 0,
170
- protocol: '-1',
171
- cidrBlocks: ['0.0.0.0/0'],
172
- },
173
- ],
174
- tags: constants_1.commonTags,
175
- }, { parent: this });
176
- return securityGroup;
177
- }
178
- createEcsService(args) {
179
- const service = new ecs_service_1.EcsService(this.name, Object.assign(Object.assign({}, args), { enableServiceAutoDiscovery: false, lbTargetGroupArn: this.lbTargetGroup.arn, assignPublicIp: true, subnetIds: args.publicSubnetIds, securityGroup: this.serviceSecurityGroup }), {
180
- parent: this,
181
- dependsOn: [this.lb, this.lbTargetGroup, this.lbHttpListener],
182
- });
183
- return service;
184
- }
185
- createCloudfrontDistribution({ domain, tags, }) {
186
- const cachePolicy = new aws.cloudfront.CachePolicy(`${this.name}-cf-cache-policy`, {
187
- comment: 'This cache policy is managed by Pulumi, changing its values will impact multiple services.',
188
- defaultTtl: 0,
189
- maxTtl: 31536000,
190
- minTtl: 0,
191
- parametersInCacheKeyAndForwardedToOrigin: {
192
- cookiesConfig: {
193
- cookieBehavior: 'none',
194
- },
195
- headersConfig: {
196
- headerBehavior: 'none',
197
- },
198
- queryStringsConfig: {
199
- queryStringBehavior: 'all',
200
- },
201
- },
202
- }, { parent: this });
203
- const originRequestPolicyId = aws.cloudfront
204
- .getOriginRequestPolicyOutput({
205
- name: 'Managed-AllViewer',
206
- })
207
- .apply(policy => policy.id);
208
- const responseHeadersPolicyId = aws.cloudfront
209
- .getResponseHeadersPolicyOutput({
210
- name: 'Managed-SecurityHeadersPolicy',
211
- })
212
- .apply(policy => policy.id);
213
- const cloudfront = new aws.cloudfront.Distribution(`${this.name}-cloudfront`, Object.assign(Object.assign({ enabled: true }, (domain && { aliases: [domain] })), { isIpv6Enabled: true, waitForDeployment: true, httpVersion: 'http2and3', viewerCertificate: Object.assign({}, (this.certificate
214
- ? {
215
- acmCertificateArn: this.certificate.certificate.arn,
216
- sslSupportMethod: 'sni-only',
217
- minimumProtocolVersion: 'TLSv1.2_2021',
218
- }
219
- : {
220
- cloudfrontDefaultCertificate: true,
221
- })), origins: [
222
- {
223
- originId: this.lb.arn,
224
- domainName: this.lb.dnsName,
225
- connectionAttempts: 3,
226
- connectionTimeout: 10,
227
- customOriginConfig: {
228
- originProtocolPolicy: 'http-only',
229
- httpPort: 80,
230
- httpsPort: 443,
231
- originSslProtocols: ['SSLv3'],
232
- },
233
- customHeaders: [
234
- { name: 'X-Forwarded-Port', value: '443' },
235
- { name: 'X-Forwarded-Ssl', value: 'on' },
236
- this.customCFHeader,
237
- ],
238
- },
239
- ], defaultCacheBehavior: {
240
- targetOriginId: this.lb.arn,
241
- viewerProtocolPolicy: 'redirect-to-https',
242
- allowedMethods: [
243
- 'GET',
244
- 'HEAD',
245
- 'OPTIONS',
246
- 'PUT',
247
- 'POST',
248
- 'PATCH',
249
- 'DELETE',
250
- ],
251
- cachedMethods: ['GET', 'HEAD'],
252
- compress: true,
253
- cachePolicyId: cachePolicy.id,
254
- originRequestPolicyId,
255
- responseHeadersPolicyId,
256
- }, priceClass: 'PriceClass_100', restrictions: {
257
- geoRestriction: { restrictionType: 'none' },
258
- }, tags: Object.assign(Object.assign({}, constants_1.commonTags), tags) }), { parent: this });
259
- return cloudfront;
260
- }
261
- createDnsRecord({ domain, hostedZoneId, }) {
262
- const cdnAliasRecord = new aws.route53.Record(`${this.name}-cdn-route53-record`, {
263
- type: 'A',
264
- name: domain,
265
- zoneId: hostedZoneId,
266
- aliases: [
267
- {
268
- name: this.cloudfront.domainName,
269
- zoneId: this.cloudfront.hostedZoneId,
270
- evaluateTargetHealth: true,
271
- },
272
- ],
273
- }, { parent: this });
274
- return cdnAliasRecord;
275
- }
276
- }
277
- exports.NuxtSSR = NuxtSSR;
@@ -1,13 +0,0 @@
1
- import * as aws from '@pulumi/aws';
2
- import * as pulumi from '@pulumi/pulumi';
3
- export type PasswordArgs = {
4
- value?: pulumi.Input<string>;
5
- };
6
- export declare class Password extends pulumi.ComponentResource {
7
- name: string;
8
- value: pulumi.Output<string>;
9
- secret: aws.secretsmanager.Secret;
10
- constructor(name: string, args: PasswordArgs, opts?: pulumi.ComponentResourceOptions);
11
- private createPasswordSecret;
12
- }
13
- //# sourceMappingURL=password.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"password.d.ts","sourceRoot":"","sources":["../../src/components/password.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,GAAG,MAAM,aAAa,CAAC;AACnC,OAAO,KAAK,MAAM,MAAM,gBAAgB,CAAC;AAIzC,MAAM,MAAM,YAAY,GAAG;IACzB,KAAK,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;CAC9B,CAAC;AAEF,qBAAa,QAAS,SAAQ,MAAM,CAAC,iBAAiB;IACpD,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAC7B,MAAM,EAAE,GAAG,CAAC,cAAc,CAAC,MAAM,CAAC;gBAGhC,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,YAAY,EAClB,IAAI,GAAE,MAAM,CAAC,wBAA6B;IA2B5C,OAAO,CAAC,oBAAoB;CAwB7B"}
@@ -1,77 +0,0 @@
1
- import * as pulumi from '@pulumi/pulumi';
2
- import * as aws from '@pulumi/aws';
3
- import * as awsx from '@pulumi/awsx';
4
- import * as upstash from '@upstash/pulumi';
5
- import { Database, DatabaseArgs } from './database';
6
- import { WebServer, WebServerArgs } from './web-server';
7
- import { Mongo, MongoArgs } from './mongo';
8
- import { Redis, RedisArgs } from './redis';
9
- import { StaticSite, StaticSiteArgs } from './static-site';
10
- import { Ec2SSMConnect } from './ec2-ssm-connect';
11
- import { EcsService, EcsServiceArgs } from './ecs-service';
12
- import { NuxtSSR, NuxtSSRArgs } from './nuxt-ssr';
13
- export type Service = Database | Redis | StaticSite | WebServer | NuxtSSR | Mongo | EcsService;
14
- export type Services = Record<string, Service>;
15
- type ServiceArgs = {
16
- /**
17
- * The unique name for the service.
18
- */
19
- serviceName: string;
20
- };
21
- export type DatabaseServiceOptions = {
22
- type: 'DATABASE';
23
- } & ServiceArgs & Omit<DatabaseArgs, 'vpcId' | 'vpcCidrBlock' | 'isolatedSubnetIds'>;
24
- export type RedisServiceOptions = {
25
- type: 'REDIS';
26
- } & ServiceArgs & RedisArgs;
27
- export type StaticSiteServiceOptions = {
28
- type: 'STATIC_SITE';
29
- } & ServiceArgs & StaticSiteArgs;
30
- export type WebServerServiceOptions = {
31
- type: 'WEB_SERVER';
32
- environment?: aws.ecs.KeyValuePair[] | ((services: Services) => aws.ecs.KeyValuePair[]);
33
- secrets?: aws.ecs.Secret[] | ((services: Services) => aws.ecs.Secret[]);
34
- } & ServiceArgs & Omit<WebServerArgs, 'clusterId' | 'clusterName' | 'vpcId' | 'vpcCidrBlock' | 'publicSubnetIds' | 'environment' | 'secrets'>;
35
- export type NuxtSSRServiceOptions = {
36
- type: 'NUXT_SSR';
37
- environment?: aws.ecs.KeyValuePair[] | ((services: Services) => aws.ecs.KeyValuePair[]);
38
- secrets?: aws.ecs.Secret[] | ((services: Services) => aws.ecs.Secret[]);
39
- } & ServiceArgs & Omit<NuxtSSRArgs, 'clusterId' | 'clusterName' | 'vpcId' | 'vpcCidrBlock' | 'publicSubnetIds' | 'environment' | 'secrets'>;
40
- export type MongoServiceOptions = {
41
- type: 'MONGO';
42
- } & ServiceArgs & Omit<MongoArgs, 'clusterId' | 'clusterName' | 'vpcId' | 'vpcCidrBlock' | 'privateSubnetIds' | 'environment' | 'secrets'>;
43
- export type EcsServiceOptions = {
44
- type: 'ECS_SERVICE';
45
- environment?: aws.ecs.KeyValuePair[] | ((services: Services) => aws.ecs.KeyValuePair[]);
46
- secrets?: aws.ecs.Secret[] | ((services: Services) => aws.ecs.Secret[]);
47
- } & ServiceArgs & Omit<EcsServiceArgs, 'clusterId' | 'clusterName' | 'vpcId' | 'vpcCidrBlock' | 'subnetIds' | 'environment' | 'secrets'>;
48
- export type ProjectArgs = {
49
- services: (DatabaseServiceOptions | RedisServiceOptions | StaticSiteServiceOptions | WebServerServiceOptions | NuxtSSRServiceOptions | MongoServiceOptions | EcsServiceOptions)[];
50
- enableSSMConnect?: pulumi.Input<boolean>;
51
- numberOfAvailabilityZones?: number;
52
- };
53
- export declare class MissingEcsCluster extends Error {
54
- constructor();
55
- }
56
- export declare class Project extends pulumi.ComponentResource {
57
- name: string;
58
- vpc: awsx.ec2.Vpc;
59
- cluster?: aws.ecs.Cluster;
60
- upstashProvider?: upstash.Provider;
61
- ec2SSMConnect?: Ec2SSMConnect;
62
- services: Services;
63
- constructor(name: string, args: ProjectArgs, opts?: pulumi.ComponentResourceOptions);
64
- private createVpc;
65
- private createServices;
66
- private createRedisPrerequisites;
67
- private createEcsCluster;
68
- private createDatabaseService;
69
- private createRedisService;
70
- private createStaticSiteService;
71
- private createWebServerService;
72
- private createNuxtSSRService;
73
- private createMongoService;
74
- private createEcsService;
75
- }
76
- export {};
77
- //# sourceMappingURL=project.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"project.d.ts","sourceRoot":"","sources":["../../src/components/project.ts"],"names":[],"mappings":"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"}