io.cloudshiftdev.awscdk.services.ecr.OnCloudTrailImagePushedOptions.kt Maven / Gradle / Ivy
The newest version!
@file:Suppress("RedundantVisibilityModifier","RedundantUnitReturnType","RemoveRedundantQualifierName","unused","UnusedImport","ClassName","REDUNDANT_PROJECTION","DEPRECATION")
package io.cloudshiftdev.awscdk.services.ecr
import io.cloudshiftdev.awscdk.common.CdkDslMarker
import io.cloudshiftdev.awscdk.common.CdkObject
import io.cloudshiftdev.awscdk.common.CdkObjectWrappers
import io.cloudshiftdev.awscdk.services.events.EventPattern
import io.cloudshiftdev.awscdk.services.events.IRuleTarget
import io.cloudshiftdev.awscdk.services.events.OnEventOptions
import io.cloudshiftdev.constructs.Construct
import kotlin.String
import kotlin.Unit
import kotlin.jvm.JvmName
/**
* Options for the onCloudTrailImagePushed method.
*
* Example:
*
* ```
* // The code below shows an example of how to instantiate this type.
* // The values are placeholders you should change.
* import io.cloudshiftdev.awscdk.services.ecr.*;
* import io.cloudshiftdev.awscdk.services.events.*;
* import software.constructs.*;
* Construct construct;
* Object detail;
* IRuleTarget ruleTarget;
* OnCloudTrailImagePushedOptions onCloudTrailImagePushedOptions =
* OnCloudTrailImagePushedOptions.builder()
* .crossStackScope(construct)
* .description("description")
* .eventPattern(EventPattern.builder()
* .account(List.of("account"))
* .detail(Map.of(
* "detailKey", detail))
* .detailType(List.of("detailType"))
* .id(List.of("id"))
* .region(List.of("region"))
* .resources(List.of("resources"))
* .source(List.of("source"))
* .time(List.of("time"))
* .version(List.of("version"))
* .build())
* .imageTag("imageTag")
* .ruleName("ruleName")
* .target(ruleTarget)
* .build();
* ```
*/
public interface OnCloudTrailImagePushedOptions : OnEventOptions {
/**
* Only watch changes to this image tag.
*
* Default: - Watch changes to all tags
*/
public fun imageTag(): String? = unwrap(this).getImageTag()
/**
* A builder for [OnCloudTrailImagePushedOptions]
*/
@CdkDslMarker
public interface Builder {
/**
* @param crossStackScope The scope to use if the source of the rule and its target are in
* different Stacks (but in the same account & region).
* This helps dealing with cycles that often arise in these situations.
*/
public fun crossStackScope(crossStackScope: Construct)
/**
* @param description A description of the rule's purpose.
*/
public fun description(description: String)
/**
* @param eventPattern Additional restrictions for the event to route to the specified target.
* The method that generates the rule probably imposes some type of event
* filtering. The filtering implied by what you pass here is added
* on top of that filtering.
*/
public fun eventPattern(eventPattern: EventPattern)
/**
* @param eventPattern Additional restrictions for the event to route to the specified target.
* The method that generates the rule probably imposes some type of event
* filtering. The filtering implied by what you pass here is added
* on top of that filtering.
*/
@kotlin.Suppress("INAPPLICABLE_JVM_NAME")
@JvmName("abcd9f7a482e45c47c6b46cc04076fedb540034e00e06120b4126d9a9d2c1c6d")
public fun eventPattern(eventPattern: EventPattern.Builder.() -> Unit)
/**
* @param imageTag Only watch changes to this image tag.
*/
public fun imageTag(imageTag: String)
/**
* @param ruleName A name for the rule.
*/
public fun ruleName(ruleName: String)
/**
* @param target The target to register for the event.
*/
public fun target(target: IRuleTarget)
}
private class BuilderImpl : Builder {
private val cdkBuilder:
software.amazon.awscdk.services.ecr.OnCloudTrailImagePushedOptions.Builder =
software.amazon.awscdk.services.ecr.OnCloudTrailImagePushedOptions.builder()
/**
* @param crossStackScope The scope to use if the source of the rule and its target are in
* different Stacks (but in the same account & region).
* This helps dealing with cycles that often arise in these situations.
*/
override fun crossStackScope(crossStackScope: Construct) {
cdkBuilder.crossStackScope(crossStackScope.let(Construct.Companion::unwrap))
}
/**
* @param description A description of the rule's purpose.
*/
override fun description(description: String) {
cdkBuilder.description(description)
}
/**
* @param eventPattern Additional restrictions for the event to route to the specified target.
* The method that generates the rule probably imposes some type of event
* filtering. The filtering implied by what you pass here is added
* on top of that filtering.
*/
override fun eventPattern(eventPattern: EventPattern) {
cdkBuilder.eventPattern(eventPattern.let(EventPattern.Companion::unwrap))
}
/**
* @param eventPattern Additional restrictions for the event to route to the specified target.
* The method that generates the rule probably imposes some type of event
* filtering. The filtering implied by what you pass here is added
* on top of that filtering.
*/
@kotlin.Suppress("INAPPLICABLE_JVM_NAME")
@JvmName("abcd9f7a482e45c47c6b46cc04076fedb540034e00e06120b4126d9a9d2c1c6d")
override fun eventPattern(eventPattern: EventPattern.Builder.() -> Unit): Unit =
eventPattern(EventPattern(eventPattern))
/**
* @param imageTag Only watch changes to this image tag.
*/
override fun imageTag(imageTag: String) {
cdkBuilder.imageTag(imageTag)
}
/**
* @param ruleName A name for the rule.
*/
override fun ruleName(ruleName: String) {
cdkBuilder.ruleName(ruleName)
}
/**
* @param target The target to register for the event.
*/
override fun target(target: IRuleTarget) {
cdkBuilder.target(target.let(IRuleTarget.Companion::unwrap))
}
public fun build(): software.amazon.awscdk.services.ecr.OnCloudTrailImagePushedOptions =
cdkBuilder.build()
}
private class Wrapper(
cdkObject: software.amazon.awscdk.services.ecr.OnCloudTrailImagePushedOptions,
) : CdkObject(cdkObject),
OnCloudTrailImagePushedOptions {
/**
* The scope to use if the source of the rule and its target are in different Stacks (but in the
* same account & region).
*
* This helps dealing with cycles that often arise in these situations.
*
* Default: - none (the main scope will be used, even for cross-stack Events)
*/
override fun crossStackScope(): Construct? =
unwrap(this).getCrossStackScope()?.let(Construct::wrap)
/**
* A description of the rule's purpose.
*
* Default: - No description
*/
override fun description(): String? = unwrap(this).getDescription()
/**
* Additional restrictions for the event to route to the specified target.
*
* The method that generates the rule probably imposes some type of event
* filtering. The filtering implied by what you pass here is added
* on top of that filtering.
*
* Default: - No additional filtering based on an event pattern.
*
* [Documentation](https://docs.aws.amazon.com/eventbridge/latest/userguide/eventbridge-and-event-patterns.html)
*/
override fun eventPattern(): EventPattern? =
unwrap(this).getEventPattern()?.let(EventPattern::wrap)
/**
* Only watch changes to this image tag.
*
* Default: - Watch changes to all tags
*/
override fun imageTag(): String? = unwrap(this).getImageTag()
/**
* A name for the rule.
*
* Default: AWS CloudFormation generates a unique physical ID.
*/
override fun ruleName(): String? = unwrap(this).getRuleName()
/**
* The target to register for the event.
*
* Default: - No target is added to the rule. Use `addTarget()` to add a target.
*/
override fun target(): IRuleTarget? = unwrap(this).getTarget()?.let(IRuleTarget::wrap)
}
public companion object {
public operator fun invoke(block: Builder.() -> Unit = {}): OnCloudTrailImagePushedOptions {
val builderImpl = BuilderImpl()
return Wrapper(builderImpl.apply(block).build())
}
internal
fun wrap(cdkObject: software.amazon.awscdk.services.ecr.OnCloudTrailImagePushedOptions):
OnCloudTrailImagePushedOptions = CdkObjectWrappers.wrap(cdkObject) as?
OnCloudTrailImagePushedOptions ?: Wrapper(cdkObject)
internal fun unwrap(wrapped: OnCloudTrailImagePushedOptions):
software.amazon.awscdk.services.ecr.OnCloudTrailImagePushedOptions = (wrapped as
CdkObject).cdkObject as software.amazon.awscdk.services.ecr.OnCloudTrailImagePushedOptions
}
}