Implement JWT authentication and user token management

This commit is contained in:
Torsten Schulz
2025-07-17 11:47:37 +02:00
parent ad2ab3cae8
commit 353b8386ee
4 changed files with 44 additions and 19 deletions

View File

@@ -1,4 +1,7 @@
import { register, activateUser, login, logout } from '../services/authService.js';
import jwt from 'jsonwebtoken';
import UserToken from '../models/UserToken.js';
import User from '../models/User.js'; // ggf. Pfad anpassen
const registerUser = async (req, res, next) => {
try {
@@ -20,24 +23,26 @@ const activate = async (req, res, next) => {
}
};
const loginUser = async (req, res, next) => {
try {
const { email, password } = req.body;
const result = await login(email, password);
res.status(200).json(result);
} catch (error) {
next(error);
const loginUser = async (req, res) => {
const { username, password } = req.body;
const user = await User.findOne({ where: { username } });
if (!user || !(await user.validatePassword(password))) {
return res.status(401).json({ message: 'Ungültige Anmeldedaten' });
}
const token = jwt.sign({ userId: user.id }, process.env.JWT_SECRET, { expiresIn: '1h' });
await UserToken.create({
userId: user.id,
token,
expiresAt: new Date(Date.now() + 3600 * 1000),
});
res.json({ token });
};
const logoutUser = async(req, res) => {
const { userid: userId, authtoken: authToken } = req.headers;
try {
logout(userId, authToken);
} catch (error) {
res.status(401).json({ msg: 'not found' });
}
res.status(200).json({ msg: 'loggedout' });
}
const logoutUser = async (req, res) => {
const token = req.headers['authorization']?.split(' ')[1];
if (!token) return res.status(400).json({ message: 'Token fehlt' });
await UserToken.destroy({ where: { token } });
res.json({ message: 'Logout erfolgreich' });
};
export { registerUser, activate, loginUser, logoutUser };

View File

@@ -0,0 +1,20 @@
import { DataTypes } from 'sequelize';
import sequelize from '../database.js'; // Korrigierter Pfad
const UserToken = sequelize.define('UserToken', {
userId: {
type: DataTypes.INTEGER,
allowNull: false,
},
token: {
type: DataTypes.STRING,
allowNull: false,
unique: true,
},
expiresAt: {
type: DataTypes.DATE,
allowNull: false,
},
});
export default UserToken;

View File

@@ -6,6 +6,6 @@ const router = express.Router();
router.post('/register', registerUser);
router.get('/activate/:activationCode', activate);
router.post('/login', loginUser);
router.get('/logout', logoutUser);
router.post('/logout', logoutUser); // Ändere GET zu POST
export default router;

View File

@@ -55,8 +55,8 @@ const store = createStore({
logout({ commit }) {
commit('clearToken');
commit('clearUsername');
router.push("/");
window.location.reload();
router.push('/login'); // Leitet den Benutzer zur Login-Seite um
window.location.reload(); // Optional, um den Zustand vollständig zurückzusetzen
},
setCurrentClub({ commit }, club) {