Refactor button management in UserController; implement role-based button filtering and update views to use dynamic button lists
This commit is contained in:
		
							parent
							
								
									bde7cc3407
								
							
						
					
					
						commit
						458d79d401
					
				|  | @ -5,14 +5,20 @@ import com.ieslamar.GestionInventario.dto.BotonDTO; | |||
| import com.ieslamar.GestionInventario.entities.User; | ||||
| import com.ieslamar.GestionInventario.services.UserService; | ||||
| import org.springframework.beans.factory.annotation.Autowired; | ||||
| import org.springframework.security.core.Authentication; | ||||
| import org.springframework.security.core.context.SecurityContextHolder; | ||||
| import org.springframework.stereotype.Controller; | ||||
| import org.springframework.ui.Model; | ||||
| import org.springframework.security.core.Authentication; | ||||
| import org.springframework.security.core.GrantedAuthority; | ||||
| 
 | ||||
| import org.springframework.web.bind.annotation.GetMapping; | ||||
| import org.springframework.web.bind.annotation.PostMapping; | ||||
| import org.springframework.web.bind.annotation.RequestParam; | ||||
| import org.springframework.security.core.Authentication; | ||||
| import org.springframework.security.core.GrantedAuthority; | ||||
| 
 | ||||
| import java.util.ArrayList; | ||||
| 
 | ||||
| 
 | ||||
| import java.util.ArrayList; | ||||
| import java.util.List; | ||||
| 
 | ||||
| @Controller | ||||
|  | @ -25,29 +31,76 @@ public class UserController { | |||
|         this.userService = userService; | ||||
|     } | ||||
| 
 | ||||
|     private final BotonDTO gestionUsuarios = new BotonDTO("Gestión de usuarios", "/user_management", true, null); | ||||
|     private final BotonDTO gestionProductos = new BotonDTO("Gestión de Productos", "/user_management", true, null); | ||||
|     private final BotonDTO gestionDepartamentos = new BotonDTO("Gestión de Departamentos", "/user_management", true, null); | ||||
|     private final BotonDTO gestionCategorias = new BotonDTO("Gestión de Categorías", "/user_management", true, null); | ||||
|     private final BotonDTO gestionUbicaciones = new BotonDTO("Gestión de Ubicaciones", "/user_management", true, null); | ||||
|     private final BotonDTO gestionInventario = new BotonDTO("Gestión de Inventario", "/user_management", true, null); | ||||
|     private final BotonDTO gestionTiposDatos = new BotonDTO("Gestión de Tipos de dato", "/user_management", true, null); | ||||
| 
 | ||||
|     private final BotonDTO inventario = new BotonDTO("Inventario", "/management", false, null); | ||||
|     private final BotonDTO gestion = new BotonDTO("Gestión", "/management", true, null); | ||||
| 
 | ||||
|     private final BotonDTO home = new BotonDTO("Salir", "/home", false, "button_salir"); | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|     private List<BotonDTO> filtrarBotones(Authentication auth,List<BotonDTO> botones){ | ||||
|         List<BotonDTO> botones_response = new ArrayList<>(); | ||||
|         List<String> roles = auth.getAuthorities() | ||||
|                          .stream() | ||||
|                          .map(GrantedAuthority::getAuthority) | ||||
|                          .toList(); | ||||
|         if (roles.contains("ROLE_ADMIN")) { | ||||
|             return botones; | ||||
|         } | ||||
|         for (BotonDTO botone : botones) { | ||||
|             if (!botone.isRequireAdmin()) { | ||||
|                 botones_response.add(botone); | ||||
|             } | ||||
|         } | ||||
|         return botones_response; | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|     @GetMapping("/login") | ||||
|     public String loginPage() { | ||||
|         return "login";  // Retorna la vista login.html | ||||
|     } | ||||
| 
 | ||||
| @GetMapping("/filtered-buttons") | ||||
| public String getFilteredButtons(Model model, Authentication authentication) { | ||||
|     List<BotonDTO> botones = List.of( | ||||
|         new BotonDTO("Inventario", "/management", false, null), | ||||
|         new BotonDTO("Gestión", "/management", true, null) | ||||
|     ); | ||||
| 
 | ||||
|     // Filtrar botones según el rol del usuario | ||||
|     List<BotonDTO> filteredButtons = botones.stream() | ||||
|         .filter(button -> !button.isRequireAdmin() || | ||||
|                (authentication != null && authentication.getAuthorities().stream() | ||||
|                    .anyMatch(auth -> auth.getAuthority().equals("ROLE_ADMIN")))) | ||||
|         .toList(); | ||||
| 
 | ||||
|     model.addAttribute("buttons", filteredButtons); | ||||
|     return "home"; // Retorna la vista home.html | ||||
|     @GetMapping("/home") | ||||
|     public String homePage(Model model) { | ||||
|         Authentication auth = SecurityContextHolder.getContext().getAuthentication(); | ||||
|         List<BotonDTO> botones = filtrarBotones(auth,new ArrayList<>(List.of( | ||||
|                 inventario, | ||||
|                 gestion | ||||
|         ))); | ||||
|         model.addAttribute("buttons", botones); | ||||
|         return "home"; | ||||
|     } | ||||
| 
 | ||||
|     @GetMapping("/management") | ||||
|     public String managementPage(Model model){ | ||||
|         Authentication auth = SecurityContextHolder.getContext().getAuthentication(); | ||||
|         List<BotonDTO>botones =  filtrarBotones(auth,new ArrayList<>(List.of( | ||||
|                 gestionUsuarios, | ||||
|                 gestionProductos, | ||||
|                 gestionDepartamentos, | ||||
|                 gestionCategorias, | ||||
|                 gestionUbicaciones, | ||||
|                 gestionInventario, | ||||
|                 gestionCategorias, | ||||
|                 gestionTiposDatos, | ||||
|                 home | ||||
|         ))); | ||||
|         model.addAttribute("buttons", botones); | ||||
|         return "management"; | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|     @GetMapping("/register") | ||||
|     public String registerPage() { | ||||
|         return "register";  // Retorna la vista register.html | ||||
|  | @ -58,10 +111,6 @@ public String getFilteredButtons(Model model, Authentication authentication) { | |||
|         userService.registerUser(username, password, role, mail, null); | ||||
|         return "redirect:/login?success";  // Redirige al login tras registrarse | ||||
|     } | ||||
|     @GetMapping("/management") | ||||
|     public String managementPage(){ | ||||
|         return "management"; | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|     @GetMapping("/user_management") | ||||
|  |  | |||
|  | @ -20,6 +20,7 @@ p { | |||
| 
 | ||||
| 
 | ||||
| .container1{ | ||||
|     margin: 10px; | ||||
|     background-color: rgba(255,255,255,0.4); | ||||
|     display: inline-flex; | ||||
|     flex-direction: column; | ||||
|  |  | |||
|  | @ -2,15 +2,13 @@ | |||
| <!DOCTYPE html> | ||||
| <html xmlns:th="http://www.thymeleaf.org" xmlns:sec="http://www.w3.org/1999/xhtml"> | ||||
| <body> | ||||
|     <div th:fragment="buttonList(buttons)"> | ||||
|     <div class="container1"> | ||||
|     <div th:fragment="buttonList(buttons)" class="container1"> | ||||
|         <div th:each="button : ${buttons}"> | ||||
|             <a th:href="@{${button.getUrl()}}"> | ||||
|                 <button th:class="${button.getCssClass()}" th:text="${button.getTexto()}"></button> | ||||
|             </a> | ||||
|         </div> | ||||
|     </div> | ||||
| </div> | ||||
| </body> | ||||
| </html> | ||||
| 
 | ||||
|  |  | |||
|  | @ -0,0 +1,13 @@ | |||
| <!-- fragments/buttons.html --> | ||||
| <!DOCTYPE html> | ||||
| <html xmlns:th="http://www.thymeleaf.org" xmlns:sec="http://www.w3.org/1999/xhtml"> | ||||
| <body> | ||||
|     <div th:fragment="List()" class="container1"> | ||||
| 
 | ||||
|     </div> | ||||
| </body> | ||||
| </html> | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  | @ -11,7 +11,7 @@ | |||
|     <div th:replace="fragments/buttons :: buttonList(${buttons})"></div> | ||||
| 
 | ||||
|     <!-- Formulario de Logout (estático y fuera del fragmento) --> | ||||
|     <form th:action="@{/logout}" method="post"> | ||||
|     <form class="container1" th:action="@{/logout}" method="post"> | ||||
|         <button class="button_salir" type="submit">Cerrar Sesión</button> | ||||
|         <input type="hidden" th:name="${_csrf.parameterName}" th:value="${_csrf.token}"/> | ||||
|     </form> | ||||
|  |  | |||
|  | @ -6,37 +6,7 @@ | |||
| </head> | ||||
| <body> | ||||
|     <h2 th:text="'Gestión'"></h2> | ||||
|     <div class="container1"> | ||||
|         <a href="/Inventario/user_management"> | ||||
|             <button>Gestión de Usuarios</button> | ||||
|         </a> | ||||
|         <!-- TODO: Cambiar la ruta a la de gestionar inventario --> | ||||
|         <a href="/Inventario/user_management"> | ||||
|             <button>Gestión de Productos</button> | ||||
|         </a> | ||||
|         <a href="/Inventario/user_management"> | ||||
|             <button>Gestión de Departamentos</button> | ||||
|         </a> | ||||
|         <a href="/Inventario/user_management"> | ||||
|             <button>Gestión de Categorías</button> | ||||
|         </a> | ||||
|         <a href="/Inventario/user_management"> | ||||
|             <button>Gestión de Ubicaciones</button> | ||||
|         </a> | ||||
|         <a href="/Inventario/user_management"> | ||||
|             <button>Gestión de Inventario</button> | ||||
|         </a> | ||||
|         <a href="/Inventario/user_management"> | ||||
|             <button>Gestión de Categorías</button> | ||||
|         </a> | ||||
|         <a href="/Inventario/user_management"> | ||||
|             <button>Gestión de Tipos de dato</button> | ||||
|         </a> | ||||
|     <div th:replace="fragments/buttons :: buttonList(${buttons})"></div> | ||||
| 
 | ||||
|         <a href="/Inventario/home"> | ||||
|             <button class="button_salir">Volver al inicio</button> | ||||
|         </a> | ||||
| 
 | ||||
|     </div> | ||||
| </body> | ||||
| </html> | ||||
		Loading…
	
		Reference in New Issue