
io.github.vigoo.zioaws.route53resolver.model.UpdateFirewallRuleRequest.scala Maven / Gradle / Ivy
package io.github.vigoo.zioaws.route53resolver.model
import java.lang.Integer
import zio.ZIO
import io.github.vigoo.zioaws.route53resolver.model.primitives.{
BlockOverrideTtl,
BlockOverrideDomain,
Priority,
Name,
ResourceId
}
import io.github.vigoo.zioaws.core.{AwsError, BuilderHelper}
import scala.jdk.CollectionConverters._
final case class UpdateFirewallRuleRequest(
firewallRuleGroupId: ResourceId,
firewallDomainListId: ResourceId,
priority: Option[Priority] = None,
action: Option[io.github.vigoo.zioaws.route53resolver.model.Action] = None,
blockResponse: Option[
io.github.vigoo.zioaws.route53resolver.model.BlockResponse
] = None,
blockOverrideDomain: Option[BlockOverrideDomain] = None,
blockOverrideDnsType: Option[
io.github.vigoo.zioaws.route53resolver.model.BlockOverrideDnsType
] = None,
blockOverrideTtl: Option[BlockOverrideTtl] = None,
name: Option[Name] = None
) {
def buildAwsValue()
: software.amazon.awssdk.services.route53resolver.model.UpdateFirewallRuleRequest = {
import UpdateFirewallRuleRequest.zioAwsBuilderHelper.BuilderOps
software.amazon.awssdk.services.route53resolver.model.UpdateFirewallRuleRequest
.builder()
.firewallRuleGroupId(firewallRuleGroupId: java.lang.String)
.firewallDomainListId(firewallDomainListId: java.lang.String)
.optionallyWith(priority.map(value => value: Integer))(_.priority)
.optionallyWith(action.map(value => value.unwrap))(_.action)
.optionallyWith(blockResponse.map(value => value.unwrap))(_.blockResponse)
.optionallyWith(
blockOverrideDomain.map(value => value: java.lang.String)
)(_.blockOverrideDomain)
.optionallyWith(blockOverrideDnsType.map(value => value.unwrap))(
_.blockOverrideDnsType
)
.optionallyWith(blockOverrideTtl.map(value => value: Integer))(
_.blockOverrideTtl
)
.optionallyWith(name.map(value => value: java.lang.String))(_.name)
.build()
}
def asReadOnly
: io.github.vigoo.zioaws.route53resolver.model.UpdateFirewallRuleRequest.ReadOnly =
io.github.vigoo.zioaws.route53resolver.model.UpdateFirewallRuleRequest
.wrap(buildAwsValue())
}
object UpdateFirewallRuleRequest {
private lazy val zioAwsBuilderHelper: BuilderHelper[
software.amazon.awssdk.services.route53resolver.model.UpdateFirewallRuleRequest
] = BuilderHelper.apply
trait ReadOnly {
def editable
: io.github.vigoo.zioaws.route53resolver.model.UpdateFirewallRuleRequest =
io.github.vigoo.zioaws.route53resolver.model.UpdateFirewallRuleRequest(
firewallRuleGroupIdValue,
firewallDomainListIdValue,
priorityValue.map(value => value),
actionValue.map(value => value),
blockResponseValue.map(value => value),
blockOverrideDomainValue.map(value => value),
blockOverrideDnsTypeValue.map(value => value),
blockOverrideTtlValue.map(value => value),
nameValue.map(value => value)
)
def firewallRuleGroupIdValue: ResourceId
def firewallDomainListIdValue: ResourceId
def priorityValue: Option[Priority]
def actionValue: Option[io.github.vigoo.zioaws.route53resolver.model.Action]
def blockResponseValue
: Option[io.github.vigoo.zioaws.route53resolver.model.BlockResponse]
def blockOverrideDomainValue: Option[BlockOverrideDomain]
def blockOverrideDnsTypeValue: Option[
io.github.vigoo.zioaws.route53resolver.model.BlockOverrideDnsType
]
def blockOverrideTtlValue: Option[BlockOverrideTtl]
def nameValue: Option[Name]
def firewallRuleGroupId: ZIO[Any, Nothing, ResourceId] =
ZIO.succeed(firewallRuleGroupIdValue)
def firewallDomainListId: ZIO[Any, Nothing, ResourceId] =
ZIO.succeed(firewallDomainListIdValue)
def priority: ZIO[Any, AwsError, Priority] =
AwsError.unwrapOptionField("priority", priorityValue)
def action: ZIO[
Any,
AwsError,
io.github.vigoo.zioaws.route53resolver.model.Action
] = AwsError.unwrapOptionField("action", actionValue)
def blockResponse: ZIO[
Any,
AwsError,
io.github.vigoo.zioaws.route53resolver.model.BlockResponse
] = AwsError.unwrapOptionField("blockResponse", blockResponseValue)
def blockOverrideDomain: ZIO[Any, AwsError, BlockOverrideDomain] = AwsError
.unwrapOptionField("blockOverrideDomain", blockOverrideDomainValue)
def blockOverrideDnsType: ZIO[
Any,
AwsError,
io.github.vigoo.zioaws.route53resolver.model.BlockOverrideDnsType
] = AwsError.unwrapOptionField(
"blockOverrideDnsType",
blockOverrideDnsTypeValue
)
def blockOverrideTtl: ZIO[Any, AwsError, BlockOverrideTtl] =
AwsError.unwrapOptionField("blockOverrideTtl", blockOverrideTtlValue)
def name: ZIO[Any, AwsError, Name] =
AwsError.unwrapOptionField("name", nameValue)
}
private class Wrapper(
impl: software.amazon.awssdk.services.route53resolver.model.UpdateFirewallRuleRequest
) extends io.github.vigoo.zioaws.route53resolver.model.UpdateFirewallRuleRequest.ReadOnly {
override def firewallRuleGroupIdValue: ResourceId =
impl.firewallRuleGroupId(): ResourceId
override def firewallDomainListIdValue: ResourceId =
impl.firewallDomainListId(): ResourceId
override def priorityValue: Option[Priority] =
scala.Option(impl.priority()).map(value => value: Priority)
override def actionValue
: Option[io.github.vigoo.zioaws.route53resolver.model.Action] = scala
.Option(impl.action())
.map(value =>
io.github.vigoo.zioaws.route53resolver.model.Action.wrap(value)
)
override def blockResponseValue
: Option[io.github.vigoo.zioaws.route53resolver.model.BlockResponse] =
scala
.Option(impl.blockResponse())
.map(value =>
io.github.vigoo.zioaws.route53resolver.model.BlockResponse.wrap(value)
)
override def blockOverrideDomainValue: Option[BlockOverrideDomain] = scala
.Option(impl.blockOverrideDomain())
.map(value => value: BlockOverrideDomain)
override def blockOverrideDnsTypeValue: Option[
io.github.vigoo.zioaws.route53resolver.model.BlockOverrideDnsType
] = scala
.Option(impl.blockOverrideDnsType())
.map(value =>
io.github.vigoo.zioaws.route53resolver.model.BlockOverrideDnsType
.wrap(value)
)
override def blockOverrideTtlValue: Option[BlockOverrideTtl] = scala
.Option(impl.blockOverrideTtl())
.map(value => value: BlockOverrideTtl)
override def nameValue: Option[Name] =
scala.Option(impl.name()).map(value => value: Name)
}
def wrap(
impl: software.amazon.awssdk.services.route53resolver.model.UpdateFirewallRuleRequest
): io.github.vigoo.zioaws.route53resolver.model.UpdateFirewallRuleRequest.ReadOnly =
new Wrapper(impl)
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy