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

commonMain.aws.sdk.kotlin.services.iam.model.AccessDetail.kt Maven / Gradle / Ivy

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

package aws.sdk.kotlin.services.iam.model

import aws.smithy.kotlin.runtime.time.Instant

/**
 * An object that contains details about when a principal in the reported Organizations entity last attempted to access an Amazon Web Services service. A principal can be an IAM user, an IAM role, or the Amazon Web Services account root user within the reported Organizations entity.
 *
 * This data type is a response element in the GetOrganizationsAccessReport operation.
 */
public class AccessDetail private constructor(builder: Builder) {
    /**
     * The path of the Organizations entity (root, organizational unit, or account) from which an authenticated principal last attempted to access the service. Amazon Web Services does not report unauthenticated requests.
     *
     * This field is null if no principals (IAM users, IAM roles, or root user) in the reported Organizations entity attempted to access the service within the [tracking period](https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies_access-advisor.html#service-last-accessed-reporting-period).
     */
    public val entityPath: kotlin.String? = builder.entityPath
    /**
     * The date and time, in [ISO 8601 date-time format](http://www.iso.org/iso/iso8601), when an authenticated principal most recently attempted to access the service. Amazon Web Services does not report unauthenticated requests.
     *
     * This field is null if no principals in the reported Organizations entity attempted to access the service within the [tracking period](https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies_access-advisor.html#service-last-accessed-reporting-period).
     */
    public val lastAuthenticatedTime: aws.smithy.kotlin.runtime.time.Instant? = builder.lastAuthenticatedTime
    /**
     * The Region where the last service access attempt occurred.
     *
     * This field is null if no principals in the reported Organizations entity attempted to access the service within the [tracking period](https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies_access-advisor.html#service-last-accessed-reporting-period).
     */
    public val region: kotlin.String? = builder.region
    /**
     * The name of the service in which access was attempted.
     */
    public val serviceName: kotlin.String = requireNotNull(builder.serviceName) { "A non-null value must be provided for serviceName" }
    /**
     * The namespace of the service in which access was attempted.
     *
     * To learn the service namespace of a service, see [Actions, resources, and condition keys for Amazon Web Services services](https://docs.aws.amazon.com/service-authorization/latest/reference/reference_policies_actions-resources-contextkeys.html) in the *Service Authorization Reference*. Choose the name of the service to view details for that service. In the first paragraph, find the service prefix. For example, `(service prefix: a4b)`. For more information about service namespaces, see [Amazon Web Services service namespaces](https://docs.aws.amazon.com/general/latest/gr/aws-arns-and-namespaces.html#genref-aws-service-namespaces) in the *Amazon Web Services General Reference*.
     */
    public val serviceNamespace: kotlin.String = requireNotNull(builder.serviceNamespace) { "A non-null value must be provided for serviceNamespace" }
    /**
     * The number of accounts with authenticated principals (root user, IAM users, and IAM roles) that attempted to access the service in the tracking period.
     */
    public val totalAuthenticatedEntities: kotlin.Int? = builder.totalAuthenticatedEntities

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

    override fun toString(): kotlin.String = buildString {
        append("AccessDetail(")
        append("entityPath=$entityPath,")
        append("lastAuthenticatedTime=$lastAuthenticatedTime,")
        append("region=$region,")
        append("serviceName=$serviceName,")
        append("serviceNamespace=$serviceNamespace,")
        append("totalAuthenticatedEntities=$totalAuthenticatedEntities")
        append(")")
    }

    override fun hashCode(): kotlin.Int {
        var result = entityPath?.hashCode() ?: 0
        result = 31 * result + (lastAuthenticatedTime?.hashCode() ?: 0)
        result = 31 * result + (region?.hashCode() ?: 0)
        result = 31 * result + (serviceName.hashCode())
        result = 31 * result + (serviceNamespace.hashCode())
        result = 31 * result + (totalAuthenticatedEntities ?: 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 AccessDetail

        if (entityPath != other.entityPath) return false
        if (lastAuthenticatedTime != other.lastAuthenticatedTime) return false
        if (region != other.region) return false
        if (serviceName != other.serviceName) return false
        if (serviceNamespace != other.serviceNamespace) return false
        if (totalAuthenticatedEntities != other.totalAuthenticatedEntities) return false

        return true
    }

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

    public class Builder {
        /**
         * The path of the Organizations entity (root, organizational unit, or account) from which an authenticated principal last attempted to access the service. Amazon Web Services does not report unauthenticated requests.
         *
         * This field is null if no principals (IAM users, IAM roles, or root user) in the reported Organizations entity attempted to access the service within the [tracking period](https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies_access-advisor.html#service-last-accessed-reporting-period).
         */
        public var entityPath: kotlin.String? = null
        /**
         * The date and time, in [ISO 8601 date-time format](http://www.iso.org/iso/iso8601), when an authenticated principal most recently attempted to access the service. Amazon Web Services does not report unauthenticated requests.
         *
         * This field is null if no principals in the reported Organizations entity attempted to access the service within the [tracking period](https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies_access-advisor.html#service-last-accessed-reporting-period).
         */
        public var lastAuthenticatedTime: aws.smithy.kotlin.runtime.time.Instant? = null
        /**
         * The Region where the last service access attempt occurred.
         *
         * This field is null if no principals in the reported Organizations entity attempted to access the service within the [tracking period](https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies_access-advisor.html#service-last-accessed-reporting-period).
         */
        public var region: kotlin.String? = null
        /**
         * The name of the service in which access was attempted.
         */
        public var serviceName: kotlin.String? = null
        /**
         * The namespace of the service in which access was attempted.
         *
         * To learn the service namespace of a service, see [Actions, resources, and condition keys for Amazon Web Services services](https://docs.aws.amazon.com/service-authorization/latest/reference/reference_policies_actions-resources-contextkeys.html) in the *Service Authorization Reference*. Choose the name of the service to view details for that service. In the first paragraph, find the service prefix. For example, `(service prefix: a4b)`. For more information about service namespaces, see [Amazon Web Services service namespaces](https://docs.aws.amazon.com/general/latest/gr/aws-arns-and-namespaces.html#genref-aws-service-namespaces) in the *Amazon Web Services General Reference*.
         */
        public var serviceNamespace: kotlin.String? = null
        /**
         * The number of accounts with authenticated principals (root user, IAM users, and IAM roles) that attempted to access the service in the tracking period.
         */
        public var totalAuthenticatedEntities: kotlin.Int? = null

        @PublishedApi
        internal constructor()
        @PublishedApi
        internal constructor(x: aws.sdk.kotlin.services.iam.model.AccessDetail) : this() {
            this.entityPath = x.entityPath
            this.lastAuthenticatedTime = x.lastAuthenticatedTime
            this.region = x.region
            this.serviceName = x.serviceName
            this.serviceNamespace = x.serviceNamespace
            this.totalAuthenticatedEntities = x.totalAuthenticatedEntities
        }

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

        internal fun correctErrors(): Builder {
            if (serviceName == null) serviceName = ""
            if (serviceNamespace == null) serviceNamespace = ""
            return this
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy