Socket
Socket
Sign inDemoInstall

@aws-cdk/aws-ssm

Package Overview
Dependencies
Maintainers
5
Versions
288
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-cdk/aws-ssm - npm Package Compare versions

Comparing version 1.6.1 to 1.7.0

70

lib/parameter.js

@@ -39,2 +39,21 @@ "use strict";

class StringParameter extends ParameterBase {
constructor(scope, id, props) {
super(scope, id, {
physicalName: props.parameterName,
});
if (props.allowedPattern) {
_assertValidValue(props.stringValue, props.allowedPattern);
}
const resource = new ssm.CfnParameter(this, 'Resource', {
allowedPattern: props.allowedPattern,
description: props.description,
name: this.physicalName,
type: STRING_PARAM_TYPE,
value: props.stringValue,
});
this.parameterName = this.getResourceNameAttribute(resource.ref);
this.parameterArn = arnForParameterName(this, this.parameterName);
this.parameterType = resource.attrType;
this.stringValue = resource.attrValue;
}
/**

@@ -128,2 +147,9 @@ * Imports an external string parameter by name.

}
}
exports.StringParameter = StringParameter;
/**
* Creates a new StringList SSM Parameter.
* @resource AWS::SSM::Parameter
*/
class StringListParameter extends ParameterBase {
constructor(scope, id, props) {

@@ -133,5 +159,8 @@ super(scope, id, {

});
if (props.allowedPattern) {
_assertValidValue(props.stringValue, props.allowedPattern);
if (props.stringListValue.find(str => !core_1.Token.isUnresolved(str) && str.indexOf(',') !== -1)) {
throw new Error('Values of a StringList SSM Parameter cannot contain the \',\' character. Use a string parameter instead.');
}
if (props.allowedPattern && !core_1.Token.isUnresolved(props.stringListValue)) {
props.stringListValue.forEach(str => _assertValidValue(str, props.allowedPattern));
}
const resource = new ssm.CfnParameter(this, 'Resource', {

@@ -141,4 +170,4 @@ allowedPattern: props.allowedPattern,

name: this.physicalName,
type: STRING_PARAM_TYPE,
value: props.stringValue,
type: STRINGLIST_PARAM_TYPE,
value: props.stringListValue.join(','),
});

@@ -148,11 +177,4 @@ this.parameterName = this.getResourceNameAttribute(resource.ref);

this.parameterType = resource.attrType;
this.stringValue = resource.attrValue;
this.stringListValue = core_1.Fn.split(',', resource.attrValue);
}
}
exports.StringParameter = StringParameter;
/**
* Creates a new StringList SSM Parameter.
* @resource AWS::SSM::Parameter
*/
class StringListParameter extends ParameterBase {
/**

@@ -173,24 +195,2 @@ * Imports an external parameter of type string list.

}
constructor(scope, id, props) {
super(scope, id, {
physicalName: props.parameterName,
});
if (props.stringListValue.find(str => !core_1.Token.isUnresolved(str) && str.indexOf(',') !== -1)) {
throw new Error('Values of a StringList SSM Parameter cannot contain the \',\' character. Use a string parameter instead.');
}
if (props.allowedPattern && !core_1.Token.isUnresolved(props.stringListValue)) {
props.stringListValue.forEach(str => _assertValidValue(str, props.allowedPattern));
}
const resource = new ssm.CfnParameter(this, 'Resource', {
allowedPattern: props.allowedPattern,
description: props.description,
name: this.physicalName,
type: STRINGLIST_PARAM_TYPE,
value: props.stringListValue.join(','),
});
this.parameterName = this.getResourceNameAttribute(resource.ref);
this.parameterArn = arnForParameterName(this, this.parameterName);
this.parameterType = resource.attrType;
this.stringListValue = core_1.Fn.split(',', resource.attrValue);
}
}

@@ -227,2 +227,2 @@ exports.StringListParameter = StringListParameter;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parameter.js","sourceRoot":"","sources":["parameter.ts"],"names":[],"mappings":"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","sourcesContent":["import iam = require('@aws-cdk/aws-iam');\nimport {\n  CfnDynamicReference, CfnDynamicReferenceService, CfnParameter,\n  Construct, ContextProvider, Fn, IConstruct, IResource, Resource, Stack, Token\n} from '@aws-cdk/core';\nimport cxapi = require('@aws-cdk/cx-api');\nimport ssm = require('./ssm.generated');\n\n/**\n * An SSM Parameter reference.\n */\nexport interface IParameter extends IResource {\n  /**\n   * The ARN of the SSM Parameter resource.\n   * @attribute\n   */\n  readonly parameterArn: string;\n\n  /**\n   * The name of the SSM Parameter resource.\n   * @attribute\n   */\n  readonly parameterName: string;\n\n  /**\n   * The type of the SSM Parameter resource.\n   * @attribute\n   */\n  readonly parameterType: string;\n\n  /**\n   * Grants read (DescribeParameter, GetParameter, GetParameterHistory) permissions on the SSM Parameter.\n   *\n   * @param grantee the role to be granted read-only access to the parameter.\n   */\n  grantRead(grantee: iam.IGrantable): iam.Grant;\n\n  /**\n   * Grants write (PutParameter) permissions on the SSM Parameter.\n   *\n   * @param grantee the role to be granted write access to the parameter.\n   */\n  grantWrite(grantee: iam.IGrantable): iam.Grant;\n}\n\n/**\n * A String SSM Parameter.\n */\nexport interface IStringParameter extends IParameter {\n  /**\n   * The parameter value. Value must not nest another parameter. Do not use {{}} in the value.\n   *\n   * @attribute Value\n   */\n  readonly stringValue: string;\n}\n\n/**\n * A StringList SSM Parameter.\n */\nexport interface IStringListParameter extends IParameter {\n  /**\n   * The parameter value. Value must not nest another parameter. Do not use {{}} in the value. Values in the array\n   * cannot contain commas (``,``).\n   *\n   * @attribute Value\n   */\n  readonly stringListValue: string[];\n}\n\n/**\n * Properties needed to create a new SSM Parameter.\n */\nexport interface ParameterOptions {\n  /**\n   * A regular expression used to validate the parameter value. For example, for String types with values restricted to\n   * numbers, you can specify the following: ``^\\d+$``\n   *\n   * @default no validation is performed\n   */\n  readonly allowedPattern?: string;\n\n  /**\n   * Information about the parameter that you want to add to the system.\n   *\n   * @default none\n   */\n  readonly description?: string;\n\n  /**\n   * The name of the parameter.\n   *\n   * @default - a name will be generated by CloudFormation\n   */\n  readonly parameterName?: string;\n}\n\n/**\n * Properties needed to create a String SSM parameter.\n */\nexport interface StringParameterProps extends ParameterOptions {\n  /**\n   * The value of the parameter. It may not reference another parameter and ``{{}}`` cannot be used in the value.\n   */\n  readonly stringValue: string;\n}\n\n/**\n * Properties needed to create a StringList SSM Parameter\n */\nexport interface StringListParameterProps extends ParameterOptions {\n  /**\n   * The values of the parameter. It may not reference another parameter and ``{{}}`` cannot be used in the value.\n   */\n  readonly stringListValue: string[];\n}\n\n/**\n * Basic features shared across all types of SSM Parameters.\n */\nabstract class ParameterBase extends Resource implements IParameter {\n  public abstract readonly parameterArn: string;\n  public abstract readonly parameterName: string;\n  public abstract readonly parameterType: string;\n\n  public grantRead(grantee: iam.IGrantable): iam.Grant {\n    return iam.Grant.addToPrincipal({\n      grantee,\n      actions: [\n        'ssm:DescribeParameters',\n        'ssm:GetParameters',\n        'ssm:GetParameter',\n        'ssm:GetParameterHistory'\n      ],\n      resourceArns: [this.parameterArn],\n    });\n  }\n\n  public grantWrite(grantee: iam.IGrantable): iam.Grant {\n    return iam.Grant.addToPrincipal({\n      grantee,\n      actions: ['ssm:PutParameter'],\n      resourceArns: [this.parameterArn],\n    });\n  }\n}\n\nconst STRING_PARAM_TYPE = 'String';\nconst SECURE_STRING_PARAM_TYPE = 'SecureString';\nconst STRINGLIST_PARAM_TYPE = 'StringList';\n\nexport interface StringParameterAttributes {\n  /**\n   * The name of the parameter store value\n   */\n  readonly parameterName: string;\n\n  /**\n   * The version number of the value you wish to retrieve.\n   *\n   * @default The latest version will be retrieved.\n   */\n  readonly version?: number;\n}\n\nexport interface SecureStringParameterAttributes {\n  /**\n   * The name of the parameter store value\n   */\n  readonly parameterName: string;\n\n  /**\n   * The version number of the value you wish to retrieve. This is required for secure strings.\n   */\n  readonly version: number;\n}\n\n/**\n * Creates a new String SSM Parameter.\n * @resource AWS::SSM::Parameter\n */\nexport class StringParameter extends ParameterBase implements IStringParameter {\n\n  /**\n   * Imports an external string parameter by name.\n   */\n  public static fromStringParameterName(scope: Construct, id: string, stringParameterName: string): IStringParameter {\n    return this.fromStringParameterAttributes(scope, id, { parameterName: stringParameterName });\n  }\n\n  /**\n   * Imports an external string parameter with name and optional version.\n   */\n  public static fromStringParameterAttributes(scope: Construct, id: string, attrs: StringParameterAttributes): IStringParameter {\n    if (!attrs.parameterName) {\n      throw new Error(`parameterName cannot be an empty string`);\n    }\n\n    const stringValue = attrs.version\n      ? new CfnDynamicReference(CfnDynamicReferenceService.SSM, `${attrs.parameterName}:${attrs.version}`).toString()\n      : new CfnParameter(scope, `${id}.Parameter`, { type: 'AWS::SSM::Parameter::Value<String>', default: attrs.parameterName }).valueAsString;\n\n    class Import extends ParameterBase {\n      public readonly parameterName = attrs.parameterName;\n      public readonly parameterArn = arnForParameterName(this, this.parameterName);\n      public readonly parameterType = STRING_PARAM_TYPE;\n      public readonly stringValue = stringValue;\n    }\n\n    return new Import(scope, id);\n  }\n\n  /**\n   * Imports a secure string parameter from the SSM parameter store.\n   */\n  public static fromSecureStringParameterAttributes(scope: Construct, id: string, attrs: SecureStringParameterAttributes): IStringParameter {\n    const stringValue = new CfnDynamicReference(CfnDynamicReferenceService.SSM_SECURE, `${attrs.parameterName}:${attrs.version}`).toString();\n\n    class Import extends ParameterBase {\n      public readonly parameterName = attrs.parameterName;\n      public readonly parameterArn = arnForParameterName(this, this.parameterName);\n      public readonly parameterType = SECURE_STRING_PARAM_TYPE;\n      public readonly stringValue = stringValue;\n    }\n\n    return new Import(scope, id);\n  }\n\n  /**\n   * Reads the value of an SSM parameter during synthesis through an\n   * environmental context provider.\n   *\n   * Requires that the stack this scope is defined in will have explicit\n   * account/region information. Otherwise, it will fail during synthesis.\n   */\n  public static valueFromLookup(scope: Construct, parameterName: string): string {\n    const value = ContextProvider.getValue(scope, {\n      provider: cxapi.SSM_PARAMETER_PROVIDER,\n      props: { parameterName },\n      dummyValue: `dummy-value-for-${parameterName}`\n    });\n\n    return value;\n  }\n\n  /**\n   * Returns a token that will resolve (during deployment) to the string value of an SSM string parameter.\n   * @param scope Some scope within a stack\n   * @param parameterName The name of the SSM parameter.\n   * @param version The parameter version (recommended in order to ensure that the value won't change during deployment)\n   */\n  public static valueForStringParameter(scope: Construct, parameterName: string, version?: number): string {\n    const stack = Stack.of(scope);\n    const id = makeIdentityForImportedValue(parameterName);\n    const exists = stack.node.tryFindChild(id) as IStringParameter;\n\n    if (exists) { return exists.stringValue; }\n\n    return this.fromStringParameterAttributes(stack, id, { parameterName, version }).stringValue;\n  }\n\n  /**\n   * Returns a token that will resolve (during deployment)\n   * @param scope Some scope within a stack\n   * @param parameterName The name of the SSM parameter\n   * @param version The parameter version (required for secure strings)\n   */\n  public static valueForSecureStringParameter(scope: Construct, parameterName: string, version: number): string {\n    const stack = Stack.of(scope);\n    const id = makeIdentityForImportedValue(parameterName);\n    const exists = stack.node.tryFindChild(id) as IStringParameter;\n    if (exists) { return exists.stringValue; }\n\n    return this.fromSecureStringParameterAttributes(stack, id, { parameterName, version }).stringValue;\n  }\n\n  public readonly parameterArn: string;\n  public readonly parameterName: string;\n  public readonly parameterType: string;\n  public readonly stringValue: string;\n\n  constructor(scope: Construct, id: string, props: StringParameterProps) {\n    super(scope, id, {\n      physicalName: props.parameterName,\n    });\n\n    if (props.allowedPattern) {\n      _assertValidValue(props.stringValue, props.allowedPattern);\n    }\n\n    const resource = new ssm.CfnParameter(this, 'Resource', {\n      allowedPattern: props.allowedPattern,\n      description: props.description,\n      name: this.physicalName,\n      type: STRING_PARAM_TYPE,\n      value: props.stringValue,\n    });\n\n    this.parameterName = this.getResourceNameAttribute(resource.ref);\n    this.parameterArn = arnForParameterName(this, this.parameterName);\n\n    this.parameterType = resource.attrType;\n    this.stringValue = resource.attrValue;\n  }\n}\n\n/**\n * Creates a new StringList SSM Parameter.\n * @resource AWS::SSM::Parameter\n */\nexport class StringListParameter extends ParameterBase implements IStringListParameter {\n\n  /**\n   * Imports an external parameter of type string list.\n   */\n  public static fromStringListParameterName(scope: Construct, id: string, stringListParameterName: string): IStringListParameter {\n    class Import extends ParameterBase {\n      public readonly parameterName = stringListParameterName;\n      public readonly parameterArn = arnForParameterName(this, this.parameterName);\n      public readonly parameterType = STRINGLIST_PARAM_TYPE;\n      public readonly stringListValue = Fn.split(',', new CfnDynamicReference(CfnDynamicReferenceService.SSM, stringListParameterName).toString());\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly parameterArn: string;\n  public readonly parameterName: string;\n  public readonly parameterType: string;\n  public readonly stringListValue: string[];\n\n  constructor(scope: Construct, id: string, props: StringListParameterProps) {\n    super(scope, id, {\n      physicalName: props.parameterName,\n    });\n\n    if (props.stringListValue.find(str => !Token.isUnresolved(str) && str.indexOf(',') !== -1)) {\n      throw new Error('Values of a StringList SSM Parameter cannot contain the \\',\\' character. Use a string parameter instead.');\n    }\n\n    if (props.allowedPattern && !Token.isUnresolved(props.stringListValue)) {\n      props.stringListValue.forEach(str => _assertValidValue(str, props.allowedPattern!));\n    }\n\n    const resource = new ssm.CfnParameter(this, 'Resource', {\n      allowedPattern: props.allowedPattern,\n      description: props.description,\n      name: this.physicalName,\n      type: STRINGLIST_PARAM_TYPE,\n      value: props.stringListValue.join(','),\n    });\n    this.parameterName = this.getResourceNameAttribute(resource.ref);\n    this.parameterArn = arnForParameterName(this, this.parameterName);\n\n    this.parameterType = resource.attrType;\n    this.stringListValue = Fn.split(',', resource.attrValue);\n  }\n}\n\n/**\n * Validates whether a supplied value conforms to the allowedPattern, granted neither is an unresolved token.\n *\n * @param value          the value to be validated.\n * @param allowedPattern the regular expression to use for validation.\n *\n * @throws if the ``value`` does not conform to the ``allowedPattern`` and neither is an unresolved token (per\n *         ``cdk.unresolved``).\n */\nfunction _assertValidValue(value: string, allowedPattern: string): void {\n  if (Token.isUnresolved(value) || Token.isUnresolved(allowedPattern)) {\n    // Unable to perform validations against unresolved tokens\n    return;\n  }\n  if (!new RegExp(allowedPattern).test(value)) {\n    throw new Error(`The supplied value (${value}) does not match the specified allowedPattern (${allowedPattern})`);\n  }\n}\n\nfunction makeIdentityForImportedValue(parameterName: string) {\n  return `SsmParameterValue:${parameterName}:C96584B6-F00A-464E-AD19-53AFF4B05118`;\n}\n\nfunction arnForParameterName(scope: IConstruct, parameterName: string): string {\n  return Stack.of(scope).formatArn({\n    service: 'ssm',\n    resource: 'parameter',\n    sep: '', // Sep is empty because this.parameterName starts with a / already!\n    resourceName: parameterName,\n  });\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parameter.js","sourceRoot":"","sources":["parameter.ts"],"names":[],"mappings":"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","sourcesContent":["import iam = require('@aws-cdk/aws-iam');\nimport {\n  CfnDynamicReference, CfnDynamicReferenceService, CfnParameter,\n  Construct, ContextProvider, Fn, IConstruct, IResource, Resource, Stack, Token\n} from '@aws-cdk/core';\nimport cxapi = require('@aws-cdk/cx-api');\nimport ssm = require('./ssm.generated');\n\n/**\n * An SSM Parameter reference.\n */\nexport interface IParameter extends IResource {\n  /**\n   * The ARN of the SSM Parameter resource.\n   * @attribute\n   */\n  readonly parameterArn: string;\n\n  /**\n   * The name of the SSM Parameter resource.\n   * @attribute\n   */\n  readonly parameterName: string;\n\n  /**\n   * The type of the SSM Parameter resource.\n   * @attribute\n   */\n  readonly parameterType: string;\n\n  /**\n   * Grants read (DescribeParameter, GetParameter, GetParameterHistory) permissions on the SSM Parameter.\n   *\n   * @param grantee the role to be granted read-only access to the parameter.\n   */\n  grantRead(grantee: iam.IGrantable): iam.Grant;\n\n  /**\n   * Grants write (PutParameter) permissions on the SSM Parameter.\n   *\n   * @param grantee the role to be granted write access to the parameter.\n   */\n  grantWrite(grantee: iam.IGrantable): iam.Grant;\n}\n\n/**\n * A String SSM Parameter.\n */\nexport interface IStringParameter extends IParameter {\n  /**\n   * The parameter value. Value must not nest another parameter. Do not use {{}} in the value.\n   *\n   * @attribute Value\n   */\n  readonly stringValue: string;\n}\n\n/**\n * A StringList SSM Parameter.\n */\nexport interface IStringListParameter extends IParameter {\n  /**\n   * The parameter value. Value must not nest another parameter. Do not use {{}} in the value. Values in the array\n   * cannot contain commas (``,``).\n   *\n   * @attribute Value\n   */\n  readonly stringListValue: string[];\n}\n\n/**\n * Properties needed to create a new SSM Parameter.\n */\nexport interface ParameterOptions {\n  /**\n   * A regular expression used to validate the parameter value. For example, for String types with values restricted to\n   * numbers, you can specify the following: ``^\\d+$``\n   *\n   * @default no validation is performed\n   */\n  readonly allowedPattern?: string;\n\n  /**\n   * Information about the parameter that you want to add to the system.\n   *\n   * @default none\n   */\n  readonly description?: string;\n\n  /**\n   * The name of the parameter.\n   *\n   * @default - a name will be generated by CloudFormation\n   */\n  readonly parameterName?: string;\n}\n\n/**\n * Properties needed to create a String SSM parameter.\n */\nexport interface StringParameterProps extends ParameterOptions {\n  /**\n   * The value of the parameter. It may not reference another parameter and ``{{}}`` cannot be used in the value.\n   */\n  readonly stringValue: string;\n}\n\n/**\n * Properties needed to create a StringList SSM Parameter\n */\nexport interface StringListParameterProps extends ParameterOptions {\n  /**\n   * The values of the parameter. It may not reference another parameter and ``{{}}`` cannot be used in the value.\n   */\n  readonly stringListValue: string[];\n}\n\n/**\n * Basic features shared across all types of SSM Parameters.\n */\nabstract class ParameterBase extends Resource implements IParameter {\n  public abstract readonly parameterArn: string;\n  public abstract readonly parameterName: string;\n  public abstract readonly parameterType: string;\n\n  public grantRead(grantee: iam.IGrantable): iam.Grant {\n    return iam.Grant.addToPrincipal({\n      grantee,\n      actions: [\n        'ssm:DescribeParameters',\n        'ssm:GetParameters',\n        'ssm:GetParameter',\n        'ssm:GetParameterHistory'\n      ],\n      resourceArns: [this.parameterArn],\n    });\n  }\n\n  public grantWrite(grantee: iam.IGrantable): iam.Grant {\n    return iam.Grant.addToPrincipal({\n      grantee,\n      actions: ['ssm:PutParameter'],\n      resourceArns: [this.parameterArn],\n    });\n  }\n}\n\nconst STRING_PARAM_TYPE = 'String';\nconst SECURE_STRING_PARAM_TYPE = 'SecureString';\nconst STRINGLIST_PARAM_TYPE = 'StringList';\n\nexport interface StringParameterAttributes {\n  /**\n   * The name of the parameter store value\n   */\n  readonly parameterName: string;\n\n  /**\n   * The version number of the value you wish to retrieve.\n   *\n   * @default The latest version will be retrieved.\n   */\n  readonly version?: number;\n}\n\nexport interface SecureStringParameterAttributes {\n  /**\n   * The name of the parameter store value\n   */\n  readonly parameterName: string;\n\n  /**\n   * The version number of the value you wish to retrieve. This is required for secure strings.\n   */\n  readonly version: number;\n}\n\n/**\n * Creates a new String SSM Parameter.\n * @resource AWS::SSM::Parameter\n */\nexport class StringParameter extends ParameterBase implements IStringParameter {\n\n  /**\n   * Imports an external string parameter by name.\n   */\n  public static fromStringParameterName(scope: Construct, id: string, stringParameterName: string): IStringParameter {\n    return this.fromStringParameterAttributes(scope, id, { parameterName: stringParameterName });\n  }\n\n  /**\n   * Imports an external string parameter with name and optional version.\n   */\n  public static fromStringParameterAttributes(scope: Construct, id: string, attrs: StringParameterAttributes): IStringParameter {\n    if (!attrs.parameterName) {\n      throw new Error(`parameterName cannot be an empty string`);\n    }\n\n    const stringValue = attrs.version\n      ? new CfnDynamicReference(CfnDynamicReferenceService.SSM, `${attrs.parameterName}:${attrs.version}`).toString()\n      : new CfnParameter(scope, `${id}.Parameter`, { type: 'AWS::SSM::Parameter::Value<String>', default: attrs.parameterName }).valueAsString;\n\n    class Import extends ParameterBase {\n      public readonly parameterName = attrs.parameterName;\n      public readonly parameterArn = arnForParameterName(this, this.parameterName);\n      public readonly parameterType = STRING_PARAM_TYPE;\n      public readonly stringValue = stringValue;\n    }\n\n    return new Import(scope, id);\n  }\n\n  /**\n   * Imports a secure string parameter from the SSM parameter store.\n   */\n  public static fromSecureStringParameterAttributes(scope: Construct, id: string, attrs: SecureStringParameterAttributes): IStringParameter {\n    const stringValue = new CfnDynamicReference(CfnDynamicReferenceService.SSM_SECURE, `${attrs.parameterName}:${attrs.version}`).toString();\n\n    class Import extends ParameterBase {\n      public readonly parameterName = attrs.parameterName;\n      public readonly parameterArn = arnForParameterName(this, this.parameterName);\n      public readonly parameterType = SECURE_STRING_PARAM_TYPE;\n      public readonly stringValue = stringValue;\n    }\n\n    return new Import(scope, id);\n  }\n\n  /**\n   * Reads the value of an SSM parameter during synthesis through an\n   * environmental context provider.\n   *\n   * Requires that the stack this scope is defined in will have explicit\n   * account/region information. Otherwise, it will fail during synthesis.\n   */\n  public static valueFromLookup(scope: Construct, parameterName: string): string {\n    const value = ContextProvider.getValue(scope, {\n      provider: cxapi.SSM_PARAMETER_PROVIDER,\n      props: { parameterName },\n      dummyValue: `dummy-value-for-${parameterName}`\n    });\n\n    return value;\n  }\n\n  /**\n   * Returns a token that will resolve (during deployment) to the string value of an SSM string parameter.\n   * @param scope Some scope within a stack\n   * @param parameterName The name of the SSM parameter.\n   * @param version The parameter version (recommended in order to ensure that the value won't change during deployment)\n   */\n  public static valueForStringParameter(scope: Construct, parameterName: string, version?: number): string {\n    const stack = Stack.of(scope);\n    const id = makeIdentityForImportedValue(parameterName);\n    const exists = stack.node.tryFindChild(id) as IStringParameter;\n\n    if (exists) { return exists.stringValue; }\n\n    return this.fromStringParameterAttributes(stack, id, { parameterName, version }).stringValue;\n  }\n\n  /**\n   * Returns a token that will resolve (during deployment)\n   * @param scope Some scope within a stack\n   * @param parameterName The name of the SSM parameter\n   * @param version The parameter version (required for secure strings)\n   */\n  public static valueForSecureStringParameter(scope: Construct, parameterName: string, version: number): string {\n    const stack = Stack.of(scope);\n    const id = makeIdentityForImportedValue(parameterName);\n    const exists = stack.node.tryFindChild(id) as IStringParameter;\n    if (exists) { return exists.stringValue; }\n\n    return this.fromSecureStringParameterAttributes(stack, id, { parameterName, version }).stringValue;\n  }\n\n  public readonly parameterArn: string;\n  public readonly parameterName: string;\n  public readonly parameterType: string;\n  public readonly stringValue: string;\n\n  constructor(scope: Construct, id: string, props: StringParameterProps) {\n    super(scope, id, {\n      physicalName: props.parameterName,\n    });\n\n    if (props.allowedPattern) {\n      _assertValidValue(props.stringValue, props.allowedPattern);\n    }\n\n    const resource = new ssm.CfnParameter(this, 'Resource', {\n      allowedPattern: props.allowedPattern,\n      description: props.description,\n      name: this.physicalName,\n      type: STRING_PARAM_TYPE,\n      value: props.stringValue,\n    });\n\n    this.parameterName = this.getResourceNameAttribute(resource.ref);\n    this.parameterArn = arnForParameterName(this, this.parameterName);\n\n    this.parameterType = resource.attrType;\n    this.stringValue = resource.attrValue;\n  }\n}\n\n/**\n * Creates a new StringList SSM Parameter.\n * @resource AWS::SSM::Parameter\n */\nexport class StringListParameter extends ParameterBase implements IStringListParameter {\n\n  /**\n   * Imports an external parameter of type string list.\n   */\n  public static fromStringListParameterName(scope: Construct, id: string, stringListParameterName: string): IStringListParameter {\n    class Import extends ParameterBase {\n      public readonly parameterName = stringListParameterName;\n      public readonly parameterArn = arnForParameterName(this, this.parameterName);\n      public readonly parameterType = STRINGLIST_PARAM_TYPE;\n      public readonly stringListValue = Fn.split(',', new CfnDynamicReference(CfnDynamicReferenceService.SSM, stringListParameterName).toString());\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly parameterArn: string;\n  public readonly parameterName: string;\n  public readonly parameterType: string;\n  public readonly stringListValue: string[];\n\n  constructor(scope: Construct, id: string, props: StringListParameterProps) {\n    super(scope, id, {\n      physicalName: props.parameterName,\n    });\n\n    if (props.stringListValue.find(str => !Token.isUnresolved(str) && str.indexOf(',') !== -1)) {\n      throw new Error('Values of a StringList SSM Parameter cannot contain the \\',\\' character. Use a string parameter instead.');\n    }\n\n    if (props.allowedPattern && !Token.isUnresolved(props.stringListValue)) {\n      props.stringListValue.forEach(str => _assertValidValue(str, props.allowedPattern!));\n    }\n\n    const resource = new ssm.CfnParameter(this, 'Resource', {\n      allowedPattern: props.allowedPattern,\n      description: props.description,\n      name: this.physicalName,\n      type: STRINGLIST_PARAM_TYPE,\n      value: props.stringListValue.join(','),\n    });\n    this.parameterName = this.getResourceNameAttribute(resource.ref);\n    this.parameterArn = arnForParameterName(this, this.parameterName);\n\n    this.parameterType = resource.attrType;\n    this.stringListValue = Fn.split(',', resource.attrValue);\n  }\n}\n\n/**\n * Validates whether a supplied value conforms to the allowedPattern, granted neither is an unresolved token.\n *\n * @param value          the value to be validated.\n * @param allowedPattern the regular expression to use for validation.\n *\n * @throws if the ``value`` does not conform to the ``allowedPattern`` and neither is an unresolved token (per\n *         ``cdk.unresolved``).\n */\nfunction _assertValidValue(value: string, allowedPattern: string): void {\n  if (Token.isUnresolved(value) || Token.isUnresolved(allowedPattern)) {\n    // Unable to perform validations against unresolved tokens\n    return;\n  }\n  if (!new RegExp(allowedPattern).test(value)) {\n    throw new Error(`The supplied value (${value}) does not match the specified allowedPattern (${allowedPattern})`);\n  }\n}\n\nfunction makeIdentityForImportedValue(parameterName: string) {\n  return `SsmParameterValue:${parameterName}:C96584B6-F00A-464E-AD19-53AFF4B05118`;\n}\n\nfunction arnForParameterName(scope: IConstruct, parameterName: string): string {\n  return Stack.of(scope).formatArn({\n    service: 'ssm',\n    resource: 'parameter',\n    sep: '', // Sep is empty because this.parameterName starts with a / already!\n    resourceName: parameterName,\n  });\n}\n"]}
{
"name": "@aws-cdk/aws-ssm",
"version": "1.6.1",
"version": "1.7.0",
"description": "The CDK Construct Library for AWS::SSM",

@@ -65,3 +65,3 @@ "main": "lib/index.js",

"devDependencies": {
"@aws-cdk/assert": "^1.6.1",
"@aws-cdk/assert": "^1.7.0",
"cdk-build-tools": "file:../../../tools/cdk-build-tools",

@@ -73,11 +73,11 @@ "cdk-integ-tools": "file:../../../tools/cdk-integ-tools",

"dependencies": {
"@aws-cdk/aws-iam": "^1.6.1",
"@aws-cdk/core": "^1.6.1",
"@aws-cdk/cx-api": "^1.6.1"
"@aws-cdk/aws-iam": "^1.7.0",
"@aws-cdk/core": "^1.7.0",
"@aws-cdk/cx-api": "^1.7.0"
},
"homepage": "https://github.com/aws/aws-cdk",
"peerDependencies": {
"@aws-cdk/aws-iam": "^1.6.1",
"@aws-cdk/core": "^1.6.1",
"@aws-cdk/cx-api": "^1.6.1"
"@aws-cdk/aws-iam": "^1.7.0",
"@aws-cdk/core": "^1.7.0",
"@aws-cdk/cx-api": "^1.7.0"
},

@@ -99,2 +99,2 @@ "engines": {

"stability": "stable"
}
}

@@ -10,5 +10,3 @@ {

"lib": [
"es2016",
"es2017.object",
"es2017.string"
"es2016"
],

@@ -15,0 +13,0 @@ "module": "CommonJS",

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