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

commonMain.aws.sdk.kotlin.services.chatbot.model.CreateSlackChannelConfigurationRequest.kt Maven / Gradle / Ivy

// Code generated by smithy-kotlin-codegen. DO NOT EDIT!

package aws.sdk.kotlin.services.chatbot.model

import aws.smithy.kotlin.runtime.SdkDsl

public class CreateSlackChannelConfigurationRequest private constructor(builder: Builder) {
    /**
     * The name of the configuration.
     */
    public val configurationName: kotlin.String? = builder.configurationName
    /**
     * The list of IAM policy ARNs that are applied as channel guardrails. The AWS managed `AdministratorAccess` policy is applied by default if this is not set.
     */
    public val guardrailPolicyArns: List? = builder.guardrailPolicyArns
    /**
     * A user-defined role that AWS Chatbot assumes. This is not the service-linked role.
     *
     * For more information, see [IAM policies for AWS Chatbot](https://docs.aws.amazon.com/chatbot/latest/adminguide/chatbot-iam-policies.html) in the * AWS Chatbot Administrator Guide*.
     */
    public val iamRoleArn: kotlin.String? = builder.iamRoleArn
    /**
     * Logging levels include `ERROR`, `INFO`, or `NONE`.
     */
    public val loggingLevel: kotlin.String? = builder.loggingLevel
    /**
     * The ID of the Slack channel.
     *
     * To get this ID, open Slack, right click on the channel name in the left pane, then choose Copy Link. The channel ID is the 9-character string at the end of the URL. For example, ABCBBLZZZ.
     */
    public val slackChannelId: kotlin.String? = builder.slackChannelId
    /**
     * The name of the Slack channel.
     */
    public val slackChannelName: kotlin.String? = builder.slackChannelName
    /**
     * The ID of the Slack workspace authorized with AWS Chatbot.
     */
    public val slackTeamId: kotlin.String? = builder.slackTeamId
    /**
     * The Amazon Resource Names (ARNs) of the SNS topics that deliver notifications to AWS Chatbot.
     */
    public val snsTopicArns: List? = builder.snsTopicArns
    /**
     * A map of tags assigned to a resource. A tag is a string-to-string map of key-value pairs.
     */
    public val tags: List? = builder.tags
    /**
     * Enables use of a user role requirement in your chat configuration.
     */
    public val userAuthorizationRequired: kotlin.Boolean? = builder.userAuthorizationRequired

    public companion object {
        public operator fun invoke(block: Builder.() -> kotlin.Unit): aws.sdk.kotlin.services.chatbot.model.CreateSlackChannelConfigurationRequest = Builder().apply(block).build()
    }

    override fun toString(): kotlin.String = buildString {
        append("CreateSlackChannelConfigurationRequest(")
        append("configurationName=$configurationName,")
        append("guardrailPolicyArns=$guardrailPolicyArns,")
        append("iamRoleArn=$iamRoleArn,")
        append("loggingLevel=$loggingLevel,")
        append("slackChannelId=$slackChannelId,")
        append("slackChannelName=*** Sensitive Data Redacted ***,")
        append("slackTeamId=$slackTeamId,")
        append("snsTopicArns=$snsTopicArns,")
        append("tags=$tags,")
        append("userAuthorizationRequired=$userAuthorizationRequired")
        append(")")
    }

    override fun hashCode(): kotlin.Int {
        var result = configurationName?.hashCode() ?: 0
        result = 31 * result + (guardrailPolicyArns?.hashCode() ?: 0)
        result = 31 * result + (iamRoleArn?.hashCode() ?: 0)
        result = 31 * result + (loggingLevel?.hashCode() ?: 0)
        result = 31 * result + (slackChannelId?.hashCode() ?: 0)
        result = 31 * result + (slackChannelName?.hashCode() ?: 0)
        result = 31 * result + (slackTeamId?.hashCode() ?: 0)
        result = 31 * result + (snsTopicArns?.hashCode() ?: 0)
        result = 31 * result + (tags?.hashCode() ?: 0)
        result = 31 * result + (userAuthorizationRequired?.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 CreateSlackChannelConfigurationRequest

        if (configurationName != other.configurationName) return false
        if (guardrailPolicyArns != other.guardrailPolicyArns) return false
        if (iamRoleArn != other.iamRoleArn) return false
        if (loggingLevel != other.loggingLevel) return false
        if (slackChannelId != other.slackChannelId) return false
        if (slackChannelName != other.slackChannelName) return false
        if (slackTeamId != other.slackTeamId) return false
        if (snsTopicArns != other.snsTopicArns) return false
        if (tags != other.tags) return false
        if (userAuthorizationRequired != other.userAuthorizationRequired) return false

        return true
    }

    public inline fun copy(block: Builder.() -> kotlin.Unit = {}): aws.sdk.kotlin.services.chatbot.model.CreateSlackChannelConfigurationRequest = Builder(this).apply(block).build()

    @SdkDsl
    public class Builder {
        /**
         * The name of the configuration.
         */
        public var configurationName: kotlin.String? = null
        /**
         * The list of IAM policy ARNs that are applied as channel guardrails. The AWS managed `AdministratorAccess` policy is applied by default if this is not set.
         */
        public var guardrailPolicyArns: List? = null
        /**
         * A user-defined role that AWS Chatbot assumes. This is not the service-linked role.
         *
         * For more information, see [IAM policies for AWS Chatbot](https://docs.aws.amazon.com/chatbot/latest/adminguide/chatbot-iam-policies.html) in the * AWS Chatbot Administrator Guide*.
         */
        public var iamRoleArn: kotlin.String? = null
        /**
         * Logging levels include `ERROR`, `INFO`, or `NONE`.
         */
        public var loggingLevel: kotlin.String? = null
        /**
         * The ID of the Slack channel.
         *
         * To get this ID, open Slack, right click on the channel name in the left pane, then choose Copy Link. The channel ID is the 9-character string at the end of the URL. For example, ABCBBLZZZ.
         */
        public var slackChannelId: kotlin.String? = null
        /**
         * The name of the Slack channel.
         */
        public var slackChannelName: kotlin.String? = null
        /**
         * The ID of the Slack workspace authorized with AWS Chatbot.
         */
        public var slackTeamId: kotlin.String? = null
        /**
         * The Amazon Resource Names (ARNs) of the SNS topics that deliver notifications to AWS Chatbot.
         */
        public var snsTopicArns: List? = null
        /**
         * A map of tags assigned to a resource. A tag is a string-to-string map of key-value pairs.
         */
        public var tags: List? = null
        /**
         * Enables use of a user role requirement in your chat configuration.
         */
        public var userAuthorizationRequired: kotlin.Boolean? = null

        @PublishedApi
        internal constructor()
        @PublishedApi
        internal constructor(x: aws.sdk.kotlin.services.chatbot.model.CreateSlackChannelConfigurationRequest) : this() {
            this.configurationName = x.configurationName
            this.guardrailPolicyArns = x.guardrailPolicyArns
            this.iamRoleArn = x.iamRoleArn
            this.loggingLevel = x.loggingLevel
            this.slackChannelId = x.slackChannelId
            this.slackChannelName = x.slackChannelName
            this.slackTeamId = x.slackTeamId
            this.snsTopicArns = x.snsTopicArns
            this.tags = x.tags
            this.userAuthorizationRequired = x.userAuthorizationRequired
        }

        @PublishedApi
        internal fun build(): aws.sdk.kotlin.services.chatbot.model.CreateSlackChannelConfigurationRequest = CreateSlackChannelConfigurationRequest(this)

        internal fun correctErrors(): Builder {
            return this
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy