UNPKG

turbo-remote-cache-construct

Version:

A Turborepo Remote Cache implementation using AWS API Gateway, Lambda, S3, and DynamoDB.

108 lines 16.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.LambdaFunctions = void 0; const constructs_1 = require("constructs"); const lambda = require("aws-cdk-lib/aws-lambda"); const path = require("path"); class LambdaFunctions extends constructs_1.Construct { constructor(scope, id, props) { super(scope, id); this.recordEventsFunction = new lambda.Function(this, 'RecordEventsFunction', { runtime: lambda.Runtime.NODEJS_20_X, functionName: 'turbo-remote-cache-record-events', handler: 'index.handler', code: lambda.Code.fromAsset(path.join(__dirname, '../lambda/dist/record-events')), environment: { EVENTS_TABLE_NAME: props.eventsTable.tableName, }, ...props.lambdaProps, }); this.artifactQueryFunction = new lambda.Function(this, 'ArtifactQueryFunction', { runtime: lambda.Runtime.NODEJS_20_X, functionName: 'turbo-remote-cache-artifact-query', handler: 'index.handler', code: lambda.Code.fromAsset(path.join(__dirname, '../lambda/dist/artifact-query')), environment: { EVENTS_TABLE_NAME: props.eventsTable.tableName, }, ...props.lambdaProps, }); this.statusFunction = new lambda.Function(this, 'StatusFunction', { runtime: lambda.Runtime.NODEJS_20_X, functionName: 'turbo-remote-cache-status', handler: 'index.handler', code: lambda.Code.fromAsset(path.join(__dirname, '../lambda/dist/status')), environment: { BUCKET_NAME: props.artifactsBucket.bucketName, }, ...props.lambdaProps, }); if (props.authorizerFunction) { this.authorizerFunction = props.authorizerFunction; } else { this.authorizerFunction = new lambda.Function(this, 'TokenAuthorizerFunction', { runtime: lambda.Runtime.NODEJS_20_X, functionName: 'turbo-remote-cache-token-authorizer', handler: 'index.handler', code: lambda.Code.fromAsset(path.join(__dirname, '../lambda/dist/token-authorizer')), environment: { TURBO_TOKEN: process.env.TURBO_TOKEN, }, ...props.lambdaProps, }); } if (props.userInfoFunction) { this.getUserInfoFunction = props.userInfoFunction; } else { this.getUserInfoFunction = new lambda.Function(this, 'GetUserInfoFunction', { runtime: lambda.Runtime.NODEJS_20_X, functionName: 'turbo-remote-cache-get-user-info', handler: 'index.handler', code: lambda.Code.fromAsset(path.join(__dirname, '../lambda/dist/get-user-info')), ...props.lambdaProps, }); } this.preflightArtifactFunction = new lambda.Function(this, 'PreflightArtifactFunction', { runtime: lambda.Runtime.NODEJS_20_X, functionName: 'turbo-remote-cache-preflight-artifact', handler: 'index.handler', code: lambda.Code.fromAsset(path.join(__dirname, '../lambda/dist/preflight-artifact')), environment: { ARTIFACTS_BUCKET: props.artifactsBucket.bucketName, }, }); // turbo login // TODO: implement lambda authorizer to validate third party JWT // this.initiateLoginFunction = new lambda.Function(this, 'InitiateLoginFunction', { // runtime: lambda.Runtime.NODEJS_20_X, // functionName: 'turbo-remote-cache-initiate-login', // handler: 'index.handler', // code: lambda.Code.fromAsset(path.join(__dirname, '../lambda/dist/initiate-login')), // environment: { // TURBO_TOKEN: process.env.TURBO_TOKEN!, // }, // ...props.lambdaProps, // }); // this.loginSuccessFunction = new lambda.Function(this, 'LoginSuccessFunction', { // runtime: lambda.Runtime.NODEJS_20_X, // functionName: 'turbo-remote-cache-login-success', // handler: 'index.handler', // code: lambda.Code.fromAsset(path.join(__dirname, '../lambda/dist/login-success')), // environment: { // TURBO_TOKEN: process.env.TURBO_TOKEN!, // }, // ...props.lambdaProps, // }); props.artifactsBucket.grantRead(this.artifactQueryFunction); props.artifactsBucket.grantReadWrite(this.recordEventsFunction); props.artifactsBucket.grantRead(this.statusFunction); // Grant permissions props.eventsTable.grantReadWriteData(this.recordEventsFunction); props.eventsTable.grantReadData(this.artifactQueryFunction); props.artifactsBucket.grantReadWrite(this.preflightArtifactFunction); } } exports.LambdaFunctions = LambdaFunctions; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda.js","sourceRoot":"","sources":["../src/lambda.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from \"constructs\";\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport * as dynamodb from 'aws-cdk-lib/aws-dynamodb';\nimport * as path from 'path';\n\ninterface LambdaFunctionsProps {\n  artifactsBucket: s3.Bucket;\n  eventsTable: dynamodb.Table;\n  lambdaProps?: Partial<lambda.FunctionProps>;\n  authorizerFunction?: lambda.Function;\n  userInfoFunction?: lambda.Function;\n}\n\nexport class LambdaFunctions extends Construct {\n  public readonly recordEventsFunction: lambda.Function;\n  public readonly artifactQueryFunction: lambda.Function;\n  public readonly statusFunction: lambda.Function;\n  public readonly initiateLoginFunction: lambda.Function;\n  public readonly loginSuccessFunction: lambda.Function;\n  public readonly getUserInfoFunction: lambda.Function;\n  public readonly authorizerFunction: lambda.Function;\n  public readonly preflightArtifactFunction: lambda.Function;\n\n  constructor(scope: Construct, id: string, props: LambdaFunctionsProps) {\n    super(scope, id);\n\n    this.recordEventsFunction = new lambda.Function(this, 'RecordEventsFunction', {\n      runtime: lambda.Runtime.NODEJS_20_X,\n      functionName: 'turbo-remote-cache-record-events',\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(path.join(__dirname, '../lambda/dist/record-events')),\n      environment: {\n        EVENTS_TABLE_NAME: props.eventsTable.tableName,\n      },\n      ...props.lambdaProps,\n    });\n\n    this.artifactQueryFunction = new lambda.Function(this, 'ArtifactQueryFunction', {\n      runtime: lambda.Runtime.NODEJS_20_X,\n      functionName: 'turbo-remote-cache-artifact-query',\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(path.join(__dirname, '../lambda/dist/artifact-query')),\n      environment: {\n        EVENTS_TABLE_NAME: props.eventsTable.tableName,\n      },\n      ...props.lambdaProps,\n    });\n\n    this.statusFunction = new lambda.Function(this, 'StatusFunction', {\n      runtime: lambda.Runtime.NODEJS_20_X,\n      functionName: 'turbo-remote-cache-status',\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(path.join(__dirname, '../lambda/dist/status')),\n      environment: {\n        BUCKET_NAME: props.artifactsBucket.bucketName,\n      },\n      ...props.lambdaProps,\n    });\n\n    if (props.authorizerFunction) {\n      this.authorizerFunction = props.authorizerFunction;\n    } else {\n      this.authorizerFunction = new lambda.Function(this, 'TokenAuthorizerFunction', {\n        runtime: lambda.Runtime.NODEJS_20_X,\n        functionName: 'turbo-remote-cache-token-authorizer',\n        handler: 'index.handler',\n        code: lambda.Code.fromAsset(path.join(__dirname, '../lambda/dist/token-authorizer')),\n        environment: {\n          TURBO_TOKEN: process.env.TURBO_TOKEN!,\n        },\n        ...props.lambdaProps,\n      });\n    }\n\n    if (props.userInfoFunction) {\n      this.getUserInfoFunction = props.userInfoFunction;\n    } else {\n      this.getUserInfoFunction = new lambda.Function(this, 'GetUserInfoFunction', {\n        runtime: lambda.Runtime.NODEJS_20_X,\n        functionName: 'turbo-remote-cache-get-user-info',\n        handler: 'index.handler',\n        code: lambda.Code.fromAsset(path.join(__dirname, '../lambda/dist/get-user-info')),\n        ...props.lambdaProps,\n      });\n    }\n\n    this.preflightArtifactFunction = new lambda.Function(this, 'PreflightArtifactFunction', {\n      runtime: lambda.Runtime.NODEJS_20_X,\n      functionName: 'turbo-remote-cache-preflight-artifact',\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(path.join(__dirname, '../lambda/dist/preflight-artifact')),\n      environment: {\n        ARTIFACTS_BUCKET: props.artifactsBucket.bucketName,\n      },\n    });\n\n    // turbo login\n    // TODO: implement lambda authorizer to validate third party JWT\n    // this.initiateLoginFunction = new lambda.Function(this, 'InitiateLoginFunction', {\n    //   runtime: lambda.Runtime.NODEJS_20_X,\n    //   functionName: 'turbo-remote-cache-initiate-login',\n    //   handler: 'index.handler',\n    //   code: lambda.Code.fromAsset(path.join(__dirname, '../lambda/dist/initiate-login')),\n    //   environment: {\n    //     TURBO_TOKEN: process.env.TURBO_TOKEN!,\n    //   },\n    //   ...props.lambdaProps,\n    // });\n\n    // this.loginSuccessFunction = new lambda.Function(this, 'LoginSuccessFunction', {\n    //   runtime: lambda.Runtime.NODEJS_20_X,\n    //   functionName: 'turbo-remote-cache-login-success',\n    //   handler: 'index.handler',\n    //   code: lambda.Code.fromAsset(path.join(__dirname, '../lambda/dist/login-success')),\n    //   environment: {\n    //     TURBO_TOKEN: process.env.TURBO_TOKEN!,\n    //   },\n    //   ...props.lambdaProps,\n    // });\n\n    props.artifactsBucket.grantRead(this.artifactQueryFunction);\n    props.artifactsBucket.grantReadWrite(this.recordEventsFunction);\n    props.artifactsBucket.grantRead(this.statusFunction);\n\n    // Grant permissions\n    props.eventsTable.grantReadWriteData(this.recordEventsFunction);\n    props.eventsTable.grantReadData(this.artifactQueryFunction);\n\n    props.artifactsBucket.grantReadWrite(this.preflightArtifactFunction);\n  }\n}"]}