commonMain.aws.sdk.kotlin.services.pinpointsmsvoicev2.model.DescribeSenderIdsRequest.kt Maven / Gradle / Ivy
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!
package aws.sdk.kotlin.services.pinpointsmsvoicev2.model
import aws.smithy.kotlin.runtime.SdkDsl
public class DescribeSenderIdsRequest private constructor(builder: Builder) {
/**
* An array of SenderIdFilter objects to filter the results.
*/
public val filters: List? = builder.filters
/**
* The maximum number of results to return per each request.
*/
public val maxResults: kotlin.Int? = builder.maxResults
/**
* The token to be used for the next set of paginated results. You don't need to supply a value for this field in the initial request.
*/
public val nextToken: kotlin.String? = builder.nextToken
/**
* Use `SELF` to filter the list of Sender Ids to ones your account owns or use `SHARED` to filter on Sender Ids shared with your account. The `Owner` and `SenderIds` parameters can't be used at the same time.
*/
public val owner: aws.sdk.kotlin.services.pinpointsmsvoicev2.model.Owner? = builder.owner
/**
* An array of SenderIdAndCountry objects to search for.
*
* If you are using a shared AWS End User Messaging SMS and Voice resource then you must use the full Amazon Resource Name(ARN).
*/
public val senderIds: List? = builder.senderIds
public companion object {
public operator fun invoke(block: Builder.() -> kotlin.Unit): aws.sdk.kotlin.services.pinpointsmsvoicev2.model.DescribeSenderIdsRequest = Builder().apply(block).build()
}
override fun toString(): kotlin.String = buildString {
append("DescribeSenderIdsRequest(")
append("filters=$filters,")
append("maxResults=$maxResults,")
append("nextToken=$nextToken,")
append("owner=$owner,")
append("senderIds=$senderIds")
append(")")
}
override fun hashCode(): kotlin.Int {
var result = filters?.hashCode() ?: 0
result = 31 * result + (maxResults ?: 0)
result = 31 * result + (nextToken?.hashCode() ?: 0)
result = 31 * result + (owner?.hashCode() ?: 0)
result = 31 * result + (senderIds?.hashCode() ?: 0)
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 DescribeSenderIdsRequest
if (filters != other.filters) return false
if (maxResults != other.maxResults) return false
if (nextToken != other.nextToken) return false
if (owner != other.owner) return false
if (senderIds != other.senderIds) return false
return true
}
public inline fun copy(block: Builder.() -> kotlin.Unit = {}): aws.sdk.kotlin.services.pinpointsmsvoicev2.model.DescribeSenderIdsRequest = Builder(this).apply(block).build()
@SdkDsl
public class Builder {
/**
* An array of SenderIdFilter objects to filter the results.
*/
public var filters: List? = null
/**
* The maximum number of results to return per each request.
*/
public var maxResults: kotlin.Int? = null
/**
* The token to be used for the next set of paginated results. You don't need to supply a value for this field in the initial request.
*/
public var nextToken: kotlin.String? = null
/**
* Use `SELF` to filter the list of Sender Ids to ones your account owns or use `SHARED` to filter on Sender Ids shared with your account. The `Owner` and `SenderIds` parameters can't be used at the same time.
*/
public var owner: aws.sdk.kotlin.services.pinpointsmsvoicev2.model.Owner? = null
/**
* An array of SenderIdAndCountry objects to search for.
*
* If you are using a shared AWS End User Messaging SMS and Voice resource then you must use the full Amazon Resource Name(ARN).
*/
public var senderIds: List? = null
@PublishedApi
internal constructor()
@PublishedApi
internal constructor(x: aws.sdk.kotlin.services.pinpointsmsvoicev2.model.DescribeSenderIdsRequest) : this() {
this.filters = x.filters
this.maxResults = x.maxResults
this.nextToken = x.nextToken
this.owner = x.owner
this.senderIds = x.senderIds
}
@PublishedApi
internal fun build(): aws.sdk.kotlin.services.pinpointsmsvoicev2.model.DescribeSenderIdsRequest = DescribeSenderIdsRequest(this)
internal fun correctErrors(): Builder {
return this
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy