GetAdminServlet.java
package com.popx.presentazione;
import com.popx.modello.ProdottoBean;
import com.popx.persistenza.ProdottoDAO;
import com.popx.persistenza.ProdottoDAOImpl;
import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.*;
import java.io.IOException;
import java.util.List;
@WebServlet(name = "GetAdminServlet", urlPatterns = {"/getAdminServlet"})
public class GetAdminServlet extends HttpServlet {
private final ProdottoDAO prodottoDAO;
private static final int PRODUCTS_PER_PAGE = 6;
// 👉 production
public GetAdminServlet() {
this.prodottoDAO = new ProdottoDAOImpl();
}
// 👉 test
public GetAdminServlet(ProdottoDAO prodottoDAO) {
this.prodottoDAO = prodottoDAO;
}
@Override
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
List<ProdottoBean> prodotti;
try {
prodotti = prodottoDAO.getAllProducts();
} catch (Exception e) {
response.sendError(
HttpServletResponse.SC_INTERNAL_SERVER_ERROR,
"Errore durante il recupero dei prodotti."
);
return;
}
if (prodotti == null) {
response.sendError(
HttpServletResponse.SC_INTERNAL_SERVER_ERROR,
"Errore durante il recupero dei prodotti."
);
return;
}
int totalProducts = prodotti.size();
int totalPages = (int) Math.ceil((double) totalProducts / PRODUCTS_PER_PAGE);
int currentPage = 1;
String pageParam = request.getParameter("page");
if (pageParam != null) {
try {
currentPage = Integer.parseInt(pageParam);
if (currentPage < 1) currentPage = 1;
} catch (NumberFormatException ignored) {
currentPage = 1;
}
}
int start = (currentPage - 1) * PRODUCTS_PER_PAGE;
int end = Math.min(start + PRODUCTS_PER_PAGE, totalProducts);
List<ProdottoBean> productsForPage = prodotti.subList(start, end);
request.setAttribute("products", productsForPage);
request.setAttribute("currentPage", currentPage);
request.setAttribute("totalPages", totalPages);
request.getRequestDispatcher("/jsp/DashboardAdmin.jsp")
.forward(request, response);
}
}