AuthController.java 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. package com.provectus.kafka.ui.controller;
  2. import java.nio.charset.Charset;
  3. import lombok.RequiredArgsConstructor;
  4. import lombok.extern.slf4j.Slf4j;
  5. import org.springframework.security.web.server.csrf.CsrfToken;
  6. import org.springframework.util.MultiValueMap;
  7. import org.springframework.web.bind.annotation.GetMapping;
  8. import org.springframework.web.bind.annotation.RestController;
  9. import org.springframework.web.server.ServerWebExchange;
  10. import reactor.core.publisher.Mono;
  11. @RestController
  12. @RequiredArgsConstructor
  13. @Slf4j
  14. public class AuthController {
  15. @GetMapping(value = "/auth", produces = {"text/html"})
  16. public Mono<byte[]> getAuth(ServerWebExchange exchange) {
  17. Mono<CsrfToken> token = exchange.getAttributeOrDefault(CsrfToken.class.getName(), Mono.empty());
  18. return token
  19. .map(AuthController::csrfToken)
  20. .defaultIfEmpty("")
  21. .map(csrfTokenHtmlInput -> createPage(exchange, csrfTokenHtmlInput));
  22. }
  23. private byte[] createPage(ServerWebExchange exchange, String csrfTokenHtmlInput) {
  24. MultiValueMap<String, String> queryParams = exchange.getRequest()
  25. .getQueryParams();
  26. String contextPath = exchange.getRequest().getPath().contextPath().value();
  27. String page =
  28. "<!DOCTYPE html>\n" + "<html lang=\"en\">\n" + " <head>\n"
  29. + " <meta charset=\"utf-8\">\n"
  30. + " <meta name=\"viewport\" content=\"width=device-width, initial-scale=1, "
  31. + "shrink-to-fit=no\">\n"
  32. + " <meta name=\"description\" content=\"\">\n"
  33. + " <meta name=\"author\" content=\"\">\n"
  34. + " <title>Please sign in</title>\n"
  35. + " <link href=\"/static/css/bootstrap.min.css\" rel=\"stylesheet\" "
  36. + "integrity=\"sha384-/Y6pD6FV/Vv2HJnA6t+vslU6fwYXjCFtcEpHbNJ0lyAFsXTsjBbfaDjzALeQsN6M\" "
  37. + "crossorigin=\"anonymous\">\n"
  38. + " <link href=\"/static/css/signin.css\" "
  39. + "rel=\"stylesheet\" crossorigin=\"anonymous\"/>\n"
  40. + " </head>\n"
  41. + " <body>\n"
  42. + " <div class=\"container\">\n"
  43. + formLogin(queryParams, contextPath, csrfTokenHtmlInput)
  44. + " </div>\n"
  45. + " </body>\n"
  46. + "</html>";
  47. return page.getBytes(Charset.defaultCharset());
  48. }
  49. private String formLogin(
  50. MultiValueMap<String, String> queryParams,
  51. String contextPath, String csrfTokenHtmlInput) {
  52. boolean isError = queryParams.containsKey("error");
  53. boolean isLogoutSuccess = queryParams.containsKey("logout");
  54. return
  55. " <form class=\"form-signin\" method=\"post\" action=\"" + contextPath + "/auth\">\n"
  56. + " <h2 class=\"form-signin-heading\">Please sign in</h2>\n"
  57. + createError(isError)
  58. + createLogoutSuccess(isLogoutSuccess)
  59. + " <p>\n"
  60. + " <label for=\"username\" class=\"sr-only\">Username</label>\n"
  61. + " <input type=\"text\" id=\"username\" name=\"username\" class=\"form-control\" "
  62. + "placeholder=\"Username\" required autofocus>\n"
  63. + " </p>\n" + " <p>\n"
  64. + " <label for=\"password\" class=\"sr-only\">Password</label>\n"
  65. + " <input type=\"password\" id=\"password\" name=\"password\" "
  66. + "class=\"form-control\" placeholder=\"Password\" required>\n"
  67. + " </p>\n" + csrfTokenHtmlInput
  68. + " <button class=\"btn btn-lg btn-primary btn-block\" "
  69. + "type=\"submit\">Sign in</button>\n"
  70. + " </form>\n";
  71. }
  72. private static String csrfToken(CsrfToken token) {
  73. return " <input type=\"hidden\" name=\""
  74. + token.getParameterName()
  75. + "\" value=\""
  76. + token.getToken()
  77. + "\">\n";
  78. }
  79. private static String createError(boolean isError) {
  80. return isError
  81. ? "<div class=\"alert alert-danger\" role=\"alert\">Invalid credentials</div>"
  82. : "";
  83. }
  84. private static String createLogoutSuccess(boolean isLogoutSuccess) {
  85. return isLogoutSuccess
  86. ? "<div class=\"alert alert-success\" role=\"alert\">You have been signed out</div>"
  87. : "";
  88. }
  89. }