
io.github.vigoo.zioaws.codepipeline.model.WebhookAuthConfiguration.scala Maven / Gradle / Ivy
package io.github.vigoo.zioaws.codepipeline.model
import zio.ZIO
import io.github.vigoo.zioaws.codepipeline.model.primitives.{
WebhookAuthConfigurationSecretToken,
WebhookAuthConfigurationAllowedIPRange
}
import io.github.vigoo.zioaws.core.{AwsError, BuilderHelper}
import scala.jdk.CollectionConverters._
final case class WebhookAuthConfiguration(
allowedIPRange: Option[WebhookAuthConfigurationAllowedIPRange] = None,
secretToken: Option[WebhookAuthConfigurationSecretToken] = None
) {
def buildAwsValue()
: software.amazon.awssdk.services.codepipeline.model.WebhookAuthConfiguration = {
import WebhookAuthConfiguration.zioAwsBuilderHelper.BuilderOps
software.amazon.awssdk.services.codepipeline.model.WebhookAuthConfiguration
.builder()
.optionallyWith(allowedIPRange.map(value => value: java.lang.String))(
_.allowedIPRange
)
.optionallyWith(secretToken.map(value => value: java.lang.String))(
_.secretToken
)
.build()
}
def asReadOnly
: io.github.vigoo.zioaws.codepipeline.model.WebhookAuthConfiguration.ReadOnly =
io.github.vigoo.zioaws.codepipeline.model.WebhookAuthConfiguration
.wrap(buildAwsValue())
}
object WebhookAuthConfiguration {
private lazy val zioAwsBuilderHelper: BuilderHelper[
software.amazon.awssdk.services.codepipeline.model.WebhookAuthConfiguration
] = BuilderHelper.apply
trait ReadOnly {
def editable
: io.github.vigoo.zioaws.codepipeline.model.WebhookAuthConfiguration =
io.github.vigoo.zioaws.codepipeline.model.WebhookAuthConfiguration(
allowedIPRangeValue.map(value => value),
secretTokenValue.map(value => value)
)
def allowedIPRangeValue: Option[WebhookAuthConfigurationAllowedIPRange]
def secretTokenValue: Option[WebhookAuthConfigurationSecretToken]
def allowedIPRange
: ZIO[Any, AwsError, WebhookAuthConfigurationAllowedIPRange] =
AwsError.unwrapOptionField("allowedIPRange", allowedIPRangeValue)
def secretToken: ZIO[Any, AwsError, WebhookAuthConfigurationSecretToken] =
AwsError.unwrapOptionField("secretToken", secretTokenValue)
}
private class Wrapper(
impl: software.amazon.awssdk.services.codepipeline.model.WebhookAuthConfiguration
) extends io.github.vigoo.zioaws.codepipeline.model.WebhookAuthConfiguration.ReadOnly {
override def allowedIPRangeValue
: Option[WebhookAuthConfigurationAllowedIPRange] = scala
.Option(impl.allowedIPRange())
.map(value => value: WebhookAuthConfigurationAllowedIPRange)
override def secretTokenValue: Option[WebhookAuthConfigurationSecretToken] =
scala
.Option(impl.secretToken())
.map(value => value: WebhookAuthConfigurationSecretToken)
}
def wrap(
impl: software.amazon.awssdk.services.codepipeline.model.WebhookAuthConfiguration
): io.github.vigoo.zioaws.codepipeline.model.WebhookAuthConfiguration.ReadOnly =
new Wrapper(impl)
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy