
io.github.vigoo.zioaws.route53resolver.model.FirewallConfig.scala Maven / Gradle / Ivy
package io.github.vigoo.zioaws.route53resolver.model
import zio.ZIO
import io.github.vigoo.zioaws.route53resolver.model.primitives.{
AccountId,
ResourceId
}
import io.github.vigoo.zioaws.core.{AwsError, BuilderHelper}
import scala.jdk.CollectionConverters._
final case class FirewallConfig(
id: Option[ResourceId] = None,
resourceId: Option[ResourceId] = None,
ownerId: Option[AccountId] = None,
firewallFailOpen: Option[
io.github.vigoo.zioaws.route53resolver.model.FirewallFailOpenStatus
] = None
) {
def buildAwsValue()
: software.amazon.awssdk.services.route53resolver.model.FirewallConfig = {
import FirewallConfig.zioAwsBuilderHelper.BuilderOps
software.amazon.awssdk.services.route53resolver.model.FirewallConfig
.builder()
.optionallyWith(id.map(value => value: java.lang.String))(_.id)
.optionallyWith(resourceId.map(value => value: java.lang.String))(
_.resourceId
)
.optionallyWith(ownerId.map(value => value: java.lang.String))(_.ownerId)
.optionallyWith(firewallFailOpen.map(value => value.unwrap))(
_.firewallFailOpen
)
.build()
}
def asReadOnly
: io.github.vigoo.zioaws.route53resolver.model.FirewallConfig.ReadOnly =
io.github.vigoo.zioaws.route53resolver.model.FirewallConfig
.wrap(buildAwsValue())
}
object FirewallConfig {
private lazy val zioAwsBuilderHelper: BuilderHelper[
software.amazon.awssdk.services.route53resolver.model.FirewallConfig
] = BuilderHelper.apply
trait ReadOnly {
def editable: io.github.vigoo.zioaws.route53resolver.model.FirewallConfig =
io.github.vigoo.zioaws.route53resolver.model.FirewallConfig(
idValue.map(value => value),
resourceIdValue.map(value => value),
ownerIdValue.map(value => value),
firewallFailOpenValue.map(value => value)
)
def idValue: Option[ResourceId]
def resourceIdValue: Option[ResourceId]
def ownerIdValue: Option[AccountId]
def firewallFailOpenValue: Option[
io.github.vigoo.zioaws.route53resolver.model.FirewallFailOpenStatus
]
def id: ZIO[Any, AwsError, ResourceId] =
AwsError.unwrapOptionField("id", idValue)
def resourceId: ZIO[Any, AwsError, ResourceId] =
AwsError.unwrapOptionField("resourceId", resourceIdValue)
def ownerId: ZIO[Any, AwsError, AccountId] =
AwsError.unwrapOptionField("ownerId", ownerIdValue)
def firewallFailOpen: ZIO[
Any,
AwsError,
io.github.vigoo.zioaws.route53resolver.model.FirewallFailOpenStatus
] = AwsError.unwrapOptionField("firewallFailOpen", firewallFailOpenValue)
}
private class Wrapper(
impl: software.amazon.awssdk.services.route53resolver.model.FirewallConfig
) extends io.github.vigoo.zioaws.route53resolver.model.FirewallConfig.ReadOnly {
override def idValue: Option[ResourceId] =
scala.Option(impl.id()).map(value => value: ResourceId)
override def resourceIdValue: Option[ResourceId] =
scala.Option(impl.resourceId()).map(value => value: ResourceId)
override def ownerIdValue: Option[AccountId] =
scala.Option(impl.ownerId()).map(value => value: AccountId)
override def firewallFailOpenValue: Option[
io.github.vigoo.zioaws.route53resolver.model.FirewallFailOpenStatus
] = scala
.Option(impl.firewallFailOpen())
.map(value =>
io.github.vigoo.zioaws.route53resolver.model.FirewallFailOpenStatus
.wrap(value)
)
}
def wrap(
impl: software.amazon.awssdk.services.route53resolver.model.FirewallConfig
): io.github.vigoo.zioaws.route53resolver.model.FirewallConfig.ReadOnly =
new Wrapper(impl)
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy