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

commonMain.aws.sdk.kotlin.services.codepipeline.model.WebhookAuthConfiguration.kt Maven / Gradle / Ivy

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

package aws.sdk.kotlin.services.codepipeline.model

import aws.smithy.kotlin.runtime.SdkDsl

/**
 * The authentication applied to incoming webhook trigger requests.
 */
public class WebhookAuthConfiguration private constructor(builder: Builder) {
    /**
     * The property used to configure acceptance of webhooks in an IP address range. For IP, only the `AllowedIPRange` property must be set. This property must be set to a valid CIDR range.
     */
    public val allowedIpRange: kotlin.String? = builder.allowedIpRange
    /**
     * The property used to configure GitHub authentication. For GITHUB_HMAC, only the `SecretToken` property must be set.
     *
     * When creating CodePipeline webhooks, do not use your own credentials or reuse the same secret token across multiple webhooks. For optimal security, generate a unique secret token for each webhook you create. The secret token is an arbitrary string that you provide, which GitHub uses to compute and sign the webhook payloads sent to CodePipeline, for protecting the integrity and authenticity of the webhook payloads. Using your own credentials or reusing the same token across multiple webhooks can lead to security vulnerabilities.
     *
     * If a secret token was provided, it will be redacted in the response.
     */
    public val secretToken: kotlin.String? = builder.secretToken

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

    override fun toString(): kotlin.String = buildString {
        append("WebhookAuthConfiguration(")
        append("allowedIpRange=$allowedIpRange,")
        append("secretToken=$secretToken")
        append(")")
    }

    override fun hashCode(): kotlin.Int {
        var result = allowedIpRange?.hashCode() ?: 0
        result = 31 * result + (secretToken?.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 WebhookAuthConfiguration

        if (allowedIpRange != other.allowedIpRange) return false
        if (secretToken != other.secretToken) return false

        return true
    }

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

    @SdkDsl
    public class Builder {
        /**
         * The property used to configure acceptance of webhooks in an IP address range. For IP, only the `AllowedIPRange` property must be set. This property must be set to a valid CIDR range.
         */
        public var allowedIpRange: kotlin.String? = null
        /**
         * The property used to configure GitHub authentication. For GITHUB_HMAC, only the `SecretToken` property must be set.
         *
         * When creating CodePipeline webhooks, do not use your own credentials or reuse the same secret token across multiple webhooks. For optimal security, generate a unique secret token for each webhook you create. The secret token is an arbitrary string that you provide, which GitHub uses to compute and sign the webhook payloads sent to CodePipeline, for protecting the integrity and authenticity of the webhook payloads. Using your own credentials or reusing the same token across multiple webhooks can lead to security vulnerabilities.
         *
         * If a secret token was provided, it will be redacted in the response.
         */
        public var secretToken: kotlin.String? = null

        @PublishedApi
        internal constructor()
        @PublishedApi
        internal constructor(x: aws.sdk.kotlin.services.codepipeline.model.WebhookAuthConfiguration) : this() {
            this.allowedIpRange = x.allowedIpRange
            this.secretToken = x.secretToken
        }

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

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




© 2015 - 2025 Weber Informatics LLC | Privacy Policy