Skip to content

Latest commit

 

History

History
65 lines (53 loc) · 2.86 KB

Secret.md

File metadata and controls

65 lines (53 loc) · 2.86 KB

Custom::Secret

The Custom::Secret resource creates a parameter in the Parameter Store with SecureString value containing an randomized string. You can also explicitly set a value in encrypted format.

An existing parameter in the Parameter Store will not be overwritten.

Syntax

To declare this entity in your AWS CloudFormation template, use the following syntax:

  Type : Custom::Secret
  Properties : 
    Name : String
    Description : String
    Alphabet : String
    Required: 
     - Count: integer
       Alphabet: String
    Length : Integer
    KeyAlias : String
    Content : String
    EncryptedContent : String
    ServiceToken : String
    RefreshOnUpdate: Boolean
    ReturnSecret: Boolean
    Version: String

Properties

You can specify the following properties:

  • Name - the name of the parameter in the Parameter Store (required)
  • Description - for the parameter in the store. (Default '')
  • Alphabet - the alphabet of characters from which to generate a secret (defaults to ASCII letters, digits and punctuation characters)
  • Required - an array of required characters and their ccount in the generated secret
  • Length - the length of the secret (default 30)
  • KeyAlias - to use to encrypt the string (default alias/aws/ssm)
  • ReturnSecret - as an attribute. (Default 'false')
  • RefreshOnUpdate - generate a new secret on update (Default 'false')
  • ServiceToken - ARN pointing to the lambda function implementing this resource
  • Version - optional, an opaque string to enforce the generation of a new secret.
  • NoEcho - indicate whether output of the return values is replaced by *****, default True.

If you need to set a particular value to a SecureString parameter, you can specify:

  • EncryptedContent - Base64 encoded KMS encoded secret, to be decrypted before stored
  • Content - Plain text secret to be stored.

Note that if you specify EncryptedContent it is encrypted with the KMS key of your choice. The value is decrypted before storing it in the Parameter Store. The SSM Parameter Store stores this decrypted value in encrypted form using the master key specified by KeyAlias. Please use a different KMS key for the encryption the EncryptedContent.

Return values

With 'Fn::GetAtt' the following values are available:

  • Secret - the generated secret value, if ReturnSecret was set to True.
  • Arn - the AWS Resource name of the parameter.
  • Hash - of the secret.
  • Version - of the value in the store.

Caveat - Version usage

Note that the input Version is just an opaque string to force an update of the key if RefreshOnUpdate is true, where as the returned Version attribute is the actual version of the parameter value in the store.

For more information about using Fn::GetAtt, see Fn::GetAtt.