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

io.github.vigoo.zioaws.datasync.model.CreateLocationHdfsRequest.scala Maven / Gradle / Ivy

package io.github.vigoo.zioaws.datasync.model
import java.lang.Integer
import zio.ZIO
import io.github.vigoo.zioaws.core.{AwsError, BuilderHelper}
import io.github.vigoo.zioaws.datasync.model.primitives.{
  KerberosKeytabFile,
  KerberosPrincipal,
  KerberosKrb5ConfFile,
  HdfsReplicationFactor,
  HdfsUser,
  HdfsSubdirectory,
  KmsKeyProviderUri,
  AgentArn,
  HdfsBlockSize
}
import scala.jdk.CollectionConverters._
final case class CreateLocationHdfsRequest(
    subdirectory: Option[HdfsSubdirectory] = None,
    nameNodes: Iterable[io.github.vigoo.zioaws.datasync.model.HdfsNameNode],
    blockSize: Option[HdfsBlockSize] = None,
    replicationFactor: Option[HdfsReplicationFactor] = None,
    kmsKeyProviderUri: Option[KmsKeyProviderUri] = None,
    qopConfiguration: Option[
      io.github.vigoo.zioaws.datasync.model.QopConfiguration
    ] = None,
    authenticationType: io.github.vigoo.zioaws.datasync.model.HdfsAuthenticationType,
    simpleUser: Option[HdfsUser] = None,
    kerberosPrincipal: Option[KerberosPrincipal] = None,
    kerberosKeytab: Option[KerberosKeytabFile] = None,
    kerberosKrb5Conf: Option[KerberosKrb5ConfFile] = None,
    agentArns: Iterable[AgentArn],
    tags: Option[Iterable[io.github.vigoo.zioaws.datasync.model.TagListEntry]] =
      None
) {
  def buildAwsValue()
      : software.amazon.awssdk.services.datasync.model.CreateLocationHdfsRequest = {
    import CreateLocationHdfsRequest.zioAwsBuilderHelper.BuilderOps
    software.amazon.awssdk.services.datasync.model.CreateLocationHdfsRequest
      .builder()
      .optionallyWith(subdirectory.map(value => value: java.lang.String))(
        _.subdirectory
      )
      .nameNodes(nameNodes.map { item =>
        item.buildAwsValue()
      }.asJavaCollection)
      .optionallyWith(blockSize.map(value => value: Integer))(_.blockSize)
      .optionallyWith(replicationFactor.map(value => value: Integer))(
        _.replicationFactor
      )
      .optionallyWith(kmsKeyProviderUri.map(value => value: java.lang.String))(
        _.kmsKeyProviderUri
      )
      .optionallyWith(qopConfiguration.map(value => value.buildAwsValue()))(
        _.qopConfiguration
      )
      .authenticationType(authenticationType.unwrap)
      .optionallyWith(simpleUser.map(value => value: java.lang.String))(
        _.simpleUser
      )
      .optionallyWith(kerberosPrincipal.map(value => value: java.lang.String))(
        _.kerberosPrincipal
      )
      .optionallyWith(
        kerberosKeytab.map(value =>
          software.amazon.awssdk.core.SdkBytes
            .fromByteArrayUnsafe(value.toArray[Byte])
        )
      )(_.kerberosKeytab)
      .optionallyWith(
        kerberosKrb5Conf.map(value =>
          software.amazon.awssdk.core.SdkBytes
            .fromByteArrayUnsafe(value.toArray[Byte])
        )
      )(_.kerberosKrb5Conf)
      .agentArns(agentArns.map { item =>
        item: java.lang.String
      }.asJavaCollection)
      .optionallyWith(
        tags.map(value =>
          value.map { item =>
            item.buildAwsValue()
          }.asJavaCollection
        )
      )(_.tags)
      .build()
  }
  def asReadOnly
      : io.github.vigoo.zioaws.datasync.model.CreateLocationHdfsRequest.ReadOnly =
    io.github.vigoo.zioaws.datasync.model.CreateLocationHdfsRequest
      .wrap(buildAwsValue())
}
object CreateLocationHdfsRequest {
  private lazy val zioAwsBuilderHelper: BuilderHelper[
    software.amazon.awssdk.services.datasync.model.CreateLocationHdfsRequest
  ] = BuilderHelper.apply
  trait ReadOnly {
    def editable
        : io.github.vigoo.zioaws.datasync.model.CreateLocationHdfsRequest =
      io.github.vigoo.zioaws.datasync.model.CreateLocationHdfsRequest(
        subdirectoryValue.map(value => value),
        nameNodesValue.map { item =>
          item.editable
        },
        blockSizeValue.map(value => value),
        replicationFactorValue.map(value => value),
        kmsKeyProviderUriValue.map(value => value),
        qopConfigurationValue.map(value => value.editable),
        authenticationTypeValue,
        simpleUserValue.map(value => value),
        kerberosPrincipalValue.map(value => value),
        kerberosKeytabValue.map(value => value),
        kerberosKrb5ConfValue.map(value => value),
        agentArnsValue,
        tagsValue.map(value =>
          value.map { item =>
            item.editable
          }
        )
      )
    def subdirectoryValue: Option[HdfsSubdirectory]
    def nameNodesValue
        : List[io.github.vigoo.zioaws.datasync.model.HdfsNameNode.ReadOnly]
    def blockSizeValue: Option[HdfsBlockSize]
    def replicationFactorValue: Option[HdfsReplicationFactor]
    def kmsKeyProviderUriValue: Option[KmsKeyProviderUri]
    def qopConfigurationValue: Option[
      io.github.vigoo.zioaws.datasync.model.QopConfiguration.ReadOnly
    ]
    def authenticationTypeValue
        : io.github.vigoo.zioaws.datasync.model.HdfsAuthenticationType
    def simpleUserValue: Option[HdfsUser]
    def kerberosPrincipalValue: Option[KerberosPrincipal]
    def kerberosKeytabValue: Option[KerberosKeytabFile]
    def kerberosKrb5ConfValue: Option[KerberosKrb5ConfFile]
    def agentArnsValue: List[AgentArn]
    def tagsValue: Option[
      List[io.github.vigoo.zioaws.datasync.model.TagListEntry.ReadOnly]
    ]
    def subdirectory: ZIO[Any, AwsError, HdfsSubdirectory] =
      AwsError.unwrapOptionField("subdirectory", subdirectoryValue)
    def nameNodes: ZIO[Any, Nothing, List[
      io.github.vigoo.zioaws.datasync.model.HdfsNameNode.ReadOnly
    ]] = ZIO.succeed(nameNodesValue)
    def blockSize: ZIO[Any, AwsError, HdfsBlockSize] =
      AwsError.unwrapOptionField("blockSize", blockSizeValue)
    def replicationFactor: ZIO[Any, AwsError, HdfsReplicationFactor] =
      AwsError.unwrapOptionField("replicationFactor", replicationFactorValue)
    def kmsKeyProviderUri: ZIO[Any, AwsError, KmsKeyProviderUri] =
      AwsError.unwrapOptionField("kmsKeyProviderUri", kmsKeyProviderUriValue)
    def qopConfiguration: ZIO[
      Any,
      AwsError,
      io.github.vigoo.zioaws.datasync.model.QopConfiguration.ReadOnly
    ] = AwsError.unwrapOptionField("qopConfiguration", qopConfigurationValue)
    def authenticationType: ZIO[
      Any,
      Nothing,
      io.github.vigoo.zioaws.datasync.model.HdfsAuthenticationType
    ] = ZIO.succeed(authenticationTypeValue)
    def simpleUser: ZIO[Any, AwsError, HdfsUser] =
      AwsError.unwrapOptionField("simpleUser", simpleUserValue)
    def kerberosPrincipal: ZIO[Any, AwsError, KerberosPrincipal] =
      AwsError.unwrapOptionField("kerberosPrincipal", kerberosPrincipalValue)
    def kerberosKeytab: ZIO[Any, AwsError, KerberosKeytabFile] =
      AwsError.unwrapOptionField("kerberosKeytab", kerberosKeytabValue)
    def kerberosKrb5Conf: ZIO[Any, AwsError, KerberosKrb5ConfFile] =
      AwsError.unwrapOptionField("kerberosKrb5Conf", kerberosKrb5ConfValue)
    def agentArns: ZIO[Any, Nothing, List[AgentArn]] =
      ZIO.succeed(agentArnsValue)
    def tags: ZIO[Any, AwsError, List[
      io.github.vigoo.zioaws.datasync.model.TagListEntry.ReadOnly
    ]] = AwsError.unwrapOptionField("tags", tagsValue)
  }
  private class Wrapper(
      impl: software.amazon.awssdk.services.datasync.model.CreateLocationHdfsRequest
  ) extends io.github.vigoo.zioaws.datasync.model.CreateLocationHdfsRequest.ReadOnly {
    override def subdirectoryValue: Option[HdfsSubdirectory] =
      scala.Option(impl.subdirectory()).map(value => value: HdfsSubdirectory)
    override def nameNodesValue
        : List[io.github.vigoo.zioaws.datasync.model.HdfsNameNode.ReadOnly] =
      impl
        .nameNodes()
        .asScala
        .map { item =>
          io.github.vigoo.zioaws.datasync.model.HdfsNameNode.wrap(item)
        }
        .toList
    override def blockSizeValue: Option[HdfsBlockSize] =
      scala.Option(impl.blockSize()).map(value => value: HdfsBlockSize)
    override def replicationFactorValue: Option[HdfsReplicationFactor] = scala
      .Option(impl.replicationFactor())
      .map(value => value: HdfsReplicationFactor)
    override def kmsKeyProviderUriValue: Option[KmsKeyProviderUri] = scala
      .Option(impl.kmsKeyProviderUri())
      .map(value => value: KmsKeyProviderUri)
    override def qopConfigurationValue: Option[
      io.github.vigoo.zioaws.datasync.model.QopConfiguration.ReadOnly
    ] = scala
      .Option(impl.qopConfiguration())
      .map(value =>
        io.github.vigoo.zioaws.datasync.model.QopConfiguration.wrap(value)
      )
    override def authenticationTypeValue
        : io.github.vigoo.zioaws.datasync.model.HdfsAuthenticationType =
      io.github.vigoo.zioaws.datasync.model.HdfsAuthenticationType
        .wrap(impl.authenticationType())
    override def simpleUserValue: Option[HdfsUser] =
      scala.Option(impl.simpleUser()).map(value => value: HdfsUser)
    override def kerberosPrincipalValue: Option[KerberosPrincipal] = scala
      .Option(impl.kerberosPrincipal())
      .map(value => value: KerberosPrincipal)
    override def kerberosKeytabValue: Option[KerberosKeytabFile] = scala
      .Option(impl.kerberosKeytab())
      .map(value => zio.Chunk.fromArray(value.asByteArrayUnsafe()))
    override def kerberosKrb5ConfValue: Option[KerberosKrb5ConfFile] = scala
      .Option(impl.kerberosKrb5Conf())
      .map(value => zio.Chunk.fromArray(value.asByteArrayUnsafe()))
    override def agentArnsValue: List[AgentArn] = impl
      .agentArns()
      .asScala
      .map { item =>
        item: AgentArn
      }
      .toList
    override def tagsValue: Option[
      List[io.github.vigoo.zioaws.datasync.model.TagListEntry.ReadOnly]
    ] = scala
      .Option(impl.tags())
      .map(value =>
        value.asScala.map { item =>
          io.github.vigoo.zioaws.datasync.model.TagListEntry.wrap(item)
        }.toList
      )
  }
  def wrap(
      impl: software.amazon.awssdk.services.datasync.model.CreateLocationHdfsRequest
  ): io.github.vigoo.zioaws.datasync.model.CreateLocationHdfsRequest.ReadOnly =
    new Wrapper(impl)
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy