
commonMain.aws.sdk.kotlin.services.qbusiness.model.AccessControl.kt Maven / Gradle / Ivy
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!
package aws.sdk.kotlin.services.qbusiness.model
/**
* A list of principals. Each principal can be either a `USER` or a `GROUP` and can be designated document access permissions of either `ALLOW` or `DENY`.
*/
public class AccessControl private constructor(builder: Builder) {
/**
* Describes the member relation within a principal list.
*/
public val memberRelation: aws.sdk.kotlin.services.qbusiness.model.MemberRelation? = builder.memberRelation
/**
* Contains a list of principals, where a principal can be either a `USER` or a `GROUP`. Each principal can be have the following type of document access: `ALLOW` or `DENY`.
*/
public val principals: List = requireNotNull(builder.principals) { "A non-null value must be provided for principals" }
public companion object {
public operator fun invoke(block: Builder.() -> kotlin.Unit): aws.sdk.kotlin.services.qbusiness.model.AccessControl = Builder().apply(block).build()
}
override fun toString(): kotlin.String = buildString {
append("AccessControl(")
append("memberRelation=$memberRelation,")
append("principals=$principals")
append(")")
}
override fun hashCode(): kotlin.Int {
var result = memberRelation?.hashCode() ?: 0
result = 31 * result + (principals.hashCode())
return result
}
override fun equals(other: kotlin.Any?): kotlin.Boolean {
if (this === other) return true
if (other == null || this::class != other::class) return false
other as AccessControl
if (memberRelation != other.memberRelation) return false
if (principals != other.principals) return false
return true
}
public inline fun copy(block: Builder.() -> kotlin.Unit = {}): aws.sdk.kotlin.services.qbusiness.model.AccessControl = Builder(this).apply(block).build()
public class Builder {
/**
* Describes the member relation within a principal list.
*/
public var memberRelation: aws.sdk.kotlin.services.qbusiness.model.MemberRelation? = null
/**
* Contains a list of principals, where a principal can be either a `USER` or a `GROUP`. Each principal can be have the following type of document access: `ALLOW` or `DENY`.
*/
public var principals: List? = null
@PublishedApi
internal constructor()
@PublishedApi
internal constructor(x: aws.sdk.kotlin.services.qbusiness.model.AccessControl) : this() {
this.memberRelation = x.memberRelation
this.principals = x.principals
}
@PublishedApi
internal fun build(): aws.sdk.kotlin.services.qbusiness.model.AccessControl = AccessControl(this)
internal fun correctErrors(): Builder {
if (principals == null) principals = emptyList()
return this
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy