mirror of
https://github.com/mamoe/mirai.git
synced 2025-01-21 07:02:23 +08:00
Add perm source
This commit is contained in:
parent
7819feaca7
commit
7a2d2ef1f9
@ -35,6 +35,7 @@ import net.mamoe.mirai.console.internal.data.builtins.AutoLoginConfig.Account.Pa
|
|||||||
import net.mamoe.mirai.console.internal.data.builtins.DataScope
|
import net.mamoe.mirai.console.internal.data.builtins.DataScope
|
||||||
import net.mamoe.mirai.console.internal.extension.GlobalComponentStorage
|
import net.mamoe.mirai.console.internal.extension.GlobalComponentStorage
|
||||||
import net.mamoe.mirai.console.internal.permission.BuiltInPermissionService
|
import net.mamoe.mirai.console.internal.permission.BuiltInPermissionService
|
||||||
|
import net.mamoe.mirai.console.internal.permission.getPermittedPermissionsAndSource
|
||||||
import net.mamoe.mirai.console.internal.pluginManagerImpl
|
import net.mamoe.mirai.console.internal.pluginManagerImpl
|
||||||
import net.mamoe.mirai.console.internal.util.runIgnoreException
|
import net.mamoe.mirai.console.internal.util.runIgnoreException
|
||||||
import net.mamoe.mirai.console.permission.Permission
|
import net.mamoe.mirai.console.permission.Permission
|
||||||
@ -227,6 +228,7 @@ public object BuiltInCommands {
|
|||||||
val sub: MutableList<PermissionId> = mutableListOf(),
|
val sub: MutableList<PermissionId> = mutableListOf(),
|
||||||
var linked: Boolean = false,
|
var linked: Boolean = false,
|
||||||
var implicit: Boolean = false,
|
var implicit: Boolean = false,
|
||||||
|
val source: MutableList<PermitteeId> = mutableListOf(),
|
||||||
) {
|
) {
|
||||||
companion object {
|
companion object {
|
||||||
fun sortView(view: PermTree) {
|
fun sortView(view: PermTree) {
|
||||||
@ -285,14 +287,17 @@ public object BuiltInCommands {
|
|||||||
@Name("被许可人 ID") target: PermitteeId,
|
@Name("被许可人 ID") target: PermitteeId,
|
||||||
@Name("显示全部") all: Boolean = true,
|
@Name("显示全部") all: Boolean = true,
|
||||||
) {
|
) {
|
||||||
val grantedPermissions = target.getPermittedPermissions().toList()
|
val grantedPermissions = target.getPermittedPermissionsAndSource().toList()
|
||||||
if (grantedPermissions.isEmpty()) {
|
if (grantedPermissions.isEmpty()) {
|
||||||
sendMessage("${target.asString()} 未被授予任何权限. 使用 `${CommandManager.commandPrefix}permission grant` 给予权限.")
|
sendMessage("${target.asString()} 未被授予任何权限. 使用 `${CommandManager.commandPrefix}permission grant` 给予权限.")
|
||||||
} else if (all) {
|
} else if (all) {
|
||||||
val allPermissions = PermissionService.INSTANCE.getRegisteredPermissions().toList()
|
val allPermissions = PermissionService.INSTANCE.getRegisteredPermissions().toList()
|
||||||
val permMapping = mutableMapOf<PermissionId, PermTree>()
|
val permMapping = mutableMapOf<PermissionId, PermTree>()
|
||||||
grantedPermissions.forEach { granted ->
|
grantedPermissions.forEach { (source, granted) ->
|
||||||
permMapping[granted.id] = PermTree(granted).also { it.implicit = false }
|
val m = permMapping[granted.id] ?: kotlin.run {
|
||||||
|
PermTree(granted).also { it.implicit = false; permMapping[granted.id] = it }
|
||||||
|
}
|
||||||
|
m.source.add(source)
|
||||||
}
|
}
|
||||||
val root = PermissionService.INSTANCE.rootPermission
|
val root = PermissionService.INSTANCE.rootPermission
|
||||||
fun linkPmTree(permTree: PermTree) {
|
fun linkPmTree(permTree: PermTree) {
|
||||||
@ -324,6 +329,12 @@ public object BuiltInCommands {
|
|||||||
sb.reset().white().ansi(BG_BLACK)
|
sb.reset().white().ansi(BG_BLACK)
|
||||||
} else {
|
} else {
|
||||||
sb.append(view.perm.id)
|
sb.append(view.perm.id)
|
||||||
|
if (view.source.isNotEmpty()) {
|
||||||
|
sb.append(' ').gray().append('(')
|
||||||
|
sb.append("from ")
|
||||||
|
view.source.joinTo(sb)
|
||||||
|
sb.append(')').reset().white().ansi(BG_BLACK)
|
||||||
|
}
|
||||||
sb.append('\n')
|
sb.append('\n')
|
||||||
}
|
}
|
||||||
view.sub.forEach { sub ->
|
view.sub.forEach { sub ->
|
||||||
@ -342,7 +353,7 @@ public object BuiltInCommands {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
sendMessage(grantedPermissions.joinToString("\n") { it.id.toString() })
|
sendMessage(grantedPermissions.map { it.second.id }.toSet().joinToString("\n"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -75,4 +75,21 @@ internal abstract class AbstractConcurrentPermissionService<P : Permission> : Pe
|
|||||||
if (granted) get(permissionIdentifier)?.let { yield(it) }
|
if (granted) get(permissionIdentifier)?.let { yield(it) }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
internal fun getPermittedPermissionsAndSource(permitteeId: PermitteeId): Sequence<Pair<PermitteeId, P>> = sequence {
|
||||||
|
for ((permissionIdentifier, permissibleIdentifiers) in grantedPermissionsMap) {
|
||||||
|
permissibleIdentifiers.forEach { pid ->
|
||||||
|
if (permitteeId.hasChild(pid)) {
|
||||||
|
get(permissionIdentifier)?.let { yield(pid to it) }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
internal fun PermitteeId.getPermittedPermissionsAndSource(): Sequence<Pair<PermitteeId, Permission>> {
|
||||||
|
return when (val ps = PermissionService.INSTANCE) {
|
||||||
|
is AbstractConcurrentPermissionService -> ps.getPermittedPermissionsAndSource(this)
|
||||||
|
else -> ps.getPermittedPermissions(this).map { this to it }
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user