Socket
Socket
Sign inDemoInstall

@aws-cdk/core

Package Overview
Dependencies
Maintainers
5
Versions
248
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-cdk/core - npm Package Compare versions

Comparing version 1.78.0 to 1.79.0

35

lib/bundling.js

@@ -5,2 +5,3 @@ "use strict";

const child_process_1 = require("child_process");
const crypto = require("crypto");
const fs_1 = require("./fs");

@@ -36,4 +37,10 @@ /**

const buildArgs = options.buildArgs || {};
// Image tag derived from path and build options
const tagHash = crypto.createHash('sha256').update(JSON.stringify({
path,
...options,
})).digest('hex');
const tag = `cdk-${tagHash}`;
const dockerArgs = [
'build', '-q',
'build', '-t', tag,
...(options.file ? ['-f', options.file] : []),

@@ -43,7 +50,3 @@ ...flatten(Object.entries(buildArgs).map(([k, v]) => ['--build-arg', `${k}=${v}`])),

];
const docker = dockerExec(dockerArgs);
const match = docker.stdout.toString().match(/sha256:[a-z0-9]+/);
if (!match) {
throw new Error('Failed to extract image ID from Docker build output');
}
dockerExec(dockerArgs);
// Fingerprints the directory containing the Dockerfile we're building and

@@ -55,3 +58,3 @@ // differentiates the fingerprint based on build arguments. We do this so

const hash = fs_1.FileSystem.fingerprint(path, { extraHash: JSON.stringify(options) });
return new BundlingDockerImage(match[0], hash);
return new BundlingDockerImage(tag, hash);
}

@@ -90,9 +93,3 @@ /**

];
dockerExec(dockerArgs, {
stdio: [
'ignore',
process.stderr,
'inherit',
],
});
dockerExec(dockerArgs);
}

@@ -143,3 +140,9 @@ /**

const prog = (_a = process.env.CDK_DOCKER) !== null && _a !== void 0 ? _a : 'docker';
const proc = child_process_1.spawnSync(prog, args, options);
const proc = child_process_1.spawnSync(prog, args, options !== null && options !== void 0 ? options : {
stdio: [
'ignore',
process.stderr,
'inherit',
],
});
if (proc.error) {

@@ -156,2 +159,2 @@ throw proc.error;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundling.js","sourceRoot":"","sources":["bundling.ts"],"names":[],"mappings":"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","sourcesContent":["import { spawnSync, SpawnSyncOptions } from 'child_process';\nimport { FileSystem } from './fs';\n\n                                               \nexport interface BundlingOptions {\n                                                             \n  readonly image: BundlingDockerImage;\n\n                                                                                                                                                                                                                         \n  readonly command?: string[];\n\n                                                                                                           \n  readonly volumes?: DockerVolume[];\n\n                                                                                                                          \n  readonly environment?: { [key: string]: string; };\n\n                                                                                               \n  readonly workingDirectory?: string;\n\n                                                                                                                                                                                                                                                                                   \n  readonly user?: string;\n\n                                                                                                                                                                                                                                                                                                                                 \n  readonly local?: ILocalBundling;\n}\n\n                                             \nexport interface ILocalBundling {\n                                                                                                                                                                                                                                                                                                                                                                                \n  tryBundle(outputDir: string, options: BundlingOptions): boolean;\n}\n\n                                                 \nexport class BundlingDockerImage {\n                                                                                                                  \n  public static fromRegistry(image: string) {\n    return new BundlingDockerImage(image);\n  }\n\n                                                                                                                                                                                                   \n  public static fromAsset(path: string, options: DockerBuildOptions = {}) {\n    const buildArgs = options.buildArgs || {};\n\n    const dockerArgs: string[] = [\n      'build', '-q',\n      ...(options.file ? ['-f', options.file] : []),\n      ...flatten(Object.entries(buildArgs).map(([k, v]) => ['--build-arg', `${k}=${v}`])),\n      path,\n    ];\n\n    const docker = dockerExec(dockerArgs);\n\n    const match = docker.stdout.toString().match(/sha256:[a-z0-9]+/);\n\n    if (!match) {\n      throw new Error('Failed to extract image ID from Docker build output');\n    }\n\n    // Fingerprints the directory containing the Dockerfile we're building and\n    // differentiates the fingerprint based on build arguments. We do this so\n    // we can provide a stable image hash. Otherwise, the image ID will be\n    // different every time the Docker layer cache is cleared, due primarily to\n    // timestamps.\n    const hash = FileSystem.fingerprint(path, { extraHash: JSON.stringify(options) });\n    return new BundlingDockerImage(match[0], hash);\n  }\n\n  /** @param image The Docker image */\n  private constructor(public readonly image: string, private readonly _imageHash?: string) {}\n\n                                                                                                                                                                           \n  public toJSON() {\n    return this._imageHash ?? this.image;\n  }\n\n                                    \n  public run(options: DockerRunOptions = {}) {\n    const volumes = options.volumes || [];\n    const environment = options.environment || {};\n    const command = options.command || [];\n\n    const dockerArgs: string[] = [\n      'run', '--rm',\n      ...options.user\n        ? ['-u', options.user]\n        : [],\n      ...flatten(volumes.map(v => ['-v', `${v.hostPath}:${v.containerPath}:${v.consistency ?? DockerVolumeConsistency.DELEGATED}`])),\n      ...flatten(Object.entries(environment).map(([k, v]) => ['--env', `${k}=${v}`])),\n      ...options.workingDirectory\n        ? ['-w', options.workingDirectory]\n        : [],\n      this.image,\n      ...command,\n    ];\n\n    dockerExec(dockerArgs, {\n      stdio: [ // show Docker output\n        'ignore', // ignore stdio\n        process.stderr, // redirect stdout to stderr\n        'inherit', // inherit stderr\n      ],\n    });\n  }\n\n                                                                                           \n  public cp(imagePath: string, outputPath: string) {\n    const { stdout } = dockerExec(['create', this.image]);\n    const match = stdout.toString().match(/([0-9a-f]{16,})/);\n    if (!match) {\n      throw new Error('Failed to extract container ID from Docker create output');\n    }\n\n    const containerId = match[1];\n    const containerPath = `${containerId}:${imagePath}`;\n    try {\n      dockerExec(['cp', containerPath, outputPath]);\n    } catch (err) {\n      throw new Error(`Failed to copy files from ${containerPath} to ${outputPath}: ${err}`);\n    } finally {\n      dockerExec(['rm', '-v', containerId]);\n    }\n  }\n}\n\n                          \nexport interface DockerVolume {\n                                                                      \n  readonly hostPath: string;\n\n                                                                                 \n  readonly containerPath: string;\n\n                                                                                                                                                                                                         \n  readonly consistency?: DockerVolumeConsistency;\n}\n\n                                                                                                                  \nexport enum DockerVolumeConsistency {\n                                                                                                                              \n  CONSISTENT = 'consistent',\n                                                                                                                                                 \n  DELEGATED = 'delegated',\n                                                                                                                                             \n  CACHED = 'cached',\n}\n\n                             \nexport interface DockerRunOptions {\n                                                                                                               \n  readonly command?: string[];\n\n                                                                                     \n  readonly volumes?: DockerVolume[];\n\n                                                                                                                   \n  readonly environment?: { [key: string]: string; };\n\n                                                                                           \n  readonly workingDirectory?: string;\n\n                                                                                                       \n  readonly user?: string;\n}\n\n                               \nexport interface DockerBuildOptions {\n                                                              \n  readonly buildArgs?: { [key: string]: string };\n\n                                                                                                                     \n  readonly file?: string;\n}\n\nfunction flatten(x: string[][]) {\n  return Array.prototype.concat([], ...x);\n}\n\nfunction dockerExec(args: string[], options?: SpawnSyncOptions) {\n  const prog = process.env.CDK_DOCKER ?? 'docker';\n  const proc = spawnSync(prog, args, options);\n\n  if (proc.error) {\n    throw proc.error;\n  }\n\n  if (proc.status !== 0) {\n    if (proc.stdout || proc.stderr) {\n      throw new Error(`[Status ${proc.status}] stdout: ${proc.stdout?.toString().trim()}\\n\\n\\nstderr: ${proc.stderr?.toString().trim()}`);\n    }\n    throw new Error(`${prog} exited with status ${proc.status}`);\n  }\n\n  return proc;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundling.js","sourceRoot":"","sources":["bundling.ts"],"names":[],"mappings":"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","sourcesContent":["import { spawnSync, SpawnSyncOptions } from 'child_process';\nimport * as crypto from 'crypto';\nimport { FileSystem } from './fs';\n\n                                               \nexport interface BundlingOptions {\n                                                             \n  readonly image: BundlingDockerImage;\n\n                                                                                                                                                                                                                         \n  readonly command?: string[];\n\n                                                                                                           \n  readonly volumes?: DockerVolume[];\n\n                                                                                                                          \n  readonly environment?: { [key: string]: string; };\n\n                                                                                               \n  readonly workingDirectory?: string;\n\n                                                                                                                                                                                                                                                                                   \n  readonly user?: string;\n\n                                                                                                                                                                                                                                                                                                                                 \n  readonly local?: ILocalBundling;\n}\n\n                                             \nexport interface ILocalBundling {\n                                                                                                                                                                                                                                                                                                                                                                                \n  tryBundle(outputDir: string, options: BundlingOptions): boolean;\n}\n\n                                                 \nexport class BundlingDockerImage {\n                                                                                                                  \n  public static fromRegistry(image: string) {\n    return new BundlingDockerImage(image);\n  }\n\n                                                                                                                                                                                                   \n  public static fromAsset(path: string, options: DockerBuildOptions = {}) {\n    const buildArgs = options.buildArgs || {};\n\n    // Image tag derived from path and build options\n    const tagHash = crypto.createHash('sha256').update(JSON.stringify({\n      path,\n      ...options,\n    })).digest('hex');\n    const tag = `cdk-${tagHash}`;\n\n    const dockerArgs: string[] = [\n      'build', '-t', tag,\n      ...(options.file ? ['-f', options.file] : []),\n      ...flatten(Object.entries(buildArgs).map(([k, v]) => ['--build-arg', `${k}=${v}`])),\n      path,\n    ];\n\n    dockerExec(dockerArgs);\n\n    // Fingerprints the directory containing the Dockerfile we're building and\n    // differentiates the fingerprint based on build arguments. We do this so\n    // we can provide a stable image hash. Otherwise, the image ID will be\n    // different every time the Docker layer cache is cleared, due primarily to\n    // timestamps.\n    const hash = FileSystem.fingerprint(path, { extraHash: JSON.stringify(options) });\n    return new BundlingDockerImage(tag, hash);\n  }\n\n  /** @param image The Docker image */\n  private constructor(public readonly image: string, private readonly _imageHash?: string) {}\n\n                                                                                                                                                                           \n  public toJSON() {\n    return this._imageHash ?? this.image;\n  }\n\n                                    \n  public run(options: DockerRunOptions = {}) {\n    const volumes = options.volumes || [];\n    const environment = options.environment || {};\n    const command = options.command || [];\n\n    const dockerArgs: string[] = [\n      'run', '--rm',\n      ...options.user\n        ? ['-u', options.user]\n        : [],\n      ...flatten(volumes.map(v => ['-v', `${v.hostPath}:${v.containerPath}:${v.consistency ?? DockerVolumeConsistency.DELEGATED}`])),\n      ...flatten(Object.entries(environment).map(([k, v]) => ['--env', `${k}=${v}`])),\n      ...options.workingDirectory\n        ? ['-w', options.workingDirectory]\n        : [],\n      this.image,\n      ...command,\n    ];\n\n    dockerExec(dockerArgs);\n  }\n\n                                                                                           \n  public cp(imagePath: string, outputPath: string) {\n    const { stdout } = dockerExec(['create', this.image]);\n    const match = stdout.toString().match(/([0-9a-f]{16,})/);\n    if (!match) {\n      throw new Error('Failed to extract container ID from Docker create output');\n    }\n\n    const containerId = match[1];\n    const containerPath = `${containerId}:${imagePath}`;\n    try {\n      dockerExec(['cp', containerPath, outputPath]);\n    } catch (err) {\n      throw new Error(`Failed to copy files from ${containerPath} to ${outputPath}: ${err}`);\n    } finally {\n      dockerExec(['rm', '-v', containerId]);\n    }\n  }\n}\n\n                          \nexport interface DockerVolume {\n                                                                      \n  readonly hostPath: string;\n\n                                                                                 \n  readonly containerPath: string;\n\n                                                                                                                                                                                                         \n  readonly consistency?: DockerVolumeConsistency;\n}\n\n                                                                                                                  \nexport enum DockerVolumeConsistency {\n                                                                                                                              \n  CONSISTENT = 'consistent',\n                                                                                                                                                 \n  DELEGATED = 'delegated',\n                                                                                                                                             \n  CACHED = 'cached',\n}\n\n                             \nexport interface DockerRunOptions {\n                                                                                                               \n  readonly command?: string[];\n\n                                                                                     \n  readonly volumes?: DockerVolume[];\n\n                                                                                                                   \n  readonly environment?: { [key: string]: string; };\n\n                                                                                           \n  readonly workingDirectory?: string;\n\n                                                                                                       \n  readonly user?: string;\n}\n\n                               \nexport interface DockerBuildOptions {\n                                                              \n  readonly buildArgs?: { [key: string]: string };\n\n                                                                                                                     \n  readonly file?: string;\n}\n\nfunction flatten(x: string[][]) {\n  return Array.prototype.concat([], ...x);\n}\n\nfunction dockerExec(args: string[], options?: SpawnSyncOptions) {\n  const prog = process.env.CDK_DOCKER ?? 'docker';\n  const proc = spawnSync(prog, args, options ?? {\n    stdio: [ // show Docker output\n      'ignore', // ignore stdio\n      process.stderr, // redirect stdout to stderr\n      'inherit', // inherit stderr\n    ],\n  });\n\n  if (proc.error) {\n    throw proc.error;\n  }\n\n  if (proc.status !== 0) {\n    if (proc.stdout || proc.stderr) {\n      throw new Error(`[Status ${proc.status}] stdout: ${proc.stdout?.toString().trim()}\\n\\n\\nstderr: ${proc.stderr?.toString().trim()}`);\n    }\n    throw new Error(`${prog} exited with status ${proc.status}`);\n  }\n\n  return proc;\n}\n"]}

@@ -97,2 +97,13 @@ import { Construct } from 'constructs';

/**
* (experimental) Returns a stack-level singleton for the custom resource provider.
*
* @param scope Construct scope.
* @param uniqueid A globally unique id that will be used for the stack-level construct.
* @param props Provider properties which will only be applied when the provider is first created.
* @returns the service token of the custom resource provider, which should be
* used when defining a `CustomResource`.
* @experimental
*/
static getOrCreateProvider(scope: Construct, uniqueid: string, props: CustomResourceProviderProps): CustomResourceProvider;
/**
* (experimental) The ARN of the provider's AWS Lambda function which should be used as the `serviceToken` when defining a custom resource.

@@ -110,6 +121,12 @@ *

/**
* (experimental) The ARN of the provider's AWS Lambda function role.
*
* @experimental
*/
readonly roleArn: string;
/**
* @experimental
*/
protected constructor(scope: Construct, id: string, props: CustomResourceProviderProps);
private renderEnvironmentVariables;
}

@@ -76,2 +76,3 @@ "use strict";

});
this.roleArn = token_1.Token.asString(role.getAtt('Arn'));
const timeout = (_a = props.timeout) !== null && _a !== void 0 ? _a : duration_1.Duration.minutes(15);

@@ -108,2 +109,15 @@ const memory = (_b = props.memorySize) !== null && _b !== void 0 ? _b : size_1.Size.mebibytes(128);

static getOrCreate(scope, uniqueid, props) {
return this.getOrCreateProvider(scope, uniqueid, props).serviceToken;
}
/**
* (experimental) Returns a stack-level singleton for the custom resource provider.
*
* @param scope Construct scope.
* @param uniqueid A globally unique id that will be used for the stack-level construct.
* @param props Provider properties which will only be applied when the provider is first created.
* @returns the service token of the custom resource provider, which should be
* used when defining a `CustomResource`.
* @experimental
*/
static getOrCreateProvider(scope, uniqueid, props) {
var _a;

@@ -113,3 +127,3 @@ const id = `${uniqueid}CustomResourceProvider`;

const provider = (_a = stack.node.tryFindChild(id)) !== null && _a !== void 0 ? _a : new CustomResourceProvider(stack, id, props);
return provider.serviceToken;
return provider;
}

@@ -132,2 +146,2 @@ renderEnvironmentVariables(env) {

exports.CustomResourceProvider = CustomResourceProvider;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-resource-provider.js","sourceRoot":"","sources":["custom-resource-provider.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport { Construct } from 'constructs';\nimport { AssetStaging } from '../asset-staging';\nimport { FileAssetPackaging } from '../assets';\nimport { CfnResource } from '../cfn-resource';\nimport { Duration } from '../duration';\nimport { Size } from '../size';\nimport { Stack } from '../stack';\nimport { Token } from '../token';\n\nconst ENTRYPOINT_FILENAME = '__entrypoint__';\nconst ENTRYPOINT_NODEJS_SOURCE = path.join(__dirname, 'nodejs-entrypoint.js');\n\n// v2 - keep this import as a separate section to reduce merge conflict when forward merging with the v2 branch.\n// eslint-disable-next-line\nimport { Construct as CoreConstruct } from '../construct-compat';\n\n                                                                                      \nexport interface CustomResourceProviderProps {\n                                                                                                                                                                        \n  readonly codeDirectory: string;\n\n                                                                            \n  readonly runtime: CustomResourceProviderRuntime;\n\n                                                                                                                                                                                                                                                                          \n  readonly policyStatements?: any[];\n\n                                                                                             \n  readonly timeout?: Duration;\n\n                                                                                                                                                                                       \n  readonly memorySize?: Size;\n\n                                                                                                                        \n  readonly environment?: { [key: string]: string };\n}\n\n/**\n * The lambda runtime to use for the resource provider. This also indicates\n * which language is used for the handler.\n * @experimental\n */\nexport enum CustomResourceProviderRuntime {\n                             \n  NODEJS_12 = 'nodejs12'\n}\n\n                                                                             \nexport class CustomResourceProvider extends CoreConstruct {\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         \n  public static getOrCreate(scope: Construct, uniqueid: string, props: CustomResourceProviderProps) {\n    const id = `${uniqueid}CustomResourceProvider`;\n    const stack = Stack.of(scope);\n    const provider = stack.node.tryFindChild(id) as CustomResourceProvider\n      ?? new CustomResourceProvider(stack, id, props);\n\n    return provider.serviceToken;\n  }\n\n                                                                                                                                                                                                                                                                                                                    \n  public readonly serviceToken: string;\n\n  protected constructor(scope: Construct, id: string, props: CustomResourceProviderProps) {\n    super(scope, id);\n\n    const stack = Stack.of(scope);\n\n    // copy the entry point to the code directory\n    fs.copyFileSync(ENTRYPOINT_NODEJS_SOURCE, path.join(props.codeDirectory, `${ENTRYPOINT_FILENAME}.js`));\n\n    // verify we have an index file there\n    if (!fs.existsSync(path.join(props.codeDirectory, 'index.js'))) {\n      throw new Error(`cannot find ${props.codeDirectory}/index.js`);\n    }\n\n    const staging = new AssetStaging(this, 'Staging', {\n      sourcePath: props.codeDirectory,\n    });\n\n    const asset = stack.addFileAsset({\n      fileName: staging.relativeStagedPath(stack),\n      sourceHash: staging.sourceHash,\n      packaging: FileAssetPackaging.ZIP_DIRECTORY,\n    });\n\n    const policies = !props.policyStatements ? undefined : [\n      {\n        PolicyName: 'Inline',\n        PolicyDocument: {\n          Version: '2012-10-17',\n          Statement: props.policyStatements,\n        },\n      },\n    ];\n\n    const role = new CfnResource(this, 'Role', {\n      type: 'AWS::IAM::Role',\n      properties: {\n        AssumeRolePolicyDocument: {\n          Version: '2012-10-17',\n          Statement: [{ Action: 'sts:AssumeRole', Effect: 'Allow', Principal: { Service: 'lambda.amazonaws.com' } }],\n        },\n        ManagedPolicyArns: [\n          { 'Fn::Sub': 'arn:${AWS::Partition}:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole' },\n        ],\n        Policies: policies,\n      },\n    });\n\n    const timeout = props.timeout ?? Duration.minutes(15);\n    const memory = props.memorySize ?? Size.mebibytes(128);\n\n    const handler = new CfnResource(this, 'Handler', {\n      type: 'AWS::Lambda::Function',\n      properties: {\n        Code: {\n          S3Bucket: asset.bucketName,\n          S3Key: asset.objectKey,\n        },\n        Timeout: timeout.toSeconds(),\n        MemorySize: memory.toMebibytes(),\n        Handler: `${ENTRYPOINT_FILENAME}.handler`,\n        Role: role.getAtt('Arn'),\n        Runtime: 'nodejs12.x',\n        Environment: this.renderEnvironmentVariables(props.environment),\n      },\n    });\n\n    handler.addDependsOn(role);\n\n    this.serviceToken = Token.asString(handler.getAtt('Arn'));\n  }\n\n  private renderEnvironmentVariables(env?: { [key: string]: string }) {\n    if (!env || Object.keys(env).length === 0) {\n      return undefined;\n    }\n\n    // Sort environment so the hash of the function used to create\n    // `currentVersion` is not affected by key order (this is how lambda does\n    // it)\n    const variables: { [key: string]: string } = {};\n    const keys = Object.keys(env).sort();\n\n    for (const key of keys) {\n      variables[key] = env[key];\n    }\n\n    return { Variables: variables };\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-resource-provider.js","sourceRoot":"","sources":["custom-resource-provider.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport { Construct } from 'constructs';\nimport { AssetStaging } from '../asset-staging';\nimport { FileAssetPackaging } from '../assets';\nimport { CfnResource } from '../cfn-resource';\nimport { Duration } from '../duration';\nimport { Size } from '../size';\nimport { Stack } from '../stack';\nimport { Token } from '../token';\n\nconst ENTRYPOINT_FILENAME = '__entrypoint__';\nconst ENTRYPOINT_NODEJS_SOURCE = path.join(__dirname, 'nodejs-entrypoint.js');\n\n// v2 - keep this import as a separate section to reduce merge conflict when forward merging with the v2 branch.\n// eslint-disable-next-line\nimport { Construct as CoreConstruct } from '../construct-compat';\n\n                                                                                      \nexport interface CustomResourceProviderProps {\n                                                                                                                                                                        \n  readonly codeDirectory: string;\n\n                                                                            \n  readonly runtime: CustomResourceProviderRuntime;\n\n                                                                                                                                                                                                                                                                          \n  readonly policyStatements?: any[];\n\n                                                                                             \n  readonly timeout?: Duration;\n\n                                                                                                                                                                                       \n  readonly memorySize?: Size;\n\n                                                                                                                        \n  readonly environment?: { [key: string]: string };\n}\n\n/**\n * The lambda runtime to use for the resource provider. This also indicates\n * which language is used for the handler.\n * @experimental\n */\nexport enum CustomResourceProviderRuntime {\n                             \n  NODEJS_12 = 'nodejs12'\n}\n\n                                                                             \nexport class CustomResourceProvider extends CoreConstruct {\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         \n  public static getOrCreate(scope: Construct, uniqueid: string, props: CustomResourceProviderProps) {\n    return this.getOrCreateProvider(scope, uniqueid, props).serviceToken;\n  }\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                \n  public static getOrCreateProvider(scope: Construct, uniqueid: string, props: CustomResourceProviderProps) {\n    const id = `${uniqueid}CustomResourceProvider`;\n    const stack = Stack.of(scope);\n    const provider = stack.node.tryFindChild(id) as CustomResourceProvider\n      ?? new CustomResourceProvider(stack, id, props);\n\n    return provider;\n  }\n\n                                                                                                                                                                                                                                                                                                                    \n  public readonly serviceToken: string;\n\n                                                                    \n  public readonly roleArn: string;\n\n  protected constructor(scope: Construct, id: string, props: CustomResourceProviderProps) {\n    super(scope, id);\n\n    const stack = Stack.of(scope);\n\n    // copy the entry point to the code directory\n    fs.copyFileSync(ENTRYPOINT_NODEJS_SOURCE, path.join(props.codeDirectory, `${ENTRYPOINT_FILENAME}.js`));\n\n    // verify we have an index file there\n    if (!fs.existsSync(path.join(props.codeDirectory, 'index.js'))) {\n      throw new Error(`cannot find ${props.codeDirectory}/index.js`);\n    }\n\n    const staging = new AssetStaging(this, 'Staging', {\n      sourcePath: props.codeDirectory,\n    });\n\n    const asset = stack.addFileAsset({\n      fileName: staging.relativeStagedPath(stack),\n      sourceHash: staging.sourceHash,\n      packaging: FileAssetPackaging.ZIP_DIRECTORY,\n    });\n\n    const policies = !props.policyStatements ? undefined : [\n      {\n        PolicyName: 'Inline',\n        PolicyDocument: {\n          Version: '2012-10-17',\n          Statement: props.policyStatements,\n        },\n      },\n    ];\n\n    const role = new CfnResource(this, 'Role', {\n      type: 'AWS::IAM::Role',\n      properties: {\n        AssumeRolePolicyDocument: {\n          Version: '2012-10-17',\n          Statement: [{ Action: 'sts:AssumeRole', Effect: 'Allow', Principal: { Service: 'lambda.amazonaws.com' } }],\n        },\n        ManagedPolicyArns: [\n          { 'Fn::Sub': 'arn:${AWS::Partition}:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole' },\n        ],\n        Policies: policies,\n      },\n    });\n    this.roleArn = Token.asString(role.getAtt('Arn'));\n\n    const timeout = props.timeout ?? Duration.minutes(15);\n    const memory = props.memorySize ?? Size.mebibytes(128);\n\n    const handler = new CfnResource(this, 'Handler', {\n      type: 'AWS::Lambda::Function',\n      properties: {\n        Code: {\n          S3Bucket: asset.bucketName,\n          S3Key: asset.objectKey,\n        },\n        Timeout: timeout.toSeconds(),\n        MemorySize: memory.toMebibytes(),\n        Handler: `${ENTRYPOINT_FILENAME}.handler`,\n        Role: role.getAtt('Arn'),\n        Runtime: 'nodejs12.x',\n        Environment: this.renderEnvironmentVariables(props.environment),\n      },\n    });\n\n    handler.addDependsOn(role);\n\n    this.serviceToken = Token.asString(handler.getAtt('Arn'));\n  }\n\n  private renderEnvironmentVariables(env?: { [key: string]: string }) {\n    if (!env || Object.keys(env).length === 0) {\n      return undefined;\n    }\n\n    // Sort environment so the hash of the function used to create\n    // `currentVersion` is not affected by key order (this is how lambda does\n    // it)\n    const variables: { [key: string]: string } = {};\n    const keys = Object.keys(env).sort();\n\n    for (const key of keys) {\n      variables[key] = env[key];\n    }\n\n    return { Variables: variables };\n  }\n}\n"]}
{
"name": "@aws-cdk/core",
"version": "1.78.0",
"version": "1.79.0",
"description": "AWS Cloud Development Kit Core Library",

@@ -183,8 +183,8 @@ "main": "lib/index.js",

"@types/sinon": "^9.0.9",
"cdk-build-tools": "1.78.0",
"cfn2ts": "1.78.0",
"cdk-build-tools": "1.79.0",
"cfn2ts": "1.79.0",
"fast-check": "^2.7.0",
"lodash": "^4.17.20",
"nodeunit-shim": "1.78.0",
"pkglint": "1.78.0",
"nodeunit-shim": "1.79.0",
"pkglint": "1.79.0",
"sinon": "^9.2.1",

@@ -194,5 +194,5 @@ "ts-mock-imports": "^1.3.1"

"dependencies": {
"@aws-cdk/cloud-assembly-schema": "1.78.0",
"@aws-cdk/cx-api": "1.78.0",
"@aws-cdk/region-info": "1.78.0",
"@aws-cdk/cloud-assembly-schema": "1.79.0",
"@aws-cdk/cx-api": "1.79.0",
"@aws-cdk/region-info": "1.79.0",
"@balena/dockerignore": "^1.0.2",

@@ -212,5 +212,5 @@ "constructs": "^3.2.0",

"peerDependencies": {
"@aws-cdk/cloud-assembly-schema": "1.78.0",
"@aws-cdk/cx-api": "1.78.0",
"@aws-cdk/region-info": "1.78.0",
"@aws-cdk/cloud-assembly-schema": "1.79.0",
"@aws-cdk/cx-api": "1.79.0",
"@aws-cdk/region-info": "1.79.0",
"constructs": "^3.2.0"

@@ -217,0 +217,0 @@ },

@@ -489,2 +489,16 @@ # AWS Cloud Development Kit Core Library

To access the ARN of the provider's AWS Lambda function role, use the `getOrCreateProvider()`
built-in singleton method:
```ts
const provider = CustomResourceProvider.getOrCreateProvider(this, 'Custom::MyCustomResourceType', {
codeDirectory: `${__dirname}/my-handler`,
runtime: CustomResourceProviderRuntime.NODEJS_12, // currently the only supported runtime
});
const roleArn = provider.roleArn;
```
This role ARN can then be used in resource-based IAM policies.
#### The Custom Resource Provider Framework

@@ -491,0 +505,0 @@

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc