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

io.github.freya022.botcommands.api.components.data.InteractionConstraints.kt Maven / Gradle / Ivy

package io.github.freya022.botcommands.api.components.data

import gnu.trove.list.array.TLongArrayList
import io.github.freya022.botcommands.api.core.utils.enumSetOf
import net.dv8tion.jda.api.Permission
import net.dv8tion.jda.api.entities.Role
import net.dv8tion.jda.api.entities.UserSnowflake
import net.dv8tion.jda.api.events.interaction.component.GenericComponentInteractionCreateEvent

/**
 * Controls who can use components (buttons, selection menus).
 *
 * A user can use a component if they fit *at least* one of the allowed elements.
 *
 * You can filter by:
 * - User ID
 * - Role ID
 * - Permissions
 *
 * You can create interaction constraints from the static methods,
 * or by using the existing instance in the component builders.
 */
class InteractionConstraints private constructor() {
    val allowedUsers = TLongArrayList()
    val allowedRoles = TLongArrayList()
    val allowingPermissions = enumSetOf()

    val isEmpty: Boolean
        get() = allowedUsers.isEmpty && allowedRoles.isEmpty && allowingPermissions.isEmpty()

    fun addUserIds(vararg userIds: Long): InteractionConstraints = apply {
        allowedUsers.addAll(userIds)
    }

    fun addUserIds(userIds: Collection): InteractionConstraints = apply {
        allowedUsers.addAll(userIds)
    }

    fun addUsers(vararg userIds: UserSnowflake): InteractionConstraints = apply {
        for (user in userIds) {
            allowedUsers.add(user.idLong)
        }
    }

    fun addUsers(users: Collection): InteractionConstraints = apply {
        for (user in users) {
            allowedUsers.add(user.idLong)
        }
    }

    fun addRoleIds(vararg roleIds: Long): InteractionConstraints = apply {
        allowedRoles.addAll(roleIds)
    }

    fun addRoleIds(roleIds: Collection): InteractionConstraints = apply {
        allowedRoles.addAll(roleIds)
    }

    fun addRoles(vararg roles: Role): InteractionConstraints = apply {
        for (role in roles) {
            allowedRoles.add(role.idLong)
        }
    }

    fun addRoles(roles: Collection): InteractionConstraints = apply {
        for (role in roles) {
            allowedRoles.add(role.idLong)
        }
    }

    fun addPermissions(vararg permissions: Permission): InteractionConstraints = apply {
        allowingPermissions.addAll(permissions)
    }

    fun addPermissions(permissions: Collection): InteractionConstraints = apply {
        allowingPermissions.addAll(permissions)
    }

    fun setConstraints(otherConstraints: InteractionConstraints): InteractionConstraints = apply {
        allowedUsers.clear()
        allowedRoles.clear()
        allowingPermissions.clear()
        allowedUsers.addAll(otherConstraints.allowedUsers)
        allowedRoles.addAll(otherConstraints.allowedRoles)
        allowingPermissions.addAll(otherConstraints.allowingPermissions)
    }

    @JvmSynthetic
    operator fun plusAssign(role: Role) {
        addRoles(role)
    }

    @JvmSynthetic
    @JvmName("plusAssignRoles")
    operator fun plusAssign(roles: Collection) {
        addRoles(roles)
    }

    @JvmSynthetic
    operator fun plusAssign(user: UserSnowflake) {
        addUsers(user)
    }

    @JvmSynthetic
    @JvmName("plusAssignUsers")
    operator fun plusAssign(users: Collection) {
        addUsers(users)
    }

    @JvmSynthetic
    operator fun plusAssign(permission: Permission) {
        addPermissions(permission)
    }

    @JvmSynthetic
    @JvmName("plusAssignPermission")
    operator fun plusAssign(permissions: Collection) {
        addPermissions(permissions)
    }

    @JvmSynthetic
    internal fun isAllowed(event: GenericComponentInteractionCreateEvent): Boolean {
        if (isEmpty) return true

        if (event.user.idLong in allowedUsers) return true

        val member = event.member
        if (member != null) {
            if (allowingPermissions.isNotEmpty()) {
                if (member.hasPermission(event.guildChannel, allowingPermissions)) {
                    return true
                }
            }

            //If the member has any of these roles
            if (member.roles.any { it.idLong in allowedRoles }) {
                return true
            }
        }

        return false
    }

    companion object {
        @JvmStatic
        fun empty(): InteractionConstraints {
            return InteractionConstraints()
        }

        @JvmStatic
        fun ofUserIds(vararg userIds: Long): InteractionConstraints {
            return empty().addUserIds(*userIds)
        }

        @JvmStatic
        fun ofUserIds(userIds: Collection): InteractionConstraints {
            return empty().addUserIds(userIds)
        }

        @JvmStatic
        fun ofUsers(vararg users: UserSnowflake): InteractionConstraints {
            return empty().addUsers(*users)
        }

        @JvmStatic
        fun ofUsers(users: Collection): InteractionConstraints {
            return empty().addUsers(users)
        }

        @JvmStatic
        fun ofRoleIds(vararg roleIds: Long): InteractionConstraints {
            return empty().addRoleIds(*roleIds)
        }

        @JvmStatic
        fun ofRoleIds(roleIds: Collection): InteractionConstraints {
            return empty().addRoleIds(roleIds)
        }

        @JvmStatic
        fun ofRoles(vararg roles: Role): InteractionConstraints {
            return empty().addRoles(*roles)
        }

        @JvmStatic
        fun ofRoles(roles: Collection): InteractionConstraints {
            return empty().addRoles(roles)
        }

        @JvmStatic
        fun ofPermissions(vararg permissions: Permission): InteractionConstraints {
            return empty().addPermissions(*permissions)
        }

        @JvmSynthetic
        internal fun of(userIds: List, roleIds: List, rawPermissions: Long): InteractionConstraints = empty().apply {
            addUserIds(userIds)
            addRoleIds(roleIds)
            addPermissions(Permission.getPermissions(rawPermissions))
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy