fix: Login schlägt fehl bei HTTP ohne Reverse Proxy (Secure-Cookie)
SESSION_SECURE=false in .env deaktiviert das Secure-Flag für Session- und CSRF-Cookie. Notwendig wenn die App direkt per HTTP erreichbar ist (kein Nginx/HTTPS davor). Standard bleibt secure=true in production. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -7,6 +7,7 @@ NODE_ENV=production
|
|||||||
|
|
||||||
# Session
|
# Session
|
||||||
SESSION_SECRET=HIER_EINEN_LANGEN_ZUFAELLIGEN_STRING_EINTRAGEN
|
SESSION_SECRET=HIER_EINEN_LANGEN_ZUFAELLIGEN_STRING_EINTRAGEN
|
||||||
|
# SESSION_SECURE=false # Nur setzen wenn kein HTTPS/Reverse Proxy (z.B. direktes localhost)
|
||||||
|
|
||||||
# Datenbank (SQLite/SQLCipher)
|
# Datenbank (SQLite/SQLCipher)
|
||||||
DB_PATH=/data/oikos.db
|
DB_PATH=/data/oikos.db
|
||||||
|
|||||||
+6
-2
@@ -43,7 +43,10 @@ const sessionMiddleware = session({
|
|||||||
name: 'oikos.sid',
|
name: 'oikos.sid',
|
||||||
cookie: {
|
cookie: {
|
||||||
httpOnly: true,
|
httpOnly: true,
|
||||||
secure: process.env.NODE_ENV === 'production',
|
// SESSION_SECURE=false in .env erlaubt HTTP-Zugriff (z.B. direktes localhost ohne Reverse Proxy)
|
||||||
|
// Ohne diese Variable: secure=true wenn NODE_ENV=production
|
||||||
|
secure: process.env.SESSION_SECURE === 'false' ? false
|
||||||
|
: process.env.NODE_ENV === 'production',
|
||||||
sameSite: 'strict',
|
sameSite: 'strict',
|
||||||
maxAge: 1000 * 60 * 60 * 24 * 7, // 7 Tage in ms
|
maxAge: 1000 * 60 * 60 * 24 * 7, // 7 Tage in ms
|
||||||
},
|
},
|
||||||
@@ -130,7 +133,8 @@ router.post('/login', loginLimiter, async (req, res) => {
|
|||||||
res.cookie('csrf-token', req.session.csrfToken, {
|
res.cookie('csrf-token', req.session.csrfToken, {
|
||||||
httpOnly: false,
|
httpOnly: false,
|
||||||
sameSite: 'strict',
|
sameSite: 'strict',
|
||||||
secure: process.env.NODE_ENV === 'production',
|
secure: process.env.SESSION_SECURE === 'false' ? false
|
||||||
|
: process.env.NODE_ENV === 'production',
|
||||||
maxAge: 1000 * 60 * 60 * 24 * 7,
|
maxAge: 1000 * 60 * 60 * 24 * 7,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user