mirror of
https://github.com/Steffo99/twom.git
synced 2024-11-25 01:24:24 +00:00
Add permission checks to invite and kicks
This commit is contained in:
parent
04e8aa3743
commit
40bfd858ee
5 changed files with 96 additions and 3 deletions
|
@ -10,6 +10,7 @@ import androidx.compose.ui.Modifier
|
||||||
import androidx.compose.ui.res.stringResource
|
import androidx.compose.ui.res.stringResource
|
||||||
import androidx.compose.ui.tooling.preview.Preview
|
import androidx.compose.ui.tooling.preview.Preview
|
||||||
import eu.steffo.twom.R
|
import eu.steffo.twom.R
|
||||||
|
import eu.steffo.twom.viewroom.effects.canIInvite
|
||||||
|
|
||||||
@Composable
|
@Composable
|
||||||
@Preview
|
@Preview
|
||||||
|
@ -17,7 +18,10 @@ fun InviteFAB(
|
||||||
modifier: Modifier = Modifier,
|
modifier: Modifier = Modifier,
|
||||||
onClick: () -> Unit = {},
|
onClick: () -> Unit = {},
|
||||||
) {
|
) {
|
||||||
// TODO: Hide if unprivileged
|
if (!canIInvite()) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
ExtendedFloatingActionButton(
|
ExtendedFloatingActionButton(
|
||||||
modifier = modifier,
|
modifier = modifier,
|
||||||
onClick = { onClick() },
|
onClick = { onClick() },
|
||||||
|
|
|
@ -28,6 +28,7 @@ import eu.steffo.twom.avatar.components.AvatarUser
|
||||||
import eu.steffo.twom.errorhandling.components.ErrorText
|
import eu.steffo.twom.errorhandling.components.ErrorText
|
||||||
import eu.steffo.twom.matrix.complocals.LocalSession
|
import eu.steffo.twom.matrix.complocals.LocalSession
|
||||||
import eu.steffo.twom.viewroom.complocals.LocalRoom
|
import eu.steffo.twom.viewroom.complocals.LocalRoom
|
||||||
|
import eu.steffo.twom.viewroom.effects.canIKick
|
||||||
import eu.steffo.twom.viewroom.effects.observeRSVP
|
import eu.steffo.twom.viewroom.effects.observeRSVP
|
||||||
import eu.steffo.twom.viewroom.effects.resolveUser
|
import eu.steffo.twom.viewroom.effects.resolveUser
|
||||||
import eu.steffo.twom.viewroom.utils.RSVPAnswer
|
import eu.steffo.twom.viewroom.utils.RSVPAnswer
|
||||||
|
@ -67,6 +68,7 @@ fun MemberListItem(
|
||||||
|
|
||||||
// This might not be necessary; I'm not sure when the internal Matrix client resolves users
|
// This might not be necessary; I'm not sure when the internal Matrix client resolves users
|
||||||
val user = resolveUser(member.userId)
|
val user = resolveUser(member.userId)
|
||||||
|
val canKick = canIKick()
|
||||||
|
|
||||||
val scope = rememberCoroutineScope()
|
val scope = rememberCoroutineScope()
|
||||||
|
|
||||||
|
@ -132,8 +134,7 @@ fun MemberListItem(
|
||||||
expanded = expanded,
|
expanded = expanded,
|
||||||
onDismissRequest = { expanded = false }
|
onDismissRequest = { expanded = false }
|
||||||
) {
|
) {
|
||||||
// TODO: Also hide if unprivileged
|
if (member.userId != session.myUserId && canKick) {
|
||||||
if (member.userId != session.myUserId) {
|
|
||||||
DropdownMenuItem(
|
DropdownMenuItem(
|
||||||
text = {
|
text = {
|
||||||
Text(stringResource(R.string.room_uninvite_label))
|
Text(stringResource(R.string.room_uninvite_label))
|
||||||
|
|
|
@ -0,0 +1,14 @@
|
||||||
|
package eu.steffo.twom.viewroom.effects
|
||||||
|
|
||||||
|
import androidx.compose.runtime.Composable
|
||||||
|
import eu.steffo.twom.matrix.complocals.LocalSession
|
||||||
|
import observePowerLevels
|
||||||
|
import kotlin.jvm.optionals.getOrNull
|
||||||
|
|
||||||
|
@Composable
|
||||||
|
fun canIInvite(): Boolean {
|
||||||
|
val session = LocalSession.current ?: return false
|
||||||
|
val powerLevelsRequest = observePowerLevels() ?: return false
|
||||||
|
val powerLevels = powerLevelsRequest.getOrNull() ?: return false
|
||||||
|
return powerLevels.second.isUserAbleToInvite(session.myUserId)
|
||||||
|
}
|
|
@ -0,0 +1,14 @@
|
||||||
|
package eu.steffo.twom.viewroom.effects
|
||||||
|
|
||||||
|
import androidx.compose.runtime.Composable
|
||||||
|
import eu.steffo.twom.matrix.complocals.LocalSession
|
||||||
|
import observePowerLevels
|
||||||
|
import kotlin.jvm.optionals.getOrNull
|
||||||
|
|
||||||
|
@Composable
|
||||||
|
fun canIKick(): Boolean {
|
||||||
|
val session = LocalSession.current ?: return false
|
||||||
|
val powerLevelsRequest = observePowerLevels() ?: return false
|
||||||
|
val powerLevels = powerLevelsRequest.getOrNull() ?: return false
|
||||||
|
return powerLevels.second.isUserAbleToKick(session.myUserId)
|
||||||
|
}
|
|
@ -0,0 +1,60 @@
|
||||||
|
import android.util.Log
|
||||||
|
import androidx.compose.runtime.Composable
|
||||||
|
import androidx.compose.runtime.getValue
|
||||||
|
import androidx.compose.runtime.livedata.observeAsState
|
||||||
|
import eu.steffo.twom.viewroom.complocals.LocalRoom
|
||||||
|
import org.matrix.android.sdk.api.query.QueryStringValue
|
||||||
|
import org.matrix.android.sdk.api.session.events.model.toModel
|
||||||
|
import org.matrix.android.sdk.api.session.room.model.PowerLevelsContent
|
||||||
|
import org.matrix.android.sdk.api.session.room.powerlevels.PowerLevelsHelper
|
||||||
|
import java.util.Optional
|
||||||
|
import kotlin.jvm.optionals.getOrNull
|
||||||
|
|
||||||
|
|
||||||
|
private const val TAG = "observePowerLevels"
|
||||||
|
|
||||||
|
|
||||||
|
@Composable
|
||||||
|
fun observePowerLevels(): Optional<Pair<PowerLevelsContent, PowerLevelsHelper>>? {
|
||||||
|
val roomRequest = LocalRoom.current
|
||||||
|
|
||||||
|
if (roomRequest == null) {
|
||||||
|
Log.v(TAG, "Requesting room information, not doing anything.")
|
||||||
|
return null
|
||||||
|
}
|
||||||
|
|
||||||
|
val room = roomRequest.getOrNull()
|
||||||
|
|
||||||
|
if (room == null) {
|
||||||
|
Log.e(TAG, "Room was not found, not doing anything.")
|
||||||
|
return null
|
||||||
|
}
|
||||||
|
|
||||||
|
val powerLevelsRequest by room.stateService().getStateEventLive(
|
||||||
|
eventType = "m.room.power_levels",
|
||||||
|
stateKey = QueryStringValue.IsEmpty,
|
||||||
|
).observeAsState()
|
||||||
|
|
||||||
|
if (powerLevelsRequest == null) {
|
||||||
|
Log.v(TAG, "Power level event is being requested.")
|
||||||
|
return null
|
||||||
|
}
|
||||||
|
|
||||||
|
val powerLevels = powerLevelsRequest?.getOrNull()
|
||||||
|
|
||||||
|
if (powerLevels == null) {
|
||||||
|
Log.v(TAG, "No power level event has been found.")
|
||||||
|
return Optional.empty()
|
||||||
|
}
|
||||||
|
|
||||||
|
val powerLevelsContent = powerLevels.content.toModel<PowerLevelsContent>()
|
||||||
|
|
||||||
|
if (powerLevelsContent == null) {
|
||||||
|
Log.e(TAG, "Could not deserialize power levels event.")
|
||||||
|
return Optional.empty()
|
||||||
|
}
|
||||||
|
|
||||||
|
val powerLevelsHelper = PowerLevelsHelper(powerLevelsContent)
|
||||||
|
|
||||||
|
return Optional.of(Pair(powerLevelsContent, powerLevelsHelper))
|
||||||
|
}
|
Loading…
Reference in a new issue