commonMain.aws.sdk.kotlin.services.proton.waiters.Waiters.kt Maven / Gradle / Ivy
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!
package aws.sdk.kotlin.services.proton.waiters
import aws.sdk.kotlin.services.proton.ProtonClient
import aws.sdk.kotlin.services.proton.model.GetComponentRequest
import aws.sdk.kotlin.services.proton.model.GetComponentResponse
import aws.sdk.kotlin.services.proton.model.GetEnvironmentRequest
import aws.sdk.kotlin.services.proton.model.GetEnvironmentResponse
import aws.sdk.kotlin.services.proton.model.GetEnvironmentTemplateVersionRequest
import aws.sdk.kotlin.services.proton.model.GetEnvironmentTemplateVersionResponse
import aws.sdk.kotlin.services.proton.model.GetServiceInstanceRequest
import aws.sdk.kotlin.services.proton.model.GetServiceInstanceResponse
import aws.sdk.kotlin.services.proton.model.GetServiceRequest
import aws.sdk.kotlin.services.proton.model.GetServiceResponse
import aws.sdk.kotlin.services.proton.model.GetServiceTemplateVersionRequest
import aws.sdk.kotlin.services.proton.model.GetServiceTemplateVersionResponse
import aws.smithy.kotlin.runtime.retries.Outcome
import aws.smithy.kotlin.runtime.retries.StandardRetryStrategy
import aws.smithy.kotlin.runtime.retries.delay.InfiniteTokenBucket
import aws.smithy.kotlin.runtime.retries.policy.Acceptor
import aws.smithy.kotlin.runtime.retries.policy.AcceptorRetryPolicy
import aws.smithy.kotlin.runtime.retries.policy.ErrorTypeAcceptor
import aws.smithy.kotlin.runtime.retries.policy.OutputAcceptor
import aws.smithy.kotlin.runtime.retries.policy.RetryDirective
import kotlin.time.Duration.Companion.milliseconds
/**
* Wait until a Component is deployed. Use this after invoking CreateComponent or UpdateComponent
*/
public suspend fun ProtonClient.waitUntilComponentDeployed(request: GetComponentRequest): Outcome {
val strategy = StandardRetryStrategy {
maxAttempts = 20
tokenBucket = InfiniteTokenBucket
delayProvider {
initialDelay = 5_000.milliseconds
scaleFactor = 1.5
jitter = 1.0
maxBackoff = 4_999_000.milliseconds
}
}
val acceptors = listOf>(
OutputAcceptor(RetryDirective.TerminateAndSucceed) {
val component = it.component
val deploymentStatus = component?.deploymentStatus?.value
deploymentStatus == "SUCCEEDED"
},
OutputAcceptor(RetryDirective.TerminateAndFail) {
val component = it.component
val deploymentStatus = component?.deploymentStatus?.value
deploymentStatus == "FAILED"
},
)
val policy = AcceptorRetryPolicy(request, acceptors)
return strategy.retry(policy) { getComponent(request) }
}
/**
* Wait until a Component is deployed. Use this after invoking CreateComponent or UpdateComponent
*/
public suspend fun ProtonClient.waitUntilComponentDeployed(block: GetComponentRequest.Builder.() -> Unit): Outcome =
waitUntilComponentDeployed(GetComponentRequest.Builder().apply(block).build())
/**
* Wait until a Component is deleted. Use this after invoking DeleteComponent
*/
public suspend fun ProtonClient.waitUntilComponentDeleted(request: GetComponentRequest): Outcome {
val strategy = StandardRetryStrategy {
maxAttempts = 20
tokenBucket = InfiniteTokenBucket
delayProvider {
initialDelay = 5_000.milliseconds
scaleFactor = 1.5
jitter = 1.0
maxBackoff = 4_999_000.milliseconds
}
}
val acceptors = listOf>(
ErrorTypeAcceptor(RetryDirective.TerminateAndSucceed, "ResourceNotFoundException"),
OutputAcceptor(RetryDirective.TerminateAndFail) {
val component = it.component
val deploymentStatus = component?.deploymentStatus?.value
deploymentStatus == "DELETE_FAILED"
},
)
val policy = AcceptorRetryPolicy(request, acceptors)
return strategy.retry(policy) { getComponent(request) }
}
/**
* Wait until a Component is deleted. Use this after invoking DeleteComponent
*/
public suspend fun ProtonClient.waitUntilComponentDeleted(block: GetComponentRequest.Builder.() -> Unit): Outcome =
waitUntilComponentDeleted(GetComponentRequest.Builder().apply(block).build())
/**
* Wait until an Environment is deployed. Use this after invoking CreateEnvironment or UpdateEnvironment
*/
public suspend fun ProtonClient.waitUntilEnvironmentDeployed(request: GetEnvironmentRequest): Outcome {
val strategy = StandardRetryStrategy {
maxAttempts = 20
tokenBucket = InfiniteTokenBucket
delayProvider {
initialDelay = 5_000.milliseconds
scaleFactor = 1.5
jitter = 1.0
maxBackoff = 4_999_000.milliseconds
}
}
val acceptors = listOf>(
OutputAcceptor(RetryDirective.TerminateAndSucceed) {
val environment = it.environment
val deploymentStatus = environment?.deploymentStatus?.value
deploymentStatus == "SUCCEEDED"
},
OutputAcceptor(RetryDirective.TerminateAndFail) {
val environment = it.environment
val deploymentStatus = environment?.deploymentStatus?.value
deploymentStatus == "FAILED"
},
)
val policy = AcceptorRetryPolicy(request, acceptors)
return strategy.retry(policy) { getEnvironment(request) }
}
/**
* Wait until an Environment is deployed. Use this after invoking CreateEnvironment or UpdateEnvironment
*/
public suspend fun ProtonClient.waitUntilEnvironmentDeployed(block: GetEnvironmentRequest.Builder.() -> Unit): Outcome =
waitUntilEnvironmentDeployed(GetEnvironmentRequest.Builder().apply(block).build())
/**
* Wait until an EnvironmentTemplateVersion is registered. Use this after invoking CreateEnvironmentTemplateVersion
*/
public suspend fun ProtonClient.waitUntilEnvironmentTemplateVersionRegistered(request: GetEnvironmentTemplateVersionRequest): Outcome {
val strategy = StandardRetryStrategy {
maxAttempts = 20
tokenBucket = InfiniteTokenBucket
delayProvider {
initialDelay = 2_000.milliseconds
scaleFactor = 1.5
jitter = 1.0
maxBackoff = 300_000.milliseconds
}
}
val acceptors = listOf>(
OutputAcceptor(RetryDirective.TerminateAndSucceed) {
val environmentTemplateVersion = it.environmentTemplateVersion
val status = environmentTemplateVersion?.status?.value
status == "DRAFT"
},
OutputAcceptor(RetryDirective.TerminateAndSucceed) {
val environmentTemplateVersion = it.environmentTemplateVersion
val status = environmentTemplateVersion?.status?.value
status == "PUBLISHED"
},
OutputAcceptor(RetryDirective.TerminateAndFail) {
val environmentTemplateVersion = it.environmentTemplateVersion
val status = environmentTemplateVersion?.status?.value
status == "REGISTRATION_FAILED"
},
)
val policy = AcceptorRetryPolicy(request, acceptors)
return strategy.retry(policy) { getEnvironmentTemplateVersion(request) }
}
/**
* Wait until an EnvironmentTemplateVersion is registered. Use this after invoking CreateEnvironmentTemplateVersion
*/
public suspend fun ProtonClient.waitUntilEnvironmentTemplateVersionRegistered(block: GetEnvironmentTemplateVersionRequest.Builder.() -> Unit): Outcome =
waitUntilEnvironmentTemplateVersionRegistered(GetEnvironmentTemplateVersionRequest.Builder().apply(block).build())
/**
* Wait until an Service has deployed its instances and possibly pipeline. Use this after invoking CreateService
*/
public suspend fun ProtonClient.waitUntilServiceCreated(request: GetServiceRequest): Outcome {
val strategy = StandardRetryStrategy {
maxAttempts = 20
tokenBucket = InfiniteTokenBucket
delayProvider {
initialDelay = 5_000.milliseconds
scaleFactor = 1.5
jitter = 1.0
maxBackoff = 4_999_000.milliseconds
}
}
val acceptors = listOf>(
OutputAcceptor(RetryDirective.TerminateAndSucceed) {
val service = it.service
val status = service?.status?.value
status == "ACTIVE"
},
OutputAcceptor(RetryDirective.TerminateAndFail) {
val service = it.service
val status = service?.status?.value
status == "CREATE_FAILED_CLEANUP_COMPLETE"
},
OutputAcceptor(RetryDirective.TerminateAndFail) {
val service = it.service
val status = service?.status?.value
status == "CREATE_FAILED_CLEANUP_FAILED"
},
OutputAcceptor(RetryDirective.TerminateAndFail) {
val service = it.service
val status = service?.status?.value
status == "CREATE_FAILED"
},
)
val policy = AcceptorRetryPolicy(request, acceptors)
return strategy.retry(policy) { getService(request) }
}
/**
* Wait until an Service has deployed its instances and possibly pipeline. Use this after invoking CreateService
*/
public suspend fun ProtonClient.waitUntilServiceCreated(block: GetServiceRequest.Builder.() -> Unit): Outcome =
waitUntilServiceCreated(GetServiceRequest.Builder().apply(block).build())
/**
* Wait until a Service, its instances, and possibly pipeline have been deployed after UpdateService is invoked
*/
public suspend fun ProtonClient.waitUntilServiceUpdated(request: GetServiceRequest): Outcome {
val strategy = StandardRetryStrategy {
maxAttempts = 20
tokenBucket = InfiniteTokenBucket
delayProvider {
initialDelay = 5_000.milliseconds
scaleFactor = 1.5
jitter = 1.0
maxBackoff = 4_999_000.milliseconds
}
}
val acceptors = listOf>(
OutputAcceptor(RetryDirective.TerminateAndSucceed) {
val service = it.service
val status = service?.status?.value
status == "ACTIVE"
},
OutputAcceptor(RetryDirective.TerminateAndFail) {
val service = it.service
val status = service?.status?.value
status == "UPDATE_FAILED_CLEANUP_COMPLETE"
},
OutputAcceptor(RetryDirective.TerminateAndFail) {
val service = it.service
val status = service?.status?.value
status == "UPDATE_FAILED_CLEANUP_FAILED"
},
OutputAcceptor(RetryDirective.TerminateAndFail) {
val service = it.service
val status = service?.status?.value
status == "UPDATE_FAILED"
},
OutputAcceptor(RetryDirective.TerminateAndFail) {
val service = it.service
val status = service?.status?.value
status == "UPDATE_COMPLETE_CLEANUP_FAILED"
},
)
val policy = AcceptorRetryPolicy(request, acceptors)
return strategy.retry(policy) { getService(request) }
}
/**
* Wait until a Service, its instances, and possibly pipeline have been deployed after UpdateService is invoked
*/
public suspend fun ProtonClient.waitUntilServiceUpdated(block: GetServiceRequest.Builder.() -> Unit): Outcome =
waitUntilServiceUpdated(GetServiceRequest.Builder().apply(block).build())
/**
* Wait until a Service, its instances, and possibly pipeline have been deleted after DeleteService is invoked
*/
public suspend fun ProtonClient.waitUntilServiceDeleted(request: GetServiceRequest): Outcome {
val strategy = StandardRetryStrategy {
maxAttempts = 20
tokenBucket = InfiniteTokenBucket
delayProvider {
initialDelay = 5_000.milliseconds
scaleFactor = 1.5
jitter = 1.0
maxBackoff = 4_999_000.milliseconds
}
}
val acceptors = listOf>(
ErrorTypeAcceptor(RetryDirective.TerminateAndSucceed, "ResourceNotFoundException"),
OutputAcceptor(RetryDirective.TerminateAndFail) {
val service = it.service
val status = service?.status?.value
status == "DELETE_FAILED"
},
)
val policy = AcceptorRetryPolicy(request, acceptors)
return strategy.retry(policy) { getService(request) }
}
/**
* Wait until a Service, its instances, and possibly pipeline have been deleted after DeleteService is invoked
*/
public suspend fun ProtonClient.waitUntilServiceDeleted(block: GetServiceRequest.Builder.() -> Unit): Outcome =
waitUntilServiceDeleted(GetServiceRequest.Builder().apply(block).build())
/**
* Wait until an ServicePipeline is deployed. Use this after invoking CreateService or UpdateServicePipeline
*/
public suspend fun ProtonClient.waitUntilServicePipelineDeployed(request: GetServiceRequest): Outcome {
val strategy = StandardRetryStrategy {
maxAttempts = 20
tokenBucket = InfiniteTokenBucket
delayProvider {
initialDelay = 10_000.milliseconds
scaleFactor = 1.5
jitter = 1.0
maxBackoff = 3_600_000.milliseconds
}
}
val acceptors = listOf>(
OutputAcceptor(RetryDirective.TerminateAndSucceed) {
val service = it.service
val pipeline = service?.pipeline
val deploymentStatus = pipeline?.deploymentStatus?.value
deploymentStatus == "SUCCEEDED"
},
OutputAcceptor(RetryDirective.TerminateAndFail) {
val service = it.service
val pipeline = service?.pipeline
val deploymentStatus = pipeline?.deploymentStatus?.value
deploymentStatus == "FAILED"
},
)
val policy = AcceptorRetryPolicy(request, acceptors)
return strategy.retry(policy) { getService(request) }
}
/**
* Wait until an ServicePipeline is deployed. Use this after invoking CreateService or UpdateServicePipeline
*/
public suspend fun ProtonClient.waitUntilServicePipelineDeployed(block: GetServiceRequest.Builder.() -> Unit): Outcome =
waitUntilServicePipelineDeployed(GetServiceRequest.Builder().apply(block).build())
/**
* Wait until a ServiceInstance is deployed. Use this after invoking CreateService or UpdateServiceInstance
*/
public suspend fun ProtonClient.waitUntilServiceInstanceDeployed(request: GetServiceInstanceRequest): Outcome {
val strategy = StandardRetryStrategy {
maxAttempts = 20
tokenBucket = InfiniteTokenBucket
delayProvider {
initialDelay = 5_000.milliseconds
scaleFactor = 1.5
jitter = 1.0
maxBackoff = 4_999_000.milliseconds
}
}
val acceptors = listOf>(
OutputAcceptor(RetryDirective.TerminateAndSucceed) {
val serviceInstance = it.serviceInstance
val deploymentStatus = serviceInstance?.deploymentStatus?.value
deploymentStatus == "SUCCEEDED"
},
OutputAcceptor(RetryDirective.TerminateAndFail) {
val serviceInstance = it.serviceInstance
val deploymentStatus = serviceInstance?.deploymentStatus?.value
deploymentStatus == "FAILED"
},
)
val policy = AcceptorRetryPolicy(request, acceptors)
return strategy.retry(policy) { getServiceInstance(request) }
}
/**
* Wait until a ServiceInstance is deployed. Use this after invoking CreateService or UpdateServiceInstance
*/
public suspend fun ProtonClient.waitUntilServiceInstanceDeployed(block: GetServiceInstanceRequest.Builder.() -> Unit): Outcome =
waitUntilServiceInstanceDeployed(GetServiceInstanceRequest.Builder().apply(block).build())
/**
* Wait until a ServiceTemplateVersion is registered. Use this after invoking CreateServiceTemplateVersion
*/
public suspend fun ProtonClient.waitUntilServiceTemplateVersionRegistered(request: GetServiceTemplateVersionRequest): Outcome {
val strategy = StandardRetryStrategy {
maxAttempts = 20
tokenBucket = InfiniteTokenBucket
delayProvider {
initialDelay = 2_000.milliseconds
scaleFactor = 1.5
jitter = 1.0
maxBackoff = 300_000.milliseconds
}
}
val acceptors = listOf>(
OutputAcceptor(RetryDirective.TerminateAndSucceed) {
val serviceTemplateVersion = it.serviceTemplateVersion
val status = serviceTemplateVersion?.status?.value
status == "DRAFT"
},
OutputAcceptor(RetryDirective.TerminateAndSucceed) {
val serviceTemplateVersion = it.serviceTemplateVersion
val status = serviceTemplateVersion?.status?.value
status == "PUBLISHED"
},
OutputAcceptor(RetryDirective.TerminateAndFail) {
val serviceTemplateVersion = it.serviceTemplateVersion
val status = serviceTemplateVersion?.status?.value
status == "REGISTRATION_FAILED"
},
)
val policy = AcceptorRetryPolicy(request, acceptors)
return strategy.retry(policy) { getServiceTemplateVersion(request) }
}
/**
* Wait until a ServiceTemplateVersion is registered. Use this after invoking CreateServiceTemplateVersion
*/
public suspend fun ProtonClient.waitUntilServiceTemplateVersionRegistered(block: GetServiceTemplateVersionRequest.Builder.() -> Unit): Outcome =
waitUntilServiceTemplateVersionRegistered(GetServiceTemplateVersionRequest.Builder().apply(block).build())
© 2015 - 2025 Weber Informatics LLC | Privacy Policy