Merge branch 'feature/session-storage' into develop

This commit is contained in:
ISA
2025-01-20 12:20:32 +01:00
5 changed files with 71 additions and 61 deletions

View File

@@ -8,32 +8,45 @@ import { useSelector } from "react-redux";
import decodeToken from "../utils/decodeToken"; import decodeToken from "../utils/decodeToken";
function Header() { function Header() {
const isAdminLoggedIn = useSelector((state) => state.auth.isAdminLoggedIn);
const router = useRouter(); const router = useRouter();
const deviceName = useSelector((state) => state.variables.deviceName);
const [showSettingsModal, setShowSettingsModal] = useState(false); const [showSettingsModal, setShowSettingsModal] = useState(false);
//const [isAdminLoggedIn, setIsAdminLoggedIn] = useState(false); const [isAdminLoggedIn, setIsAdminLoggedIn] = useState(false);
const deviceName = useSelector((state) => state.variables.deviceName);
const handleSettingsClick = () => setShowSettingsModal(true); const handleSettingsClick = () => setShowSettingsModal(true);
const handleCloseSettingsModal = () => setShowSettingsModal(false); const handleCloseSettingsModal = () => setShowSettingsModal(false);
const handleLogout = () => { const handleLogout = () => {
localStorage.removeItem("token"); // Token entfernen beim Abmelden sessionStorage.removeItem("token"); // Token entfernen
//setIsAdminLoggedIn(false); localStorage.setItem("isAdminLoggedIn", "false"); // Admin-Status entfernen
window.location.href = "/offline.html"; setIsAdminLoggedIn(false); // Zustand sofort aktualisieren
router.push("/offline.html"); // Weiterleitung
};
const handleLogin = () => {
const token = JSON.stringify({ exp: Date.now() + 5 * 60 * 1000 }); // Beispiel-Token mit 5 Minuten Ablaufzeit
sessionStorage.setItem("token", token); // Token speichern
localStorage.setItem("isAdminLoggedIn", "true"); // Admin-Status setzen
setIsAdminLoggedIn(true); // Zustand sofort aktualisieren
}; };
// Funktion, um den Token-Status zu prüfen
useEffect(() => { useEffect(() => {
const token = localStorage.getItem("token"); // Initialer Check beim Laden der Komponente
if (token) { const isAdmin = localStorage.getItem("isAdminLoggedIn") === "true";
const { exp } = decodeToken(token); setIsAdminLoggedIn(isAdmin);
if (exp && Date.now() < exp) {
// Token ist gültig // Beobachten von Änderungen in localStorage
} else { const interval = setInterval(() => {
localStorage.removeItem("token"); // Entferne abgelaufenen Token const updatedIsAdmin = localStorage.getItem("isAdminLoggedIn") === "true";
if (updatedIsAdmin !== isAdminLoggedIn) {
setIsAdminLoggedIn(updatedIsAdmin);
} }
} }, 500); // Überprüfung alle 500ms
}, []);
return () => {
clearInterval(interval); // Intervall stoppen, wenn die Komponente entladen wird
};
}, [isAdminLoggedIn]);
return ( return (
<header className="bg-gray-300 flex justify-between items-center w-full h-28 relative text-black"> <header className="bg-gray-300 flex justify-between items-center w-full h-28 relative text-black">

View File

@@ -89,7 +89,7 @@ function KueModal({ showModal, onClose, slot, onModulNameChange }) {
}, [showModal]); // nur von showModal abhängig ansonsten wird alle 10 Sekunden die Werte zurückgesetzt in Modal }, [showModal]); // nur von showModal abhängig ansonsten wird alle 10 Sekunden die Werte zurückgesetzt in Modal
//------------------------------------------------------------------------------------------------------------ //------------------------------------------------------------------------------------------------------------
useEffect(() => { useEffect(() => {
const token = localStorage.getItem("token"); const token = sessionStorage.getItem("token");
if (token) { if (token) {
const decoded = decodeToken(token); const decoded = decodeToken(token);
if (decoded && decoded.role.toLowerCase() === "admin") { if (decoded && decoded.role.toLowerCase() === "admin") {

View File

@@ -9,12 +9,18 @@ import handleReboot from "./handlers/handleReboot";
import handleSetDateTime from "./handlers/handleSetDateTime"; import handleSetDateTime from "./handlers/handleSetDateTime";
import handleSubmit from "./handlers/handleSubmit"; import handleSubmit from "./handlers/handleSubmit";
import { useRouter } from "next/router"; import { useRouter } from "next/router";
import { setAdminLoggedIn } from "../../../store/authSlice";
import CryptoJS from "crypto-js";
import bcrypt from "bcryptjs"; import bcrypt from "bcryptjs";
ReactModal.setAppElement("#__next"); ReactModal.setAppElement("#__next");
const USERS = {
Admin: {
username: "admin",
// Gehashte Version von "admin" mit bcrypt
password: "$2a$10$xpq/.tcOJN/LXfzdCcCVrenlBh2nRlM1R1ISY7dd1q2qGWC9Fyd2G",
role: "Admin",
},
};
// Function to generate JWT token // Function to generate JWT token
function generateToken(user) { function generateToken(user) {
const payload = { const payload = {
@@ -39,40 +45,33 @@ function decryptToken(encryptedToken) {
} }
function SettingModal({ showModal, onClose }) { function SettingModal({ showModal, onClose }) {
const isAdminLoggedIn = useSelector((state) => state.auth.isAdminLoggedIn); const [isAdminLoggedIn, setAdminLoggedIn] = useState(false);
const USERS = useSelector((state) => state.auth.users); //const isAdminLoggedIn = sessionStorage.getItem("token");
const dispatch = useDispatch();
const [username, setUsername] = useState(""); const [username, setUsername] = useState("");
const [password, setPassword] = useState(""); const [password, setPassword] = useState("");
const [error, setError] = useState(""); const [error, setError] = useState("");
const [isLoggedIn, setIsLoggedIn] = useState(false);
const [showLoginForm, setShowLoginForm] = useState(false); // Zustand für Login-Formular const [showLoginForm, setShowLoginForm] = useState(false); // Zustand für Login-Formular
const router = useRouter(); const router = useRouter();
const handleAdminLogin = async (e) => { function handleAdminLogin(e) {
e.preventDefault(); e.preventDefault();
const userInput = username.toLowerCase(); // Benutzername in Kleinbuchstaben const user = USERS.Admin; // Finde den Admin-Benutzer
const user = Object.values(USERS).find( bcrypt.compare(password, user.password, (err, isMatch) => {
(u) => u.username.toLowerCase() === userInput if (isMatch) {
); const token = generateToken(user);
sessionStorage.setItem("token", token); // Speichere Token in SessionStorage
if (user && (await bcrypt.compare(password, user.password))) { localStorage.setItem("isAdminLoggedIn", "true");
// Token generieren
const token = generateToken({ username: user.username, role: "Admin" });
// Token in localStorage speichern
localStorage.setItem("token", token);
dispatch(setAdminLoggedIn(true));
setError("");
onClose();
} else {
setError(
"Login fehlgeschlagen. Bitte überprüfen Sie Benutzername und Passwort."
);
}
};
setShowLoginForm(false);
onClose();
} else {
setError(
"Login fehlgeschlagen. Bitte überprüfen Sie Benutzername und Passwort."
);
}
});
}
const deviceName_Redux = useSelector((state) => state.variables.deviceName); const deviceName_Redux = useSelector((state) => state.variables.deviceName);
const mac1_Redux = useSelector((state) => state.variables.mac1); const mac1_Redux = useSelector((state) => state.variables.mac1);
const ip_Redux = useSelector((state) => state.variables.ip); const ip_Redux = useSelector((state) => state.variables.ip);
@@ -112,8 +111,8 @@ function SettingModal({ showModal, onClose }) {
active, active,
}; };
const handleAdminLogout = () => { const handleAdminLogout = () => {
localStorage.removeItem("token"); // Remove token on logout sessionStorage.removeItem("token"); // Token aus sessionStorage entfernen
dispatch(setAdminLoggedIn(false)); // Update Redux state localStorage.setItem("isAdminLoggedIn", "false"); // Admin-Status im localStorage setzen
}; };
useEffect(() => { useEffect(() => {
@@ -156,18 +155,15 @@ function SettingModal({ showModal, onClose }) {
active_Redux, active_Redux,
]); ]);
useEffect(() => { useEffect(() => {
const token = localStorage.getItem("token"); // Check if a valid token exists in localStorage
const token = sessionStorage.getItem("token");
if (token) { if (token) {
try { setAdminLoggedIn(true);
const decrypted = decryptToken(token); const { exp } = JSON.parse(atob(token));
if (Date.now() < decrypted.exp) { if (Date.now() < exp) {
setIsLoggedIn(true); setAdminLoggedIn(true);
} else { } else {
localStorage.removeItem("token"); // Entfernen, wenn abgelaufen // localStorage.removeItem("token"); // Remove expired token
}
} catch (error) {
console.error("Fehler beim Token-Entschlüsseln:", error);
localStorage.removeItem("token"); // Entfernen bei Fehler
} }
} }
}, []); }, []);

View File

@@ -126,7 +126,8 @@ function Kue705FO({
return; return;
} }
let slotFormat = slot < 10 ? `0${slot}` : `${slot}`; // Entfernt führende Nullen, falls vorhanden
let slotFormat = slot < 10 ? `${parseInt(slot, 10)}` : `${slot}`;
setLoading(true); setLoading(true);
alert(`TDR wird für Slot ${slot + 1} gestartet...`); alert(`TDR wird für Slot ${slot + 1} gestartet...`);

View File

@@ -177,7 +177,7 @@ function Dashboard() {
<div className="flex flex-row p-2 space-x-2"> <div className="flex flex-row p-2 space-x-2">
<Icon icon="mdi:web" className="text-xl text-blue-400" /> <Icon icon="mdi:web" className="text-xl text-blue-400" />
<p className="text-sm text-gray-600"> <p className="text-sm text-gray-600">
<span className="font-bold"> </span>Webserverversion: 1.0.5 <span className="font-bold"> </span>Webserverversion: 1.0.5.0
</p> </p>
</div> </div>
</div> </div>