diff --git a/packages/@aws-cdk/aws-ssm/lib/parameter.ts b/packages/@aws-cdk/aws-ssm/lib/parameter.ts index f24e4d0375108..5721cd30e922d 100644 --- a/packages/@aws-cdk/aws-ssm/lib/parameter.ts +++ b/packages/@aws-cdk/aws-ssm/lib/parameter.ts @@ -492,7 +492,10 @@ export class StringParameter extends ParameterBase implements IStringParameter { */ public static fromSecureStringParameterAttributes(scope: Construct, id: string, attrs: SecureStringParameterAttributes): IStringParameter { const version = attrs.version ? Tokenization.stringifyNumber(attrs.version) : ''; - const stringValue = new CfnDynamicReference(CfnDynamicReferenceService.SSM_SECURE, `${attrs.parameterName}:${version}`).toString(); + const stringValue = new CfnDynamicReference( + CfnDynamicReferenceService.SSM_SECURE, + version ? `${attrs.parameterName}:${version}` : attrs.parameterName, + ).toString(); class Import extends ParameterBase { public readonly parameterName = attrs.parameterName; diff --git a/packages/@aws-cdk/aws-ssm/test/parameter.test.ts b/packages/@aws-cdk/aws-ssm/test/parameter.test.ts index 817eb4d264239..c33bfaa01305f 100644 --- a/packages/@aws-cdk/aws-ssm/test/parameter.test.ts +++ b/packages/@aws-cdk/aws-ssm/test/parameter.test.ts @@ -602,7 +602,7 @@ test('StringParameter.fromSecureStringParameterAttributes without version', () = }); // THEN - expect(stack.resolve(param.stringValue)).toEqual('{{resolve:ssm-secure:MyParamName:}}'); + expect(stack.resolve(param.stringValue)).toEqual('{{resolve:ssm-secure:MyParamName}}'); }); test('StringListParameter.fromName', () => {