diff --git a/onyxia-api/src/main/java/fr/insee/onyxia/api/security/LogUserInfoFilter.java b/onyxia-api/src/main/java/fr/insee/onyxia/api/security/LogUserInfoFilter.java new file mode 100644 index 00000000..381cefb3 --- /dev/null +++ b/onyxia-api/src/main/java/fr/insee/onyxia/api/security/LogUserInfoFilter.java @@ -0,0 +1,32 @@ +package fr.insee.onyxia.api.security; + +import fr.insee.onyxia.api.configuration.properties.RegionsConfiguration; +import fr.insee.onyxia.api.services.UserProvider; +import jakarta.servlet.FilterChain; +import jakarta.servlet.ServletException; +import jakarta.servlet.http.HttpServletRequest; +import jakarta.servlet.http.HttpServletResponse; +import org.slf4j.MDC; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Component; +import org.springframework.web.filter.OncePerRequestFilter; + +import java.io.IOException; + +@Component +public class LogUserInfoFilter extends OncePerRequestFilter { + + @Autowired + private UserProvider userProvider; + + @Autowired + private RegionsConfiguration regionsConfiguration; + + @Override + protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, + FilterChain filterChain) throws ServletException, IOException { + MDC.put("username", userProvider.getUser(regionsConfiguration.getDefaultRegion()).getIdep()); + filterChain.doFilter(request, response); + MDC.clear(); + } +} \ No newline at end of file