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

io.github.vigoo.zioaws.route53resolver.model.FirewallRuleGroupAssociation.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.{
  CreatorRequestId,
  Priority,
  Arn,
  Rfc3339TimeString,
  Name,
  ResourceId,
  StatusMessage,
  ServicePrinciple
}
import io.github.vigoo.zioaws.core.{AwsError, BuilderHelper}
import scala.jdk.CollectionConverters._
final case class FirewallRuleGroupAssociation(
    id: Option[ResourceId] = None,
    arn: Option[Arn] = None,
    firewallRuleGroupId: Option[ResourceId] = None,
    vpcId: Option[ResourceId] = None,
    name: Option[Name] = None,
    priority: Option[Priority] = None,
    mutationProtection: Option[
      io.github.vigoo.zioaws.route53resolver.model.MutationProtectionStatus
    ] = None,
    managedOwnerName: Option[ServicePrinciple] = None,
    status: Option[
      io.github.vigoo.zioaws.route53resolver.model.FirewallRuleGroupAssociationStatus
    ] = None,
    statusMessage: Option[StatusMessage] = None,
    creatorRequestId: Option[CreatorRequestId] = None,
    creationTime: Option[Rfc3339TimeString] = None,
    modificationTime: Option[Rfc3339TimeString] = None
) {
  def buildAwsValue()
      : software.amazon.awssdk.services.route53resolver.model.FirewallRuleGroupAssociation = {
    import FirewallRuleGroupAssociation.zioAwsBuilderHelper.BuilderOps
    software.amazon.awssdk.services.route53resolver.model.FirewallRuleGroupAssociation
      .builder()
      .optionallyWith(id.map(value => value: java.lang.String))(_.id)
      .optionallyWith(arn.map(value => value: java.lang.String))(_.arn)
      .optionallyWith(
        firewallRuleGroupId.map(value => value: java.lang.String)
      )(_.firewallRuleGroupId)
      .optionallyWith(vpcId.map(value => value: java.lang.String))(_.vpcId)
      .optionallyWith(name.map(value => value: java.lang.String))(_.name)
      .optionallyWith(priority.map(value => value: Integer))(_.priority)
      .optionallyWith(mutationProtection.map(value => value.unwrap))(
        _.mutationProtection
      )
      .optionallyWith(managedOwnerName.map(value => value: java.lang.String))(
        _.managedOwnerName
      )
      .optionallyWith(status.map(value => value.unwrap))(_.status)
      .optionallyWith(statusMessage.map(value => value: java.lang.String))(
        _.statusMessage
      )
      .optionallyWith(creatorRequestId.map(value => value: java.lang.String))(
        _.creatorRequestId
      )
      .optionallyWith(creationTime.map(value => value: java.lang.String))(
        _.creationTime
      )
      .optionallyWith(modificationTime.map(value => value: java.lang.String))(
        _.modificationTime
      )
      .build()
  }
  def asReadOnly
      : io.github.vigoo.zioaws.route53resolver.model.FirewallRuleGroupAssociation.ReadOnly =
    io.github.vigoo.zioaws.route53resolver.model.FirewallRuleGroupAssociation
      .wrap(buildAwsValue())
}
object FirewallRuleGroupAssociation {
  private lazy val zioAwsBuilderHelper: BuilderHelper[
    software.amazon.awssdk.services.route53resolver.model.FirewallRuleGroupAssociation
  ] = BuilderHelper.apply
  trait ReadOnly {
    def editable
        : io.github.vigoo.zioaws.route53resolver.model.FirewallRuleGroupAssociation =
      io.github.vigoo.zioaws.route53resolver.model.FirewallRuleGroupAssociation(
        idValue.map(value => value),
        arnValue.map(value => value),
        firewallRuleGroupIdValue.map(value => value),
        vpcIdValue.map(value => value),
        nameValue.map(value => value),
        priorityValue.map(value => value),
        mutationProtectionValue.map(value => value),
        managedOwnerNameValue.map(value => value),
        statusValue.map(value => value),
        statusMessageValue.map(value => value),
        creatorRequestIdValue.map(value => value),
        creationTimeValue.map(value => value),
        modificationTimeValue.map(value => value)
      )
    def idValue: Option[ResourceId]
    def arnValue: Option[Arn]
    def firewallRuleGroupIdValue: Option[ResourceId]
    def vpcIdValue: Option[ResourceId]
    def nameValue: Option[Name]
    def priorityValue: Option[Priority]
    def mutationProtectionValue: Option[
      io.github.vigoo.zioaws.route53resolver.model.MutationProtectionStatus
    ]
    def managedOwnerNameValue: Option[ServicePrinciple]
    def statusValue: Option[
      io.github.vigoo.zioaws.route53resolver.model.FirewallRuleGroupAssociationStatus
    ]
    def statusMessageValue: Option[StatusMessage]
    def creatorRequestIdValue: Option[CreatorRequestId]
    def creationTimeValue: Option[Rfc3339TimeString]
    def modificationTimeValue: Option[Rfc3339TimeString]
    def id: ZIO[Any, AwsError, ResourceId] =
      AwsError.unwrapOptionField("id", idValue)
    def arn: ZIO[Any, AwsError, Arn] =
      AwsError.unwrapOptionField("arn", arnValue)
    def firewallRuleGroupId: ZIO[Any, AwsError, ResourceId] = AwsError
      .unwrapOptionField("firewallRuleGroupId", firewallRuleGroupIdValue)
    def vpcId: ZIO[Any, AwsError, ResourceId] =
      AwsError.unwrapOptionField("vpcId", vpcIdValue)
    def name: ZIO[Any, AwsError, Name] =
      AwsError.unwrapOptionField("name", nameValue)
    def priority: ZIO[Any, AwsError, Priority] =
      AwsError.unwrapOptionField("priority", priorityValue)
    def mutationProtection: ZIO[
      Any,
      AwsError,
      io.github.vigoo.zioaws.route53resolver.model.MutationProtectionStatus
    ] =
      AwsError.unwrapOptionField("mutationProtection", mutationProtectionValue)
    def managedOwnerName: ZIO[Any, AwsError, ServicePrinciple] =
      AwsError.unwrapOptionField("managedOwnerName", managedOwnerNameValue)
    def status: ZIO[
      Any,
      AwsError,
      io.github.vigoo.zioaws.route53resolver.model.FirewallRuleGroupAssociationStatus
    ] = AwsError.unwrapOptionField("status", statusValue)
    def statusMessage: ZIO[Any, AwsError, StatusMessage] =
      AwsError.unwrapOptionField("statusMessage", statusMessageValue)
    def creatorRequestId: ZIO[Any, AwsError, CreatorRequestId] =
      AwsError.unwrapOptionField("creatorRequestId", creatorRequestIdValue)
    def creationTime: ZIO[Any, AwsError, Rfc3339TimeString] =
      AwsError.unwrapOptionField("creationTime", creationTimeValue)
    def modificationTime: ZIO[Any, AwsError, Rfc3339TimeString] =
      AwsError.unwrapOptionField("modificationTime", modificationTimeValue)
  }
  private class Wrapper(
      impl: software.amazon.awssdk.services.route53resolver.model.FirewallRuleGroupAssociation
  ) extends io.github.vigoo.zioaws.route53resolver.model.FirewallRuleGroupAssociation.ReadOnly {
    override def idValue: Option[ResourceId] =
      scala.Option(impl.id()).map(value => value: ResourceId)
    override def arnValue: Option[Arn] =
      scala.Option(impl.arn()).map(value => value: Arn)
    override def firewallRuleGroupIdValue: Option[ResourceId] =
      scala.Option(impl.firewallRuleGroupId()).map(value => value: ResourceId)
    override def vpcIdValue: Option[ResourceId] =
      scala.Option(impl.vpcId()).map(value => value: ResourceId)
    override def nameValue: Option[Name] =
      scala.Option(impl.name()).map(value => value: Name)
    override def priorityValue: Option[Priority] =
      scala.Option(impl.priority()).map(value => value: Priority)
    override def mutationProtectionValue: Option[
      io.github.vigoo.zioaws.route53resolver.model.MutationProtectionStatus
    ] = scala
      .Option(impl.mutationProtection())
      .map(value =>
        io.github.vigoo.zioaws.route53resolver.model.MutationProtectionStatus
          .wrap(value)
      )
    override def managedOwnerNameValue: Option[ServicePrinciple] = scala
      .Option(impl.managedOwnerName())
      .map(value => value: ServicePrinciple)
    override def statusValue: Option[
      io.github.vigoo.zioaws.route53resolver.model.FirewallRuleGroupAssociationStatus
    ] = scala
      .Option(impl.status())
      .map(value =>
        io.github.vigoo.zioaws.route53resolver.model.FirewallRuleGroupAssociationStatus
          .wrap(value)
      )
    override def statusMessageValue: Option[StatusMessage] =
      scala.Option(impl.statusMessage()).map(value => value: StatusMessage)
    override def creatorRequestIdValue: Option[CreatorRequestId] = scala
      .Option(impl.creatorRequestId())
      .map(value => value: CreatorRequestId)
    override def creationTimeValue: Option[Rfc3339TimeString] =
      scala.Option(impl.creationTime()).map(value => value: Rfc3339TimeString)
    override def modificationTimeValue: Option[Rfc3339TimeString] = scala
      .Option(impl.modificationTime())
      .map(value => value: Rfc3339TimeString)
  }
  def wrap(
      impl: software.amazon.awssdk.services.route53resolver.model.FirewallRuleGroupAssociation
  ): io.github.vigoo.zioaws.route53resolver.model.FirewallRuleGroupAssociation.ReadOnly =
    new Wrapper(impl)
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy