zio.aws.ram.model.CreatePermissionRequest.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of zio-aws-ram_3 Show documentation
Show all versions of zio-aws-ram_3 Show documentation
Low-level AWS wrapper for ZIO
The newest version!
package zio.aws.ram.model
import zio.ZIO
import zio.aws.core.{AwsError, BuilderHelper}
import zio.prelude.data.Optional
import zio.aws.ram.model.primitives.{Policy, PermissionName}
import scala.jdk.CollectionConverters.*
final case class CreatePermissionRequest(
name: PermissionName,
resourceType: String,
policyTemplate: Policy,
clientToken: Optional[String] = Optional.Absent,
tags: Optional[Iterable[zio.aws.ram.model.Tag]] = Optional.Absent
) {
def buildAwsValue()
: software.amazon.awssdk.services.ram.model.CreatePermissionRequest = {
import CreatePermissionRequest.zioAwsBuilderHelper.BuilderOps
software.amazon.awssdk.services.ram.model.CreatePermissionRequest
.builder()
.name(PermissionName.unwrap(name): java.lang.String)
.resourceType(resourceType: java.lang.String)
.policyTemplate(Policy.unwrap(policyTemplate): java.lang.String)
.optionallyWith(clientToken.map(value => value: java.lang.String))(
_.clientToken
)
.optionallyWith(
tags.map(value =>
value.map { item =>
item.buildAwsValue()
}.asJavaCollection
)
)(_.tags)
.build()
}
def asReadOnly: zio.aws.ram.model.CreatePermissionRequest.ReadOnly =
zio.aws.ram.model.CreatePermissionRequest.wrap(buildAwsValue())
}
object CreatePermissionRequest {
private lazy val zioAwsBuilderHelper: BuilderHelper[
software.amazon.awssdk.services.ram.model.CreatePermissionRequest
] = BuilderHelper.apply
trait ReadOnly {
def asEditable: zio.aws.ram.model.CreatePermissionRequest =
zio.aws.ram.model.CreatePermissionRequest(
name,
resourceType,
policyTemplate,
clientToken.map(value => value),
tags.map(value =>
value.map { item =>
item.asEditable
}
)
)
def name: PermissionName
def resourceType: String
def policyTemplate: Policy
def clientToken: Optional[String]
def tags: Optional[List[zio.aws.ram.model.Tag.ReadOnly]]
def getName: ZIO[Any, Nothing, PermissionName] = ZIO.succeed(name)
def getResourceType: ZIO[Any, Nothing, String] = ZIO.succeed(resourceType)
def getPolicyTemplate: ZIO[Any, Nothing, Policy] =
ZIO.succeed(policyTemplate)
def getClientToken: ZIO[Any, AwsError, String] =
AwsError.unwrapOptionField("clientToken", clientToken)
def getTags: ZIO[Any, AwsError, List[zio.aws.ram.model.Tag.ReadOnly]] =
AwsError.unwrapOptionField("tags", tags)
}
private final class Wrapper(
impl: software.amazon.awssdk.services.ram.model.CreatePermissionRequest
) extends zio.aws.ram.model.CreatePermissionRequest.ReadOnly {
override val name: PermissionName =
zio.aws.ram.model.primitives.PermissionName(impl.name())
override val resourceType: String = impl.resourceType(): String
override val policyTemplate: Policy =
zio.aws.ram.model.primitives.Policy(impl.policyTemplate())
override val clientToken: Optional[String] = zio.aws.core.internal
.optionalFromNullable(impl.clientToken())
.map(value => value: String)
override val tags: Optional[List[zio.aws.ram.model.Tag.ReadOnly]] =
zio.aws.core.internal
.optionalFromNullable(impl.tags())
.map(value =>
value.asScala.map { item =>
zio.aws.ram.model.Tag.wrap(item)
}.toList
)
}
def wrap(
impl: software.amazon.awssdk.services.ram.model.CreatePermissionRequest
): zio.aws.ram.model.CreatePermissionRequest.ReadOnly = new Wrapper(impl)
}