1
0

introduce Context service

This commit is contained in:
Michael Hoennig
2022-07-29 14:24:50 +02:00
parent 2b630aadbc
commit 414149f0a1
8 changed files with 132 additions and 44 deletions

View File

@ -1,26 +0,0 @@
package net.hostsharing.hsadminng;
import org.assertj.core.api.Assertions;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.autoconfigure.orm.jpa.DataJpaTest;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.transaction.Transactional;
@DataJpaTest
class RbacIntegrationTests {
@PersistenceContext
private EntityManager em;
@Test
@Transactional
void currentUser() {
em.createNativeQuery("SET LOCAL hsadminng.currentUser = 'mike@hostsharing.net';").executeUpdate();
em.createNativeQuery("SET LOCAL hsadminng.assumedRoles = '';").executeUpdate();
final var result = em.createNativeQuery("select currentUser()").getSingleResult();
Assertions.assertThat(result).isEqualTo("mike@hostsharing.net");
}
}

View File

@ -0,0 +1,43 @@
package net.hostsharing.hsadminng.context;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.orm.jpa.DataJpaTest;
import org.springframework.context.annotation.ComponentScan;
import javax.transaction.Transactional;
import static org.assertj.core.api.Assertions.assertThat;
@DataJpaTest
@ComponentScan(basePackageClasses = Context.class)
class ContextIntegrationTests {
@Autowired
private Context context;
@Test
@Transactional
void setCurrentUser() {
context.setCurrentUser("mike@hostsharing.net");
final var currentUser = context.getCurrentUser();
assertThat(currentUser).isEqualTo("mike@hostsharing.net");
final var assumedRoles = context.getAssumedRoles();
assertThat(assumedRoles).isEmpty();
}
@Test
@Transactional
void assumeRoles() {
context.setCurrentUser("mike@hostsharing.net");
context.assumeRoles("customer#aaa.owner;customer#aab.owner");
final var currentUser = context.getCurrentUser();
assertThat(currentUser).isEqualTo("mike@hostsharing.net");
final var assumedRoles = context.getAssumedRoles();
assertThat(assumedRoles).containsExactlyInAnyOrder("customer#aaa.owner", "customer#aab.owner");
}
}

View File

@ -12,7 +12,7 @@ spring:
properties:
hibernate:
default_schema: public
dialect: org.hibernate.dialect.PostgreSQLDialect
dialect: net.hostsharing.hsadminng.config.PostgreSQL95CustomDialect
hibernate:
ddl-auto: none
show-sql: true
@ -29,9 +29,5 @@ logging:
level:
liquibase: INFO
# spring.datasource.driver-class-name=org.postgresql.Driver
# spring.datasource.url=${DB_URL}
# spring.datasource.username=${DB_USERNAME}
# spring.datasource.password=${DB_PASSWORD}
# spring.jpa.properties.hibernate.default-schema=public
liquibase:
contexts: dev,tc