-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSecurityServlet.java
More file actions
89 lines (70 loc) · 3.35 KB
/
Copy pathSecurityServlet.java
File metadata and controls
89 lines (70 loc) · 3.35 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
package com.securefileshare.servlets;
import com.securefileshare.models.User;
import com.securefileshare.dao.FileDAO;
import com.securefileshare.dao.AuditDAO;
import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.*;
import java.io.IOException;
import java.util.List;
public class SecurityServlet extends HttpServlet {
private FileDAO fileDAO;
private AuditDAO auditDAO;
@Override
public void init() throws ServletException {
try {
this.fileDAO = new FileDAO();
this.auditDAO = new AuditDAO();
System.out.println("✓ SecurityServlet initialized successfully");
} catch (Exception e) {
System.err.println("✗ SecurityServlet initialization failed: " + e.getMessage());
e.printStackTrace();
}
}
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
try {
HttpSession session = request.getSession(false);
if (session == null || session.getAttribute("user") == null) {
response.sendRedirect(request.getContextPath() + "/jsp/login.jsp");
return;
}
User user = (User) session.getAttribute("user");
System.out.println("\n=== SECURITY DASHBOARD REQUEST ===");
System.out.println("User: " + user.getUsername() + " (ID: " + user.getUserId() + ")");
int totalFiles = fileDAO.getFileCountByUser(user.getUserId());
int encryptedFiles = fileDAO.getEncryptedFileCountByUser(user.getUserId());
int encryptionPercentage = totalFiles > 0 ? (encryptedFiles * 100 / totalFiles) : 0;
List<AuditDAO.ActivityLog> securityEvents = auditDAO.getRecentActivitiesByAction(
user.getUserId(),
new String[]{"LOGIN", "LOGIN_FAILED", "DOWNLOAD", "UPLOAD", "DELETE"},
20
);
request.setAttribute("totalFiles", totalFiles);
request.setAttribute("encryptedFiles", encryptedFiles);
request.setAttribute("encryptionPercentage", encryptionPercentage);
request.setAttribute("securityEvents", securityEvents);
request.setAttribute("securityScore", calculateSecurityScore(user, totalFiles, encryptedFiles));
RequestDispatcher dispatcher = request.getRequestDispatcher("/jsp/user/security.jsp");
dispatcher.forward(request, response);
} catch (Exception e) {
System.err.println("✗ SecurityServlet error: " + e.getMessage());
e.printStackTrace();
response.sendError(HttpServletResponse.SC_INTERNAL_SERVER_ERROR, "Unable to load security dashboard");
}
}
private int calculateSecurityScore(User user, int totalFiles, int encryptedFiles) {
int score = 0;
if (user != null) {
score += 20;
}
if (totalFiles > 0) {
score += (encryptedFiles * 40) / totalFiles;
} else {
score += 40;
}
score += 20;
return Math.min(score, 100);
}
}