Throw exception if decisions is empty
This commit is contained in:
@@ -27,9 +27,13 @@ abstract class AccessKontrol {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* A helper to convert a list of subject into one response
|
* A helper to convert a list of subject into one response
|
||||||
|
*
|
||||||
|
* @throws [NoDecision] if the list of responses is empty
|
||||||
*/
|
*/
|
||||||
protected fun <S : List<T>, T> canAll(items: S, action: (T) -> AccessResponse): AccessResponses = items
|
protected fun <S : List<T>, T> canAll(items: S, action: (T) -> AccessResponse): AccessResponses = items
|
||||||
.map { action(it) }.let { responses ->
|
.ifEmpty { throw NoDecision() }
|
||||||
|
.map { action(it) }
|
||||||
|
.let { responses ->
|
||||||
if (responses.any { it is DeniedResponse }) {
|
if (responses.any { it is DeniedResponse }) {
|
||||||
DeniedResponses(responses)
|
DeniedResponses(responses)
|
||||||
} else {
|
} else {
|
||||||
@@ -50,9 +54,12 @@ typealias AccessResponses = List<AccessResponse>
|
|||||||
/**
|
/**
|
||||||
* Check all responses and return DENIED if one is DENIED
|
* Check all responses and return DENIED if one is DENIED
|
||||||
*
|
*
|
||||||
* If the list of responses is empty, return GRANTED
|
* @throws [NoDecision] if the list of responses is empty
|
||||||
*/
|
*/
|
||||||
fun AccessResponses.getFirstDecisionResponse(): AccessResponse = this.firstOrNull { it.decision == AccessDecision.DENIED } ?: this.first { it.decision == AccessDecision.GRANTED }
|
fun AccessResponses.getFirstDecisionResponse(): AccessResponse {
|
||||||
|
ifEmpty { throw NoDecision() }
|
||||||
|
return firstOrNull { it.decision == AccessDecision.DENIED } ?: first()
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Throw an Exception if one response is DENIED
|
* Throw an Exception if one response is DENIED
|
||||||
@@ -166,3 +173,5 @@ class DeniedResponses(
|
|||||||
accessResponses.deniedResponses.first().message,
|
accessResponses.deniedResponses.first().message,
|
||||||
accessResponses.deniedResponses.first().code
|
accessResponses.deniedResponses.first().code
|
||||||
)
|
)
|
||||||
|
|
||||||
|
class NoDecision : RuntimeException("No decision has been taken")
|
||||||
|
|||||||
@@ -59,6 +59,14 @@ class AccessKontrolTest {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun `test empty canAllGranted`() {
|
||||||
|
assertThrows(NoDecision::class.java) {
|
||||||
|
AccessControlSample()
|
||||||
|
.canView(listOf(), User(""))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun `test CanAllDenied`() {
|
fun `test CanAllDenied`() {
|
||||||
AccessControlSample().run {
|
AccessControlSample().run {
|
||||||
@@ -127,13 +135,14 @@ class AccessKontrolTest {
|
|||||||
.run {
|
.run {
|
||||||
assertFalse(decision.toBoolean())
|
assertFalse(decision.toBoolean())
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
AccessControlSample()
|
@Test
|
||||||
.canView(listOf(MyObject("denied"), MyObject("granted")), User(""))
|
fun `test getFirstDecisionResponse on empty`() {
|
||||||
.getFirstDecisionResponse()
|
assertThrows(NoDecision::class.java) {
|
||||||
.run {
|
listOf<AccessResponse>()
|
||||||
assertFalse(decision.toBoolean())
|
.getFirstDecisionResponse()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|||||||
Reference in New Issue
Block a user