- Implements: @aws-cdk/aws-secretsmanager.ISecret
A drop in replacement for the normal Secret, that is populated with the encrypted content of the given sops file.
import { SopsSecret } from 'cdk-sops-secrets'
new SopsSecret(scope: Construct, id: string, props: SopsSecretProps)
Name | Type | Description |
---|---|---|
scope |
@aws-cdk/core.Construct |
No description. |
id |
string |
No description. |
props |
SopsSecretProps |
No description. |
- Type: @aws-cdk/core.Construct
- Type: string
- Type: SopsSecretProps
Name | Description |
---|---|
toString |
Returns a string representation of this construct. |
addRotationSchedule |
Adds a rotation schedule to the secret. |
addToResourcePolicy |
Adds a statement to the IAM resource policy associated with this secret. |
applyRemovalPolicy |
Apply the given removal policy to this resource. |
attach |
Attach a target to this secret. |
currentVersionId |
Returns the current versionId that was created via the SopsSync. |
denyAccountRootDelete |
Denies the DeleteSecret action to all principals within the current account. |
grantRead |
Grants reading the secret value to some role. |
grantWrite |
Grants writing and updating the secret value to some role. |
secretValueFromJson |
Interpret the secret as a JSON object and return a field's value from it as a SecretValue . |
public toString(): string
Returns a string representation of this construct.
public addRotationSchedule(id: string, options: RotationScheduleOptions): RotationSchedule
Adds a rotation schedule to the secret.
- Type: string
- Type: @aws-cdk/aws-secretsmanager.RotationScheduleOptions
public addToResourcePolicy(statement: PolicyStatement): AddToResourcePolicyResult
Adds a statement to the IAM resource policy associated with this secret.
If this secret was created in this stack, a resource policy will be
automatically created upon the first call to addToResourcePolicy
. If
the secret is imported, then this is a no-op.
- Type: @aws-cdk/aws-iam.PolicyStatement
public applyRemovalPolicy(policy: RemovalPolicy): void
Apply the given removal policy to this resource.
The Removal Policy controls what happens to this resource when it stops being managed by CloudFormation, either because you've removed it from the CDK application or because you've made a change that requires the resource to be replaced.
The resource can be deleted (RemovalPolicy.DESTROY
), or left in your AWS
account for data recovery and cleanup later (RemovalPolicy.RETAIN
).
- Type: @aws-cdk/core.RemovalPolicy
public attach(target: ISecretAttachmentTarget): ISecret
Attach a target to this secret.
- Type: @aws-cdk/aws-secretsmanager.ISecretAttachmentTarget
public currentVersionId(): string
Returns the current versionId that was created via the SopsSync.
public denyAccountRootDelete(): void
Denies the DeleteSecret
action to all principals within the current account.
public grantRead(grantee: IGrantable, versionStages?: string[]): Grant
Grants reading the secret value to some role.
- Type: @aws-cdk/aws-iam.IGrantable
- Type: string[]
public grantWrite(grantee: IGrantable): Grant
Grants writing and updating the secret value to some role.
- Type: @aws-cdk/aws-iam.IGrantable
public secretValueFromJson(jsonField: string): SecretValue
Interpret the secret as a JSON object and return a field's value from it as a SecretValue
.
- Type: string
Name | Description |
---|---|
isConstruct |
Return whether the given object is a Construct. |
import { SopsSecret } from 'cdk-sops-secrets'
SopsSecret.isConstruct(x: any)
Return whether the given object is a Construct.
- Type: any
Name | Type | Description |
---|---|---|
node |
@aws-cdk/core.ConstructNode |
The construct tree node associated with this construct. |
env |
@aws-cdk/core.ResourceEnvironment |
The environment this resource belongs to. |
secretArn |
string |
The ARN of the secret in AWS Secrets Manager. |
secretName |
string |
The name of the secret. |
secretValue |
@aws-cdk/core.SecretValue |
Retrieve the value of the stored secret as a SecretValue . |
stack |
@aws-cdk/core.Stack |
The stack in which this resource is defined. |
sync |
SopsSync |
No description. |
encryptionKey |
@aws-cdk/aws-kms.IKey |
The customer-managed encryption key that is used to encrypt this secret, if any. |
secretFullArn |
string |
The full ARN of the secret in AWS Secrets Manager, which is the ARN including the Secrets Manager-supplied 6-character suffix. |
public readonly node: ConstructNode;
- Type: @aws-cdk/core.ConstructNode
The construct tree node associated with this construct.
public readonly env: ResourceEnvironment;
- Type: @aws-cdk/core.ResourceEnvironment
The environment this resource belongs to.
For resources that are created and managed by the CDK (generally, those created by creating new class instances like Role, Bucket, etc.), this is always the same as the environment of the stack they belong to; however, for imported resources (those obtained from static methods like fromRoleArn, fromBucketName, etc.), that might be different than the stack they were imported into.
public readonly secretArn: string;
- Type: string
The ARN of the secret in AWS Secrets Manager.
Will return the full ARN if available, otherwise a partial arn.
For secrets imported by the deprecated fromSecretName
, it will return the secretName
.
public readonly secretName: string;
- Type: string
The name of the secret.
For "owned" secrets, this will be the full resource name (secret name + suffix), unless the '@aws-cdk/aws-secretsmanager:parseOwnedSecretName' feature flag is set.
public readonly secretValue: SecretValue;
- Type: @aws-cdk/core.SecretValue
Retrieve the value of the stored secret as a SecretValue
.
public readonly stack: Stack;
- Type: @aws-cdk/core.Stack
The stack in which this resource is defined.
public readonly sync: SopsSync;
- Type: SopsSync
public readonly encryptionKey: IKey;
- Type: @aws-cdk/aws-kms.IKey
The customer-managed encryption key that is used to encrypt this secret, if any.
When not specified, the default KMS key for the account and region is being used.
public readonly secretFullArn: string;
- Type: string
The full ARN of the secret in AWS Secrets Manager, which is the ARN including the Secrets Manager-supplied 6-character suffix.
This is equal to secretArn
in most cases, but is undefined when a full ARN is not available (e.g., secrets imported by name).
The custom resource, that is syncing the content from a sops file to a secret.
import { SopsSync } from 'cdk-sops-secrets'
new SopsSync(scope: Construct, id: string, props: SopsSyncProps)
Name | Type | Description |
---|---|---|
scope |
@aws-cdk/core.Construct |
No description. |
id |
string |
No description. |
props |
SopsSyncProps |
No description. |
- Type: @aws-cdk/core.Construct
- Type: string
- Type: SopsSyncProps
Name | Description |
---|---|
toString |
Returns a string representation of this construct. |
public toString(): string
Returns a string representation of this construct.
Name | Description |
---|---|
isConstruct |
Return whether the given object is a Construct. |
import { SopsSync } from 'cdk-sops-secrets'
SopsSync.isConstruct(x: any)
Return whether the given object is a Construct.
- Type: any
Name | Type | Description |
---|---|---|
node |
@aws-cdk/core.ConstructNode |
The construct tree node associated with this construct. |
converToJSON |
boolean |
Was the format converted to json? |
flatten |
boolean |
Was the structure flattened? |
sopsFileFormat |
string |
The format of the input file. |
stringifiedValues |
boolean |
Were the values stringified? |
versionId |
string |
The current versionId of the secret populated via this resource. |
public readonly node: ConstructNode;
- Type: @aws-cdk/core.ConstructNode
The construct tree node associated with this construct.
public readonly converToJSON: boolean;
- Type: boolean
Was the format converted to json?
public readonly flatten: boolean;
- Type: boolean
Was the structure flattened?
public readonly sopsFileFormat: string;
- Type: string
The format of the input file.
public readonly stringifiedValues: boolean;
- Type: boolean
Were the values stringified?
public readonly versionId: string;
- Type: string
The current versionId of the secret populated via this resource.
import { SopsSyncProvider } from 'cdk-sops-secrets'
new SopsSyncProvider(scope: Construct, id?: string)
Name | Type | Description |
---|---|---|
scope |
@aws-cdk/core.Construct |
No description. |
id |
string |
No description. |
- Type: @aws-cdk/core.Construct
- Type: string
Name | Description |
---|---|
toString |
Returns a string representation of this construct. |
applyRemovalPolicy |
Apply the given removal policy to this resource. |
addEventSource |
Adds an event source to this function. |
addEventSourceMapping |
Adds an event source that maps to this AWS Lambda function. |
addPermission |
Adds a permission to the Lambda resource policy. |
addToRolePolicy |
Adds a statement to the IAM role assumed by the instance. |
configureAsyncInvoke |
Configures options for asynchronous invocation. |
considerWarningOnInvokeFunctionPermissions |
A warning will be added to functions under the following conditions: - permissions that include lambda:InvokeFunction are added to the unqualified function. |
grantInvoke |
Grant the given identity permissions to invoke this Lambda. |
metric |
Return the given named metric for this Function. |
metricDuration |
How long execution of this Lambda takes. |
metricErrors |
How many invocations of this Lambda fail. |
metricInvocations |
How often this Lambda is invoked. |
metricThrottles |
How often this Lambda is throttled. |
addDependency |
Using node.addDependency() does not work on this method as the underlying lambda function is modeled as a singleton across the stack. Use this method instead to declare dependencies. |
addEnvironment |
Adds an environment variable to this Lambda function. |
addLayers |
Adds one or more Lambda Layers to this Lambda function. |
dependOn |
The SingletonFunction construct cannot be added as a dependency of another construct using node.addDependency(). Use this method instead to declare this as a dependency of another construct. |
addAgeKey |
No description. |
public toString(): string
Returns a string representation of this construct.
public applyRemovalPolicy(policy: RemovalPolicy): void
Apply the given removal policy to this resource.
The Removal Policy controls what happens to this resource when it stops being managed by CloudFormation, either because you've removed it from the CDK application or because you've made a change that requires the resource to be replaced.
The resource can be deleted (RemovalPolicy.DESTROY
), or left in your AWS
account for data recovery and cleanup later (RemovalPolicy.RETAIN
).
- Type: @aws-cdk/core.RemovalPolicy
public addEventSource(source: IEventSource): void
Adds an event source to this function.
Event sources are implemented in the @aws-cdk/aws-lambda-event-sources module.
The following example adds an SQS Queue as an event source:
import { SqsEventSource } from '@aws-cdk/aws-lambda-event-sources';
myFunction.addEventSource(new SqsEventSource(myQueue));
- Type: @aws-cdk/aws-lambda.IEventSource
public addEventSourceMapping(id: string, options: EventSourceMappingOptions): EventSourceMapping
Adds an event source that maps to this AWS Lambda function.
- Type: string
- Type: @aws-cdk/aws-lambda.EventSourceMappingOptions
public addPermission(name: string, permission: Permission): void
Adds a permission to the Lambda resource policy.
- Type: string
- Type: @aws-cdk/aws-lambda.Permission
public addToRolePolicy(statement: PolicyStatement): void
Adds a statement to the IAM role assumed by the instance.
- Type: @aws-cdk/aws-iam.PolicyStatement
public configureAsyncInvoke(options: EventInvokeConfigOptions): void
Configures options for asynchronous invocation.
- Type: @aws-cdk/aws-lambda.EventInvokeConfigOptions
public considerWarningOnInvokeFunctionPermissions(scope: Construct, action: string): void
A warning will be added to functions under the following conditions: - permissions that include lambda:InvokeFunction
are added to the unqualified function.
function.currentVersion is invoked before or after the permission is created.
This applies only to permissions on Lambda functions, not versions or aliases. This function is overridden as a noOp for QualifiedFunctionBase.
- Type: @aws-cdk/core.Construct
- Type: string
public grantInvoke(grantee: IGrantable): Grant
Grant the given identity permissions to invoke this Lambda.
- Type: @aws-cdk/aws-iam.IGrantable
public metric(metricName: string, props?: MetricOptions): Metric
Return the given named metric for this Function.
- Type: string
- Type: @aws-cdk/aws-cloudwatch.MetricOptions
public metricDuration(props?: MetricOptions): Metric
How long execution of this Lambda takes.
Average over 5 minutes
- Type: @aws-cdk/aws-cloudwatch.MetricOptions
public metricErrors(props?: MetricOptions): Metric
How many invocations of this Lambda fail.
Sum over 5 minutes
- Type: @aws-cdk/aws-cloudwatch.MetricOptions
public metricInvocations(props?: MetricOptions): Metric
How often this Lambda is invoked.
Sum over 5 minutes
- Type: @aws-cdk/aws-cloudwatch.MetricOptions
public metricThrottles(props?: MetricOptions): Metric
How often this Lambda is throttled.
Sum over 5 minutes
- Type: @aws-cdk/aws-cloudwatch.MetricOptions
public addDependency(up: IDependable): void
Using node.addDependency() does not work on this method as the underlying lambda function is modeled as a singleton across the stack. Use this method instead to declare dependencies.
- Type: @aws-cdk/core.IDependable
public addEnvironment(key: string, value: string, options?: EnvironmentOptions): Function
Adds an environment variable to this Lambda function.
If this is a ref to a Lambda function, this operation results in a no-op.
- Type: string
The environment variable key.
- Type: string
The environment variable's value.
- Type: @aws-cdk/aws-lambda.EnvironmentOptions
Environment variable options.
public addLayers(layers: ILayerVersion): void
Adds one or more Lambda Layers to this Lambda function.
- Type: @aws-cdk/aws-lambda.ILayerVersion
the layers to be added.
public dependOn(down: IConstruct): void
The SingletonFunction construct cannot be added as a dependency of another construct using node.addDependency(). Use this method instead to declare this as a dependency of another construct.
- Type: @aws-cdk/core.IConstruct
public addAgeKey(key: SecretValue): void
- Type: @aws-cdk/core.SecretValue
Name | Description |
---|---|
isConstruct |
Return whether the given object is a Construct. |
isResource |
Check whether the given construct is a Resource. |
import { SopsSyncProvider } from 'cdk-sops-secrets'
SopsSyncProvider.isConstruct(x: any)
Return whether the given object is a Construct.
- Type: any
import { SopsSyncProvider } from 'cdk-sops-secrets'
SopsSyncProvider.isResource(construct: IConstruct)
Check whether the given construct is a Resource.
- Type: @aws-cdk/core.IConstruct
Name | Type | Description |
---|---|---|
node |
@aws-cdk/core.ConstructNode |
The construct tree node associated with this construct. |
env |
@aws-cdk/core.ResourceEnvironment |
The environment this resource belongs to. |
stack |
@aws-cdk/core.Stack |
The stack in which this resource is defined. |
architecture |
@aws-cdk/aws-lambda.Architecture |
The architecture of this Lambda Function. |
connections |
@aws-cdk/aws-ec2.Connections |
Access the Connections object. |
functionArn |
string |
The ARN fo the function. |
functionName |
string |
The name of the function. |
grantPrincipal |
@aws-cdk/aws-iam.IPrincipal |
The principal this Lambda Function is running as. |
isBoundToVpc |
boolean |
Whether or not this Lambda function was bound to a VPC. |
latestVersion |
@aws-cdk/aws-lambda.IVersion |
The $LATEST version of this function. |
permissionsNode |
@aws-cdk/core.ConstructNode |
The construct node where permissions are attached. |
resourceArnsForGrantInvoke |
string[] |
The ARN(s) to put into the resource field of the generated IAM policy for grantInvoke(). |
role |
@aws-cdk/aws-iam.IRole |
The IAM role associated with this function. |
currentVersion |
@aws-cdk/aws-lambda.Version |
Returns a lambda.Version which represents the current version of this singleton Lambda function. A new version will be created every time the function's configuration changes. |
logGroup |
@aws-cdk/aws-logs.ILogGroup |
The LogGroup where the Lambda function's logs are made available. |
runtime |
@aws-cdk/aws-lambda.Runtime |
The runtime environment for the Lambda function. |
public readonly node: ConstructNode;
- Type: @aws-cdk/core.ConstructNode
The construct tree node associated with this construct.
public readonly env: ResourceEnvironment;
- Type: @aws-cdk/core.ResourceEnvironment
The environment this resource belongs to.
For resources that are created and managed by the CDK (generally, those created by creating new class instances like Role, Bucket, etc.), this is always the same as the environment of the stack they belong to; however, for imported resources (those obtained from static methods like fromRoleArn, fromBucketName, etc.), that might be different than the stack they were imported into.
public readonly stack: Stack;
- Type: @aws-cdk/core.Stack
The stack in which this resource is defined.
public readonly architecture: Architecture;
- Type: @aws-cdk/aws-lambda.Architecture
The architecture of this Lambda Function.
public readonly connections: Connections;
- Type: @aws-cdk/aws-ec2.Connections
Access the Connections object.
Will fail if not a VPC-enabled Lambda Function
public readonly functionArn: string;
- Type: string
The ARN fo the function.
public readonly functionName: string;
- Type: string
The name of the function.
public readonly grantPrincipal: IPrincipal;
- Type: @aws-cdk/aws-iam.IPrincipal
The principal this Lambda Function is running as.
public readonly isBoundToVpc: boolean;
- Type: boolean
Whether or not this Lambda function was bound to a VPC.
If this is is false
, trying to access the connections
object will fail.
public readonly latestVersion: IVersion;
- Type: @aws-cdk/aws-lambda.IVersion
The $LATEST
version of this function.
Note that this is reference to a non-specific AWS Lambda version, which means the function this version refers to can return different results in different invocations.
To obtain a reference to an explicit version which references the current
function configuration, use lambdaFunction.currentVersion
instead.
public readonly permissionsNode: ConstructNode;
- Type: @aws-cdk/core.ConstructNode
The construct node where permissions are attached.
public readonly resourceArnsForGrantInvoke: string[];
- Type: string[]
The ARN(s) to put into the resource field of the generated IAM policy for grantInvoke().
public readonly role: IRole;
- Type: @aws-cdk/aws-iam.IRole
The IAM role associated with this function.
Undefined if the function was imported without a role.
public readonly currentVersion: Version;
- Type: @aws-cdk/aws-lambda.Version
Returns a lambda.Version
which represents the current version of this singleton Lambda function. A new version will be created every time the function's configuration changes.
You can specify options for this version using the currentVersionOptions
prop when initializing the lambda.SingletonFunction
.
public readonly logGroup: ILogGroup;
- Type: @aws-cdk/aws-logs.ILogGroup
The LogGroup where the Lambda function's logs are made available.
If either logRetention
is set or this property is called, a CloudFormation custom resource is added to the stack that
pre-creates the log group as part of the stack deployment, if it already doesn't exist, and sets the correct log retention
period (never expire, by default).
Further, if the log group already exists and the logRetention
is not set, the custom resource will reset the log retention
to never expire even if it was configured with a different value.
public readonly runtime: Runtime;
- Type: @aws-cdk/aws-lambda.Runtime
The runtime environment for the Lambda function.
The configuration options of the SopsSecret.
import { SopsSecretProps } from 'cdk-sops-secrets'
const sopsSecretProps: SopsSecretProps = { ... }
Name | Type | Description |
---|---|---|
description |
string |
An optional, human-friendly description of the secret. |
encryptionKey |
@aws-cdk/aws-kms.IKey |
The customer-managed encryption key to use for encrypting the secret value. |
generateSecretString |
@aws-cdk/aws-secretsmanager.SecretStringGenerator |
Configuration for how to generate a secret value. |
removalPolicy |
@aws-cdk/core.RemovalPolicy |
Policy to apply when the secret is removed from this stack. |
replicaRegions |
@aws-cdk/aws-secretsmanager.ReplicaRegion[] |
A list of regions where to replicate this secret. |
secretName |
string |
A name for the secret. |
secretStringBeta1 |
@aws-cdk/aws-secretsmanager.SecretStringValueBeta1 |
Initial value for the secret. |
sopsFilePath |
string |
The filepath to the sops file. |
convertToJSON |
boolean |
Should the encrypted sops value should be converted to JSON? |
flatten |
boolean |
Should the structure be flattened? |
sopsAgeKey |
@aws-cdk/core.SecretValue |
The age key that should be used for encryption. |
sopsFileFormat |
string |
The format of the sops file. |
sopsKmsKey |
@aws-cdk/aws-kms.IKey[] |
The kmsKey used to encrypt the sops file. |
sopsProvider |
SopsSyncProvider |
The custom resource provider to use. |
stringifyValues |
boolean |
Shall all values be flattened? |
public readonly description: string;
- Type: string
- Default: No description.
An optional, human-friendly description of the secret.
public readonly encryptionKey: IKey;
- Type: @aws-cdk/aws-kms.IKey
- Default: A default KMS key for the account and region is used.
The customer-managed encryption key to use for encrypting the secret value.
public readonly generateSecretString: SecretStringGenerator;
- Type: @aws-cdk/aws-secretsmanager.SecretStringGenerator
- Default: 32 characters with upper-case letters, lower-case letters, punctuation and numbers (at least one from each category), per the default values of
SecretStringGenerator
.
Configuration for how to generate a secret value.
Only one of secretString
and generateSecretString
can be provided.
public readonly removalPolicy: RemovalPolicy;
- Type: @aws-cdk/core.RemovalPolicy
- Default: Not set.
Policy to apply when the secret is removed from this stack.
public readonly replicaRegions: ReplicaRegion[];
- Type: @aws-cdk/aws-secretsmanager.ReplicaRegion[]
- Default: Secret is not replicated
A list of regions where to replicate this secret.
public readonly secretName: string;
- Type: string
- Default: A name is generated by CloudFormation.
A name for the secret.
Note that deleting secrets from SecretsManager does not happen immediately, but after a 7 to 30 days blackout period. During that period, it is not possible to create another secret that shares the same name.
public readonly secretStringBeta1: SecretStringValueBeta1;
- Type: @aws-cdk/aws-secretsmanager.SecretStringValueBeta1
- Default: SecretsManager generates a new secret value.
Initial value for the secret.
NOTE: *It is highly encouraged to leave this field undefined and allow SecretsManager to create the secret value. The secret string -- if provided -- will be included in the output of the cdk as part of synthesis, and will appear in the CloudFormation template in the console. This can be secure(-ish) if that value is merely reference to another resource (or one of its attributes), but if the value is a plaintext string, it will be visible to anyone with access to the CloudFormation template (via the AWS Console, SDKs, or CLI).
Specifies text data that you want to encrypt and store in this new version of the secret. May be a simple string value, or a string representation of a JSON structure.
Only one of secretString
and generateSecretString
can be provided.
public readonly sopsFilePath: string;
- Type: string
The filepath to the sops file.
public readonly convertToJSON: boolean;
- Type: boolean
- Default: true
Should the encrypted sops value should be converted to JSON?
Only JSON can be handled by cloud formations dynamic references.
public readonly flatten: boolean;
- Type: boolean
- Default: true
Should the structure be flattened?
The result will be a flat structure and all object keys will be replaced with the full jsonpath as key. This is usefull for dynamic references, as those don't support nested objects.
public readonly sopsAgeKey: SecretValue;
- Type: @aws-cdk/core.SecretValue
The age key that should be used for encryption.
public readonly sopsFileFormat: string;
- Type: string
- Default: The fileformat will be derived from the file ending
The format of the sops file.
public readonly sopsKmsKey: IKey[];
- Type: @aws-cdk/aws-kms.IKey[]
- Default: The key will be derived from the sops file
The kmsKey used to encrypt the sops file.
Encrypt permissions will be granted to the custom resource provider.
public readonly sopsProvider: SopsSyncProvider;
- Type: SopsSyncProvider
- Default: A new singleton provider will be created
The custom resource provider to use.
If you don't specify any, a new provider will be created - or if already exists within this stack - reused.
public readonly stringifyValues: boolean;
- Type: boolean
Shall all values be flattened?
This is usefull for dynamic references, as there are lookup errors for certain float types
Configuration options for the SopsSync.
import { SopsSyncOptions } from 'cdk-sops-secrets'
const sopsSyncOptions: SopsSyncOptions = { ... }
Name | Type | Description |
---|---|---|
sopsFilePath |
string |
The filepath to the sops file. |
convertToJSON |
boolean |
Should the encrypted sops value should be converted to JSON? |
flatten |
boolean |
Should the structure be flattened? |
sopsAgeKey |
@aws-cdk/core.SecretValue |
The age key that should be used for encryption. |
sopsFileFormat |
string |
The format of the sops file. |
sopsKmsKey |
@aws-cdk/aws-kms.IKey[] |
The kmsKey used to encrypt the sops file. |
sopsProvider |
SopsSyncProvider |
The custom resource provider to use. |
stringifyValues |
boolean |
Shall all values be flattened? |
public readonly sopsFilePath: string;
- Type: string
The filepath to the sops file.
public readonly convertToJSON: boolean;
- Type: boolean
- Default: true
Should the encrypted sops value should be converted to JSON?
Only JSON can be handled by cloud formations dynamic references.
public readonly flatten: boolean;
- Type: boolean
- Default: true
Should the structure be flattened?
The result will be a flat structure and all object keys will be replaced with the full jsonpath as key. This is usefull for dynamic references, as those don't support nested objects.
public readonly sopsAgeKey: SecretValue;
- Type: @aws-cdk/core.SecretValue
The age key that should be used for encryption.
public readonly sopsFileFormat: string;
- Type: string
- Default: The fileformat will be derived from the file ending
The format of the sops file.
public readonly sopsKmsKey: IKey[];
- Type: @aws-cdk/aws-kms.IKey[]
- Default: The key will be derived from the sops file
The kmsKey used to encrypt the sops file.
Encrypt permissions will be granted to the custom resource provider.
public readonly sopsProvider: SopsSyncProvider;
- Type: SopsSyncProvider
- Default: A new singleton provider will be created
The custom resource provider to use.
If you don't specify any, a new provider will be created - or if already exists within this stack - reused.
public readonly stringifyValues: boolean;
- Type: boolean
Shall all values be flattened?
This is usefull for dynamic references, as there are lookup errors for certain float types
The configuration options extended by the target Secret.
import { SopsSyncProps } from 'cdk-sops-secrets'
const sopsSyncProps: SopsSyncProps = { ... }
Name | Type | Description |
---|---|---|
sopsFilePath |
string |
The filepath to the sops file. |
convertToJSON |
boolean |
Should the encrypted sops value should be converted to JSON? |
flatten |
boolean |
Should the structure be flattened? |
sopsAgeKey |
@aws-cdk/core.SecretValue |
The age key that should be used for encryption. |
sopsFileFormat |
string |
The format of the sops file. |
sopsKmsKey |
@aws-cdk/aws-kms.IKey[] |
The kmsKey used to encrypt the sops file. |
sopsProvider |
SopsSyncProvider |
The custom resource provider to use. |
stringifyValues |
boolean |
Shall all values be flattened? |
secret |
@aws-cdk/aws-secretsmanager.ISecret |
The secret that will be populated with the encrypted sops file content. |
public readonly sopsFilePath: string;
- Type: string
The filepath to the sops file.
public readonly convertToJSON: boolean;
- Type: boolean
- Default: true
Should the encrypted sops value should be converted to JSON?
Only JSON can be handled by cloud formations dynamic references.
public readonly flatten: boolean;
- Type: boolean
- Default: true
Should the structure be flattened?
The result will be a flat structure and all object keys will be replaced with the full jsonpath as key. This is usefull for dynamic references, as those don't support nested objects.
public readonly sopsAgeKey: SecretValue;
- Type: @aws-cdk/core.SecretValue
The age key that should be used for encryption.
public readonly sopsFileFormat: string;
- Type: string
- Default: The fileformat will be derived from the file ending
The format of the sops file.
public readonly sopsKmsKey: IKey[];
- Type: @aws-cdk/aws-kms.IKey[]
- Default: The key will be derived from the sops file
The kmsKey used to encrypt the sops file.
Encrypt permissions will be granted to the custom resource provider.
public readonly sopsProvider: SopsSyncProvider;
- Type: SopsSyncProvider
- Default: A new singleton provider will be created
The custom resource provider to use.
If you don't specify any, a new provider will be created - or if already exists within this stack - reused.
public readonly stringifyValues: boolean;
- Type: boolean
Shall all values be flattened?
This is usefull for dynamic references, as there are lookup errors for certain float types
public readonly secret: ISecret;
- Type: @aws-cdk/aws-secretsmanager.ISecret
The secret that will be populated with the encrypted sops file content.