All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.github.vigoo.zioaws.route53resolver.model.CreateFirewallRuleRequest.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,
  CreatorRequestId,
  Priority,
  Name,
  ResourceId
}
import io.github.vigoo.zioaws.core.{AwsError, BuilderHelper}
import scala.jdk.CollectionConverters._
final case class CreateFirewallRuleRequest(
    creatorRequestId: CreatorRequestId,
    firewallRuleGroupId: ResourceId,
    firewallDomainListId: ResourceId,
    priority: Priority,
    action: io.github.vigoo.zioaws.route53resolver.model.Action,
    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: Name
) {
  def buildAwsValue()
      : software.amazon.awssdk.services.route53resolver.model.CreateFirewallRuleRequest = {
    import CreateFirewallRuleRequest.zioAwsBuilderHelper.BuilderOps
    software.amazon.awssdk.services.route53resolver.model.CreateFirewallRuleRequest
      .builder()
      .creatorRequestId(creatorRequestId: java.lang.String)
      .firewallRuleGroupId(firewallRuleGroupId: java.lang.String)
      .firewallDomainListId(firewallDomainListId: java.lang.String)
      .priority(priority: Integer)
      .action(action.unwrap)
      .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
      )
      .name(name: java.lang.String)
      .build()
  }
  def asReadOnly
      : io.github.vigoo.zioaws.route53resolver.model.CreateFirewallRuleRequest.ReadOnly =
    io.github.vigoo.zioaws.route53resolver.model.CreateFirewallRuleRequest
      .wrap(buildAwsValue())
}
object CreateFirewallRuleRequest {
  private lazy val zioAwsBuilderHelper: BuilderHelper[
    software.amazon.awssdk.services.route53resolver.model.CreateFirewallRuleRequest
  ] = BuilderHelper.apply
  trait ReadOnly {
    def editable
        : io.github.vigoo.zioaws.route53resolver.model.CreateFirewallRuleRequest =
      io.github.vigoo.zioaws.route53resolver.model.CreateFirewallRuleRequest(
        creatorRequestIdValue,
        firewallRuleGroupIdValue,
        firewallDomainListIdValue,
        priorityValue,
        actionValue,
        blockResponseValue.map(value => value),
        blockOverrideDomainValue.map(value => value),
        blockOverrideDnsTypeValue.map(value => value),
        blockOverrideTtlValue.map(value => value),
        nameValue
      )
    def creatorRequestIdValue: CreatorRequestId
    def firewallRuleGroupIdValue: ResourceId
    def firewallDomainListIdValue: ResourceId
    def priorityValue: Priority
    def actionValue: 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: Name
    def creatorRequestId: ZIO[Any, Nothing, CreatorRequestId] =
      ZIO.succeed(creatorRequestIdValue)
    def firewallRuleGroupId: ZIO[Any, Nothing, ResourceId] =
      ZIO.succeed(firewallRuleGroupIdValue)
    def firewallDomainListId: ZIO[Any, Nothing, ResourceId] =
      ZIO.succeed(firewallDomainListIdValue)
    def priority: ZIO[Any, Nothing, Priority] = ZIO.succeed(priorityValue)
    def action: ZIO[
      Any,
      Nothing,
      io.github.vigoo.zioaws.route53resolver.model.Action
    ] = ZIO.succeed(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, Nothing, Name] = ZIO.succeed(nameValue)
  }
  private class Wrapper(
      impl: software.amazon.awssdk.services.route53resolver.model.CreateFirewallRuleRequest
  ) extends io.github.vigoo.zioaws.route53resolver.model.CreateFirewallRuleRequest.ReadOnly {
    override def creatorRequestIdValue: CreatorRequestId =
      impl.creatorRequestId(): CreatorRequestId
    override def firewallRuleGroupIdValue: ResourceId =
      impl.firewallRuleGroupId(): ResourceId
    override def firewallDomainListIdValue: ResourceId =
      impl.firewallDomainListId(): ResourceId
    override def priorityValue: Priority = impl.priority(): Priority
    override def actionValue
        : io.github.vigoo.zioaws.route53resolver.model.Action =
      io.github.vigoo.zioaws.route53resolver.model.Action.wrap(impl.action())
    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: Name = impl.name(): Name
  }
  def wrap(
      impl: software.amazon.awssdk.services.route53resolver.model.CreateFirewallRuleRequest
  ): io.github.vigoo.zioaws.route53resolver.model.CreateFirewallRuleRequest.ReadOnly =
    new Wrapper(impl)
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy