UNPKG

@aws-cdk/aws-ecs

Version:

The CDK Construct Library for AWS::ECS

276 lines 35.3 kB
"use strict"; var _a, _b, _c; Object.defineProperty(exports, "__esModule", { value: true }); exports.BottleRocketImage = exports.BottlerocketEcsVariant = exports.EcsOptimizedImage = exports.EcsOptimizedAmi = exports.WindowsOptimizedVersion = exports.AmiHardwareType = void 0; const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const ec2 = require("@aws-cdk/aws-ec2"); const ssm = require("@aws-cdk/aws-ssm"); /** * The ECS-optimized AMI variant to use. For more information, see * [Amazon ECS-optimized AMIs](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-optimized_AMI.html). */ var AmiHardwareType; (function (AmiHardwareType) { /** * Use the standard Amazon ECS-optimized AMI. */ AmiHardwareType["STANDARD"] = "Standard"; /** * Use the Amazon ECS GPU-optimized AMI. */ AmiHardwareType["GPU"] = "GPU"; /** * Use the Amazon ECS-optimized Amazon Linux 2 (arm64) AMI. */ AmiHardwareType["ARM"] = "ARM64"; })(AmiHardwareType = exports.AmiHardwareType || (exports.AmiHardwareType = {})); /** * ECS-optimized Windows version list */ var WindowsOptimizedVersion; (function (WindowsOptimizedVersion) { WindowsOptimizedVersion["SERVER_2019"] = "2019"; WindowsOptimizedVersion["SERVER_2016"] = "2016"; })(WindowsOptimizedVersion = exports.WindowsOptimizedVersion || (exports.WindowsOptimizedVersion = {})); /* * TODO:v2.0.0 remove EcsOptimizedAmi */ /** * Construct a Linux or Windows machine image from the latest ECS Optimized AMI published in SSM * * @deprecated see {@link EcsOptimizedImage#amazonLinux}, {@link EcsOptimizedImage#amazonLinux} and {@link EcsOptimizedImage#windows} */ class EcsOptimizedAmi { /** * Constructs a new instance of the EcsOptimizedAmi class. */ constructor(props) { try { jsiiDeprecationWarnings.print("@aws-cdk/aws-ecs.EcsOptimizedAmi", "see {@link EcsOptimizedImage#amazonLinux}, {@link EcsOptimizedImage#amazonLinux} and {@link EcsOptimizedImage#windows}"); jsiiDeprecationWarnings._aws_cdk_aws_ecs_EcsOptimizedAmiProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, EcsOptimizedAmi); } throw error; } this.hwType = (props && props.hardwareType) || AmiHardwareType.STANDARD; if (props && props.generation) { // generation defined in the props object if (props.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX && this.hwType !== AmiHardwareType.STANDARD) { throw new Error('Amazon Linux does not support special hardware type. Use Amazon Linux 2 instead'); } else if (props.windowsVersion) { throw new Error('"windowsVersion" and Linux image "generation" cannot be both set'); } else { this.generation = props.generation; } } else if (props && props.windowsVersion) { if (this.hwType !== AmiHardwareType.STANDARD) { throw new Error('Windows Server does not support special hardware type'); } else { this.windowsVersion = props.windowsVersion; } } else { // generation not defined in props object // always default to Amazon Linux v2 regardless of HW this.generation = ec2.AmazonLinuxGeneration.AMAZON_LINUX_2; } // set the SSM parameter name this.amiParameterName = '/aws/service/ecs/optimized-ami/' + (this.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX ? 'amazon-linux/' : '') + (this.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX_2 ? 'amazon-linux-2/' : '') + (this.windowsVersion ? `windows_server/${this.windowsVersion}/english/full/` : '') + (this.hwType === AmiHardwareType.GPU ? 'gpu/' : '') + (this.hwType === AmiHardwareType.ARM ? 'arm64/' : '') + 'recommended/image_id'; this.cachedInContext = props?.cachedInContext ?? false; } /** * Return the correct image */ getImage(scope) { try { jsiiDeprecationWarnings.print("@aws-cdk/aws-ecs.EcsOptimizedAmi#getImage", "see {@link EcsOptimizedImage#amazonLinux}, {@link EcsOptimizedImage#amazonLinux} and {@link EcsOptimizedImage#windows}"); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.getImage); } throw error; } const ami = lookupImage(scope, this.cachedInContext, this.amiParameterName); const osType = this.windowsVersion ? ec2.OperatingSystemType.WINDOWS : ec2.OperatingSystemType.LINUX; return { imageId: ami, osType, userData: ec2.UserData.forOperatingSystem(osType), }; } } exports.EcsOptimizedAmi = EcsOptimizedAmi; _a = JSII_RTTI_SYMBOL_1; EcsOptimizedAmi[_a] = { fqn: "@aws-cdk/aws-ecs.EcsOptimizedAmi", version: "1.204.0" }; /** * Construct a Linux or Windows machine image from the latest ECS Optimized AMI published in SSM */ class EcsOptimizedImage { /** * Constructs a new instance of the EcsOptimizedAmi class. */ constructor(props) { this.hwType = props && props.hardwareType; if (props.windowsVersion) { this.windowsVersion = props.windowsVersion; } else if (props.generation) { this.generation = props.generation; } else { throw new Error('This error should never be thrown'); } // set the SSM parameter name this.amiParameterName = '/aws/service/ecs/optimized-ami/' + (this.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX ? 'amazon-linux/' : '') + (this.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX_2 ? 'amazon-linux-2/' : '') + (this.windowsVersion ? `windows_server/${this.windowsVersion}/english/full/` : '') + (this.hwType === AmiHardwareType.GPU ? 'gpu/' : '') + (this.hwType === AmiHardwareType.ARM ? 'arm64/' : '') + 'recommended/image_id'; this.cachedInContext = props?.cachedInContext ?? false; } /** * Construct an Amazon Linux 2 image from the latest ECS Optimized AMI published in SSM * * @param hardwareType ECS-optimized AMI variant to use */ static amazonLinux2(hardwareType = AmiHardwareType.STANDARD, options = {}) { try { jsiiDeprecationWarnings._aws_cdk_aws_ecs_AmiHardwareType(hardwareType); jsiiDeprecationWarnings._aws_cdk_aws_ecs_EcsOptimizedImageOptions(options); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.amazonLinux2); } throw error; } return new EcsOptimizedImage({ generation: ec2.AmazonLinuxGeneration.AMAZON_LINUX_2, hardwareType, cachedInContext: options.cachedInContext, }); } /** * Construct an Amazon Linux AMI image from the latest ECS Optimized AMI published in SSM */ static amazonLinux(options = {}) { try { jsiiDeprecationWarnings._aws_cdk_aws_ecs_EcsOptimizedImageOptions(options); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.amazonLinux); } throw error; } return new EcsOptimizedImage({ generation: ec2.AmazonLinuxGeneration.AMAZON_LINUX, cachedInContext: options.cachedInContext, }); } /** * Construct a Windows image from the latest ECS Optimized AMI published in SSM * * @param windowsVersion Windows Version to use */ static windows(windowsVersion, options = {}) { try { jsiiDeprecationWarnings._aws_cdk_aws_ecs_WindowsOptimizedVersion(windowsVersion); jsiiDeprecationWarnings._aws_cdk_aws_ecs_EcsOptimizedImageOptions(options); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.windows); } throw error; } return new EcsOptimizedImage({ windowsVersion, cachedInContext: options.cachedInContext, }); } /** * Return the correct image */ getImage(scope) { const ami = lookupImage(scope, this.cachedInContext, this.amiParameterName); const osType = this.windowsVersion ? ec2.OperatingSystemType.WINDOWS : ec2.OperatingSystemType.LINUX; return { imageId: ami, osType, userData: ec2.UserData.forOperatingSystem(osType), }; } } exports.EcsOptimizedImage = EcsOptimizedImage; _b = JSII_RTTI_SYMBOL_1; EcsOptimizedImage[_b] = { fqn: "@aws-cdk/aws-ecs.EcsOptimizedImage", version: "1.204.0" }; /** * Amazon ECS variant */ var BottlerocketEcsVariant; (function (BottlerocketEcsVariant) { /** * aws-ecs-1 variant */ BottlerocketEcsVariant["AWS_ECS_1"] = "aws-ecs-1"; })(BottlerocketEcsVariant = exports.BottlerocketEcsVariant || (exports.BottlerocketEcsVariant = {})); /** * Construct an Bottlerocket image from the latest AMI published in SSM */ class BottleRocketImage { /** * Constructs a new instance of the BottleRocketImage class. */ constructor(props = {}) { try { jsiiDeprecationWarnings._aws_cdk_aws_ecs_BottleRocketImageProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, BottleRocketImage); } throw error; } this.variant = props.variant ?? BottlerocketEcsVariant.AWS_ECS_1; this.architecture = props.architecture ?? ec2.InstanceArchitecture.X86_64; // set the SSM parameter name this.amiParameterName = `/aws/service/bottlerocket/${this.variant}/${this.architecture}/latest/image_id`; this.cachedInContext = props.cachedInContext ?? false; } /** * Return the correct image */ getImage(scope) { const ami = lookupImage(scope, this.cachedInContext, this.amiParameterName); return { imageId: ami, osType: ec2.OperatingSystemType.LINUX, userData: ec2.UserData.custom(''), }; } } exports.BottleRocketImage = BottleRocketImage; _c = JSII_RTTI_SYMBOL_1; BottleRocketImage[_c] = { fqn: "@aws-cdk/aws-ecs.BottleRocketImage", version: "1.204.0" }; function lookupImage(scope, cachedInContext, parameterName) { return cachedInContext ? ssm.StringParameter.valueFromLookup(scope, parameterName) : ssm.StringParameter.valueForTypedStringParameter(scope, parameterName, ssm.ParameterType.AWS_EC2_IMAGE_ID); } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"amis.js","sourceRoot":"","sources":["amis.ts"],"names":[],"mappings":"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","sourcesContent":["import * as ec2 from '@aws-cdk/aws-ec2';\nimport * as ssm from '@aws-cdk/aws-ssm';\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 '@aws-cdk/core';\n\n/**\n * The ECS-optimized AMI variant to use. For more information, see\n * [Amazon ECS-optimized AMIs](https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-optimized_AMI.html).\n */\nexport enum AmiHardwareType {\n\n  /**\n   * Use the standard Amazon ECS-optimized AMI.\n   */\n  STANDARD = 'Standard',\n\n  /**\n   * Use the Amazon ECS GPU-optimized AMI.\n   */\n  GPU = 'GPU',\n\n  /**\n   * Use the Amazon ECS-optimized Amazon Linux 2 (arm64) AMI.\n   */\n  ARM = 'ARM64',\n}\n\n\n/**\n * ECS-optimized Windows version list\n */\nexport enum WindowsOptimizedVersion {\n  SERVER_2019 = '2019',\n  SERVER_2016 = '2016',\n}\n\n/*\n * TODO:v2.0.0\n *  * remove `export` keyword\n *  * remove @deprecated\n */\n/**\n * The properties that define which ECS-optimized AMI is used.\n *\n * @deprecated see {@link EcsOptimizedImage}\n */\nexport interface EcsOptimizedAmiProps {\n  /**\n   * The Amazon Linux generation to use.\n   *\n   * @default AmazonLinuxGeneration.AmazonLinux2\n   */\n  readonly generation?: ec2.AmazonLinuxGeneration;\n\n  /**\n   * The Windows Server version to use.\n   *\n   * @default none, uses Linux generation\n   */\n  readonly windowsVersion?: WindowsOptimizedVersion;\n\n  /**\n   * The ECS-optimized AMI variant to use.\n   *\n   * @default AmiHardwareType.Standard\n   */\n  readonly hardwareType?: AmiHardwareType;\n\n  /**\n   * Whether the AMI ID is cached to be stable between deployments\n   *\n   * By default, the newest image is used on each deployment. This will cause\n   * instances to be replaced whenever a new version is released, and may cause\n   * downtime if there aren't enough running instances in the AutoScalingGroup\n   * to reschedule the tasks on.\n   *\n   * If set to true, the AMI ID will be cached in `cdk.context.json` and the\n   * same value will be used on future runs. Your instances will not be replaced\n   * but your AMI version will grow old over time. To refresh the AMI lookup,\n   * you will have to evict the value from the cache using the `cdk context`\n   * command. See https://docs.aws.amazon.com/cdk/latest/guide/context.html for\n   * more information.\n   *\n   * Can not be set to `true` in environment-agnostic stacks.\n   *\n   * @default false\n   */\n  readonly cachedInContext?: boolean;\n}\n\n/*\n * TODO:v2.0.0 remove EcsOptimizedAmi\n */\n/**\n * Construct a Linux or Windows machine image from the latest ECS Optimized AMI published in SSM\n *\n * @deprecated see {@link EcsOptimizedImage#amazonLinux}, {@link EcsOptimizedImage#amazonLinux} and {@link EcsOptimizedImage#windows}\n */\nexport class EcsOptimizedAmi implements ec2.IMachineImage {\n  private readonly generation?: ec2.AmazonLinuxGeneration;\n  private readonly windowsVersion?: WindowsOptimizedVersion;\n  private readonly hwType: AmiHardwareType;\n\n  private readonly amiParameterName: string;\n  private readonly cachedInContext: boolean;\n\n  /**\n   * Constructs a new instance of the EcsOptimizedAmi class.\n   */\n  constructor(props?: EcsOptimizedAmiProps) {\n    this.hwType = (props && props.hardwareType) || AmiHardwareType.STANDARD;\n    if (props && props.generation) { // generation defined in the props object\n      if (props.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX && this.hwType !== AmiHardwareType.STANDARD) {\n        throw new Error('Amazon Linux does not support special hardware type. Use Amazon Linux 2 instead');\n      } else if (props.windowsVersion) {\n        throw new Error('\"windowsVersion\" and Linux image \"generation\" cannot be both set');\n      } else {\n        this.generation = props.generation;\n      }\n    } else if (props && props.windowsVersion) {\n      if (this.hwType !== AmiHardwareType.STANDARD) {\n        throw new Error('Windows Server does not support special hardware type');\n      } else {\n        this.windowsVersion = props.windowsVersion;\n      }\n    } else { // generation not defined in props object\n      // always default to Amazon Linux v2 regardless of HW\n      this.generation = ec2.AmazonLinuxGeneration.AMAZON_LINUX_2;\n    }\n\n    // set the SSM parameter name\n    this.amiParameterName = '/aws/service/ecs/optimized-ami/'\n      + (this.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX ? 'amazon-linux/' : '')\n      + (this.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX_2 ? 'amazon-linux-2/' : '')\n      + (this.windowsVersion ? `windows_server/${this.windowsVersion}/english/full/` : '')\n      + (this.hwType === AmiHardwareType.GPU ? 'gpu/' : '')\n      + (this.hwType === AmiHardwareType.ARM ? 'arm64/' : '')\n      + 'recommended/image_id';\n\n    this.cachedInContext = props?.cachedInContext ?? false;\n  }\n\n  /**\n   * Return the correct image\n   */\n  public getImage(scope: CoreConstruct): ec2.MachineImageConfig {\n    const ami = lookupImage(scope, this.cachedInContext, this.amiParameterName);\n\n    const osType = this.windowsVersion ? ec2.OperatingSystemType.WINDOWS : ec2.OperatingSystemType.LINUX;\n    return {\n      imageId: ami,\n      osType,\n      userData: ec2.UserData.forOperatingSystem(osType),\n    };\n  }\n}\n\n/**\n * Additional configuration properties for EcsOptimizedImage factory functions\n */\nexport interface EcsOptimizedImageOptions {\n  /**\n   * Whether the AMI ID is cached to be stable between deployments\n   *\n   * By default, the newest image is used on each deployment. This will cause\n   * instances to be replaced whenever a new version is released, and may cause\n   * downtime if there aren't enough running instances in the AutoScalingGroup\n   * to reschedule the tasks on.\n   *\n   * If set to true, the AMI ID will be cached in `cdk.context.json` and the\n   * same value will be used on future runs. Your instances will not be replaced\n   * but your AMI version will grow old over time. To refresh the AMI lookup,\n   * you will have to evict the value from the cache using the `cdk context`\n   * command. See https://docs.aws.amazon.com/cdk/latest/guide/context.html for\n   * more information.\n   *\n   * Can not be set to `true` in environment-agnostic stacks.\n   *\n   * @default false\n   */\n  readonly cachedInContext?: boolean;\n}\n\n/**\n * Construct a Linux or Windows machine image from the latest ECS Optimized AMI published in SSM\n */\nexport class EcsOptimizedImage implements ec2.IMachineImage {\n  /**\n   * Construct an Amazon Linux 2 image from the latest ECS Optimized AMI published in SSM\n   *\n   * @param hardwareType ECS-optimized AMI variant to use\n   */\n  public static amazonLinux2(hardwareType = AmiHardwareType.STANDARD, options: EcsOptimizedImageOptions = {}): EcsOptimizedImage {\n    return new EcsOptimizedImage({\n      generation: ec2.AmazonLinuxGeneration.AMAZON_LINUX_2,\n      hardwareType,\n      cachedInContext: options.cachedInContext,\n    });\n  }\n\n  /**\n   * Construct an Amazon Linux AMI image from the latest ECS Optimized AMI published in SSM\n   */\n  public static amazonLinux(options: EcsOptimizedImageOptions = {}): EcsOptimizedImage {\n    return new EcsOptimizedImage({\n      generation: ec2.AmazonLinuxGeneration.AMAZON_LINUX,\n      cachedInContext: options.cachedInContext,\n    });\n  }\n\n  /**\n   * Construct a Windows image from the latest ECS Optimized AMI published in SSM\n   *\n   * @param windowsVersion Windows Version to use\n   */\n  public static windows(windowsVersion: WindowsOptimizedVersion, options: EcsOptimizedImageOptions = {}): EcsOptimizedImage {\n    return new EcsOptimizedImage({\n      windowsVersion,\n      cachedInContext: options.cachedInContext,\n    });\n  }\n\n  private readonly generation?: ec2.AmazonLinuxGeneration;\n  private readonly windowsVersion?: WindowsOptimizedVersion;\n  private readonly hwType?: AmiHardwareType;\n\n  private readonly amiParameterName: string;\n  private readonly cachedInContext: boolean;\n\n  /**\n   * Constructs a new instance of the EcsOptimizedAmi class.\n   */\n  private constructor(props: EcsOptimizedAmiProps) {\n    this.hwType = props && props.hardwareType;\n\n    if (props.windowsVersion) {\n      this.windowsVersion = props.windowsVersion;\n    } else if (props.generation) {\n      this.generation = props.generation;\n    } else {\n      throw new Error('This error should never be thrown');\n    }\n\n    // set the SSM parameter name\n    this.amiParameterName = '/aws/service/ecs/optimized-ami/'\n      + (this.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX ? 'amazon-linux/' : '')\n      + (this.generation === ec2.AmazonLinuxGeneration.AMAZON_LINUX_2 ? 'amazon-linux-2/' : '')\n      + (this.windowsVersion ? `windows_server/${this.windowsVersion}/english/full/` : '')\n      + (this.hwType === AmiHardwareType.GPU ? 'gpu/' : '')\n      + (this.hwType === AmiHardwareType.ARM ? 'arm64/' : '')\n      + 'recommended/image_id';\n\n    this.cachedInContext = props?.cachedInContext ?? false;\n  }\n\n  /**\n   * Return the correct image\n   */\n  public getImage(scope: CoreConstruct): ec2.MachineImageConfig {\n    const ami = lookupImage(scope, this.cachedInContext, this.amiParameterName);\n\n    const osType = this.windowsVersion ? ec2.OperatingSystemType.WINDOWS : ec2.OperatingSystemType.LINUX;\n    return {\n      imageId: ami,\n      osType,\n      userData: ec2.UserData.forOperatingSystem(osType),\n    };\n  }\n}\n\n/**\n * Amazon ECS variant\n */\nexport enum BottlerocketEcsVariant {\n  /**\n   * aws-ecs-1 variant\n   */\n  AWS_ECS_1 = 'aws-ecs-1'\n\n}\n\n/**\n * Properties for BottleRocketImage\n */\nexport interface BottleRocketImageProps {\n  /**\n   * The Amazon ECS variant to use.\n   * Only `aws-ecs-1` is currently available\n   *\n   * @default - BottlerocketEcsVariant.AWS_ECS_1\n   */\n  readonly variant?: BottlerocketEcsVariant;\n\n  /**\n   * The CPU architecture\n   *\n   * @default - x86_64\n   */\n  readonly architecture?: ec2.InstanceArchitecture;\n\n  /**\n   * Whether the AMI ID is cached to be stable between deployments\n   *\n   * By default, the newest image is used on each deployment. This will cause\n   * instances to be replaced whenever a new version is released, and may cause\n   * downtime if there aren't enough running instances in the AutoScalingGroup\n   * to reschedule the tasks on.\n   *\n   * If set to true, the AMI ID will be cached in `cdk.context.json` and the\n   * same value will be used on future runs. Your instances will not be replaced\n   * but your AMI version will grow old over time. To refresh the AMI lookup,\n   * you will have to evict the value from the cache using the `cdk context`\n   * command. See https://docs.aws.amazon.com/cdk/latest/guide/context.html for\n   * more information.\n   *\n   * Can not be set to `true` in environment-agnostic stacks.\n   *\n   * @default false\n   */\n  readonly cachedInContext?: boolean;\n}\n\n/**\n * Construct an Bottlerocket image from the latest AMI published in SSM\n */\nexport class BottleRocketImage implements ec2.IMachineImage {\n  private readonly amiParameterName: string;\n  /**\n   * Amazon ECS variant for Bottlerocket AMI\n   */\n  private readonly variant: string;\n\n  /**\n   * Instance architecture\n   */\n  private readonly architecture: ec2.InstanceArchitecture;\n\n  private readonly cachedInContext: boolean;\n\n  /**\n   * Constructs a new instance of the BottleRocketImage class.\n   */\n  public constructor(props: BottleRocketImageProps = {}) {\n    this.variant = props.variant ?? BottlerocketEcsVariant.AWS_ECS_1;\n    this.architecture = props.architecture ?? ec2.InstanceArchitecture.X86_64;\n\n    // set the SSM parameter name\n    this.amiParameterName = `/aws/service/bottlerocket/${this.variant}/${this.architecture}/latest/image_id`;\n\n    this.cachedInContext = props.cachedInContext ?? false;\n  }\n\n  /**\n   * Return the correct image\n   */\n  public getImage(scope: CoreConstruct): ec2.MachineImageConfig {\n    const ami = lookupImage(scope, this.cachedInContext, this.amiParameterName);\n\n    return {\n      imageId: ami,\n      osType: ec2.OperatingSystemType.LINUX,\n      userData: ec2.UserData.custom(''),\n    };\n  }\n}\n\nfunction lookupImage(scope: CoreConstruct, cachedInContext: boolean | undefined, parameterName: string) {\n  return cachedInContext\n    ? ssm.StringParameter.valueFromLookup(scope, parameterName)\n    : ssm.StringParameter.valueForTypedStringParameter(scope, parameterName, ssm.ParameterType.AWS_EC2_IMAGE_ID);\n}"]}