@papiro/cdk 0.0.1 → 0.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AIOServer.d.ts +25 -0
- package/dist/AIOServer.js +87 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +18 -0
- package/package.json +9 -4
- package/cdk.context.json +0 -5
- package/jest.config.js +0 -8
- package/tsconfig.json +0 -32
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { StackProps } from "aws-cdk-lib";
|
|
2
|
+
import { Construct } from "constructs";
|
|
3
|
+
import { Vpc, Instance, SecurityGroup } from "aws-cdk-lib/aws-ec2";
|
|
4
|
+
import { PolicyDocument } from "aws-cdk-lib/aws-iam";
|
|
5
|
+
import { Bucket } from "aws-cdk-lib/aws-s3";
|
|
6
|
+
export interface AppDefinition {
|
|
7
|
+
id: string;
|
|
8
|
+
domains: string[];
|
|
9
|
+
port: number;
|
|
10
|
+
}
|
|
11
|
+
export interface AIOServerStackProps extends StackProps {
|
|
12
|
+
vpc: Vpc;
|
|
13
|
+
/** Public domains that should resolve to the AIO server */
|
|
14
|
+
apps?: AppDefinition[];
|
|
15
|
+
keyPairName: string;
|
|
16
|
+
imageS3Bucket: Bucket;
|
|
17
|
+
userData?: string[];
|
|
18
|
+
instanceType?: string;
|
|
19
|
+
inlinePolicies?: Record<string, PolicyDocument>;
|
|
20
|
+
}
|
|
21
|
+
export declare class AIOServer extends Construct {
|
|
22
|
+
readonly instance: Instance;
|
|
23
|
+
readonly securityGroup: SecurityGroup;
|
|
24
|
+
constructor(scope: Construct, id: string, { vpc, apps, keyPairName, imageS3Bucket, userData, instanceType, inlinePolicies, ...props }: AIOServerStackProps);
|
|
25
|
+
}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AIOServer = void 0;
|
|
4
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
5
|
+
const constructs_1 = require("constructs");
|
|
6
|
+
const aws_ec2_1 = require("aws-cdk-lib/aws-ec2");
|
|
7
|
+
const aws_route53_1 = require("aws-cdk-lib/aws-route53");
|
|
8
|
+
const aws_iam_1 = require("aws-cdk-lib/aws-iam");
|
|
9
|
+
class AIOServer extends constructs_1.Construct {
|
|
10
|
+
instance;
|
|
11
|
+
securityGroup;
|
|
12
|
+
constructor(scope, id, { vpc, apps = [], keyPairName, imageS3Bucket, userData = [], instanceType = "t4g.small", inlinePolicies, ...props }) {
|
|
13
|
+
super(scope, id);
|
|
14
|
+
const securityGroup = new aws_ec2_1.SecurityGroup(this, "SecurityGroup", {
|
|
15
|
+
vpc,
|
|
16
|
+
description: "AIOServer security group",
|
|
17
|
+
allowAllOutbound: true,
|
|
18
|
+
});
|
|
19
|
+
securityGroup.addIngressRule(aws_ec2_1.Peer.anyIpv4(), aws_ec2_1.Port.tcp(80), "HTTP from internet");
|
|
20
|
+
securityGroup.addIngressRule(aws_ec2_1.Peer.anyIpv4(), aws_ec2_1.Port.tcp(443), "HTTPS from internet");
|
|
21
|
+
const instance = new aws_ec2_1.Instance(this, "Instance", {
|
|
22
|
+
vpc,
|
|
23
|
+
vpcSubnets: { subnetType: aws_ec2_1.SubnetType.PUBLIC },
|
|
24
|
+
instanceType: new aws_ec2_1.InstanceType(instanceType),
|
|
25
|
+
machineImage: aws_ec2_1.MachineImage.latestAmazonLinux2023({
|
|
26
|
+
cpuType: aws_ec2_1.AmazonLinuxCpuType.ARM_64,
|
|
27
|
+
cachedInContext: true,
|
|
28
|
+
}),
|
|
29
|
+
securityGroup: securityGroup,
|
|
30
|
+
role: new aws_iam_1.Role(this, "IncubatorAppServerRole", {
|
|
31
|
+
assumedBy: new aws_iam_1.ServicePrincipal("ec2.amazonaws.com"),
|
|
32
|
+
managedPolicies: [
|
|
33
|
+
aws_iam_1.ManagedPolicy.fromAwsManagedPolicyName("AmazonSSMManagedInstanceCore"),
|
|
34
|
+
aws_iam_1.ManagedPolicy.fromAwsManagedPolicyName("CloudWatchAgentServerPolicy"),
|
|
35
|
+
],
|
|
36
|
+
inlinePolicies,
|
|
37
|
+
}),
|
|
38
|
+
keyPair: aws_ec2_1.KeyPair.fromKeyPairName(this, "KeyPair", keyPairName),
|
|
39
|
+
blockDevices: [
|
|
40
|
+
{
|
|
41
|
+
deviceName: "/dev/xvda",
|
|
42
|
+
volume: aws_ec2_1.BlockDeviceVolume.ebs(20, {
|
|
43
|
+
volumeType: aws_ec2_1.EbsDeviceVolumeType.GP3,
|
|
44
|
+
deleteOnTermination: false,
|
|
45
|
+
encrypted: true,
|
|
46
|
+
}),
|
|
47
|
+
},
|
|
48
|
+
],
|
|
49
|
+
});
|
|
50
|
+
instance.addUserData("dnf update -y", ...userData, "dnf install -y amazon-cloudwatch-agent", 'echo "UserData complete"');
|
|
51
|
+
// Allocate Elastic IP and associate with instance for stable public address
|
|
52
|
+
const eip = new aws_ec2_1.CfnEIP(this, "Eip", {
|
|
53
|
+
domain: "vpc",
|
|
54
|
+
});
|
|
55
|
+
new aws_ec2_1.CfnEIPAssociation(this, "CfnEipAssociation", {
|
|
56
|
+
allocationId: eip.attrAllocationId,
|
|
57
|
+
instanceId: instance.instanceId,
|
|
58
|
+
});
|
|
59
|
+
new aws_cdk_lib_1.CfnOutput(this, "AIOServerElasticIp", {
|
|
60
|
+
value: eip.attrPublicIp,
|
|
61
|
+
description: "Elastic IP of the AIO Server",
|
|
62
|
+
exportName: "AIOServerEip",
|
|
63
|
+
});
|
|
64
|
+
new aws_cdk_lib_1.CfnOutput(this, "AIOServerInstanceId", {
|
|
65
|
+
value: instance.instanceId,
|
|
66
|
+
exportName: "AIOServerInstanceId",
|
|
67
|
+
});
|
|
68
|
+
// Public DNS records per incubated application
|
|
69
|
+
apps.forEach((appDef) => {
|
|
70
|
+
const publicZone = aws_route53_1.HostedZone.fromLookup(this, `${appDef.id}-PublicZone`, {
|
|
71
|
+
domainName: appDef.domains[0].split(".").slice(1).join("."),
|
|
72
|
+
});
|
|
73
|
+
appDef.domains.forEach((domain) => {
|
|
74
|
+
new aws_route53_1.ARecord(this, `ARecord-${domain}`, {
|
|
75
|
+
zone: publicZone,
|
|
76
|
+
recordName: domain.replace(`.${publicZone.zoneName}`, ""),
|
|
77
|
+
target: aws_route53_1.RecordTarget.fromIpAddresses(instance.instancePublicIp),
|
|
78
|
+
ttl: aws_cdk_lib_1.Duration.minutes(1),
|
|
79
|
+
});
|
|
80
|
+
});
|
|
81
|
+
});
|
|
82
|
+
this.instance = instance;
|
|
83
|
+
this.securityGroup = securityGroup;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
exports.AIOServer = AIOServer;
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AIOServer.js","sourceRoot":"","sources":["../lib/AIOServer.ts"],"names":[],"mappings":"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","sourcesContent":["import { CfnOutput, Duration, Stack, StackProps } from \"aws-cdk-lib\";\nimport { Construct } from \"constructs\";\nimport {\n  Vpc,\n  Instance,\n  SecurityGroup,\n  Peer,\n  Port,\n  BlockDeviceVolume,\n  CfnEIP,\n  CfnEIPAssociation,\n  EbsDeviceVolumeType,\n  InstanceType,\n  KeyPair,\n  MachineImage,\n  SubnetType,\n  AmazonLinuxCpuType,\n} from \"aws-cdk-lib/aws-ec2\";\nimport { ARecord, HostedZone, RecordTarget } from \"aws-cdk-lib/aws-route53\";\nimport {\n  Role,\n  ServicePrincipal,\n  ManagedPolicy,\n  PolicyStatement,\n  Effect,\n  PolicyDocument,\n} from \"aws-cdk-lib/aws-iam\";\nimport { Bucket } from \"aws-cdk-lib/aws-s3\";\n\nexport interface AppDefinition {\n  id: string;\n  domains: string[];\n  port: number;\n}\n\nexport interface AIOServerStackProps extends StackProps {\n  vpc: Vpc;\n  /** Public domains that should resolve to the AIO server */\n  apps?: AppDefinition[];\n  keyPairName: string;\n  imageS3Bucket: Bucket;\n  userData?: string[];\n  instanceType?: string;\n  inlinePolicies?: Record<string, PolicyDocument>;\n}\n\nexport class AIOServer extends Construct {\n  public readonly instance: Instance;\n  public readonly securityGroup: SecurityGroup;\n\n  constructor(\n    scope: Construct,\n    id: string,\n    {\n      vpc,\n      apps = [],\n      keyPairName,\n      imageS3Bucket,\n      userData = [],\n      instanceType = \"t4g.small\",\n      inlinePolicies,\n      ...props\n    }: AIOServerStackProps\n  ) {\n    super(scope, id);\n\n    const securityGroup = new SecurityGroup(this, \"SecurityGroup\", {\n      vpc,\n      description: \"AIOServer security group\",\n      allowAllOutbound: true,\n    });\n\n    securityGroup.addIngressRule(\n      Peer.anyIpv4(),\n      Port.tcp(80),\n      \"HTTP from internet\"\n    );\n\n    securityGroup.addIngressRule(\n      Peer.anyIpv4(),\n      Port.tcp(443),\n      \"HTTPS from internet\"\n    );\n\n    const instance = new Instance(this, \"Instance\", {\n      vpc,\n      vpcSubnets: { subnetType: SubnetType.PUBLIC },\n      instanceType: new InstanceType(instanceType),\n      machineImage: MachineImage.latestAmazonLinux2023({\n        cpuType: AmazonLinuxCpuType.ARM_64,\n        cachedInContext: true,\n      }),\n      securityGroup: securityGroup,\n      role: new Role(this, \"IncubatorAppServerRole\", {\n        assumedBy: new ServicePrincipal(\"ec2.amazonaws.com\"),\n        managedPolicies: [\n          ManagedPolicy.fromAwsManagedPolicyName(\n            \"AmazonSSMManagedInstanceCore\"\n          ),\n          ManagedPolicy.fromAwsManagedPolicyName(\"CloudWatchAgentServerPolicy\"),\n        ],\n        inlinePolicies,\n      }),\n      keyPair: KeyPair.fromKeyPairName(this, \"KeyPair\", keyPairName),\n      blockDevices: [\n        {\n          deviceName: \"/dev/xvda\",\n          volume: BlockDeviceVolume.ebs(20, {\n            volumeType: EbsDeviceVolumeType.GP3,\n            deleteOnTermination: false,\n            encrypted: true,\n          }),\n        },\n      ],\n    });\n\n    instance.addUserData(\n      \"dnf update -y\",\n      ...userData,\n      \"dnf install -y amazon-cloudwatch-agent\",\n      'echo \"UserData complete\"'\n    );\n\n    // Allocate Elastic IP and associate with instance for stable public address\n    const eip = new CfnEIP(this, \"Eip\", {\n      domain: \"vpc\",\n    });\n\n    new CfnEIPAssociation(this, \"CfnEipAssociation\", {\n      allocationId: eip.attrAllocationId,\n      instanceId: instance.instanceId,\n    });\n\n    new CfnOutput(this, \"AIOServerElasticIp\", {\n      value: eip.attrPublicIp,\n      description: \"Elastic IP of the AIO Server\",\n      exportName: \"AIOServerEip\",\n    });\n\n    new CfnOutput(this, \"AIOServerInstanceId\", {\n      value: instance.instanceId,\n      exportName: \"AIOServerInstanceId\",\n    });\n\n    // Public DNS records per incubated application\n    apps.forEach((appDef) => {\n      const publicZone = HostedZone.fromLookup(\n        this,\n        `${appDef.id}-PublicZone`,\n        {\n          domainName: appDef.domains[0].split(\".\").slice(1).join(\".\"),\n        }\n      );\n\n      appDef.domains.forEach((domain) => {\n        new ARecord(this, `ARecord-${domain}`, {\n          zone: publicZone,\n          recordName: domain.replace(`.${publicZone.zoneName}`, \"\"),\n          target: RecordTarget.fromIpAddresses(instance.instancePublicIp),\n          ttl: Duration.minutes(1),\n        });\n      });\n    });\n\n    this.instance = instance;\n    this.securityGroup = securityGroup;\n  }\n}\n"]}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./AIOServer";
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
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("./AIOServer"), exports);
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9saWIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDhDQUE0QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL0FJT1NlcnZlclwiO1xuIl19
|
package/package.json
CHANGED
|
@@ -1,12 +1,17 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@papiro/cdk",
|
|
3
|
-
"version": "0.0.
|
|
4
|
-
"main": "
|
|
5
|
-
"types": "
|
|
3
|
+
"version": "0.0.3",
|
|
4
|
+
"main": "dist/index.js",
|
|
5
|
+
"types": "dist/index.d.ts",
|
|
6
|
+
"files": [
|
|
7
|
+
"dist"
|
|
8
|
+
],
|
|
6
9
|
"scripts": {
|
|
7
10
|
"build": "tsc",
|
|
8
11
|
"watch": "tsc -w",
|
|
9
|
-
"test": "jest"
|
|
12
|
+
"test": "jest",
|
|
13
|
+
"prepack": "tsc --outDir dist",
|
|
14
|
+
"postpack": "rm -R dist"
|
|
10
15
|
},
|
|
11
16
|
"devDependencies": {
|
|
12
17
|
"@types/jest": "^29.5.14",
|
package/cdk.context.json
DELETED
package/jest.config.js
DELETED
package/tsconfig.json
DELETED
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"compilerOptions": {
|
|
3
|
-
"target": "ES2022",
|
|
4
|
-
"module": "NodeNext",
|
|
5
|
-
"moduleResolution": "NodeNext",
|
|
6
|
-
"lib": [
|
|
7
|
-
"es2022"
|
|
8
|
-
],
|
|
9
|
-
"declaration": true,
|
|
10
|
-
"strict": true,
|
|
11
|
-
"noImplicitAny": true,
|
|
12
|
-
"strictNullChecks": true,
|
|
13
|
-
"noImplicitThis": true,
|
|
14
|
-
"alwaysStrict": true,
|
|
15
|
-
"noUnusedLocals": false,
|
|
16
|
-
"noUnusedParameters": false,
|
|
17
|
-
"noImplicitReturns": true,
|
|
18
|
-
"noFallthroughCasesInSwitch": false,
|
|
19
|
-
"inlineSourceMap": true,
|
|
20
|
-
"inlineSources": true,
|
|
21
|
-
"experimentalDecorators": true,
|
|
22
|
-
"strictPropertyInitialization": false,
|
|
23
|
-
"skipLibCheck": true,
|
|
24
|
-
"typeRoots": [
|
|
25
|
-
"./node_modules/@types"
|
|
26
|
-
]
|
|
27
|
-
},
|
|
28
|
-
"exclude": [
|
|
29
|
-
"node_modules",
|
|
30
|
-
"cdk.out"
|
|
31
|
-
]
|
|
32
|
-
}
|