fix: Gitea Traefik routing and connection pool optimization
Some checks failed
🚀 Build & Deploy Image / Determine Build Necessity (push) Failing after 10m14s
🚀 Build & Deploy Image / Build Runtime Base Image (push) Has been skipped
🚀 Build & Deploy Image / Build Docker Image (push) Has been skipped
🚀 Build & Deploy Image / Run Tests & Quality Checks (push) Has been skipped
🚀 Build & Deploy Image / Auto-deploy to Staging (push) Has been skipped
🚀 Build & Deploy Image / Auto-deploy to Production (push) Has been skipped
Security Vulnerability Scan / Check for Dependency Changes (push) Failing after 11m25s
Security Vulnerability Scan / Composer Security Audit (push) Has been cancelled

- Remove middleware reference from Gitea Traefik labels (caused routing issues)
- Optimize Gitea connection pool settings (MAX_IDLE_CONNS=30, authentication_timeout=180s)
- Add explicit service reference in Traefik labels
- Fix intermittent 504 timeouts by improving PostgreSQL connection handling

Fixes Gitea unreachability via git.michaelschiemer.de
This commit is contained in:
2025-11-09 14:46:15 +01:00
parent 85c369e846
commit 36ef2a1e2c
1366 changed files with 104925 additions and 28719 deletions

View File

@@ -0,0 +1,86 @@
/**
* Security Module
*
* Provides security-related utilities including CSRF, XSS protection, and CSP helpers.
*
* Usage:
* - Add data-module="security" to enable global security features
* - Or import and use directly: import { SecurityManager } from './modules/security/index.js'
*
* Features:
* - CSRF token management and auto-refresh
* - XSS protection helpers
* - Content Security Policy helpers
* - Security headers validation
*/
import { Logger } from '../../core/logger.js';
import { SecurityManager } from './SecurityManager.js';
import { CsrfManager } from './CsrfManager.js';
const SecurityModule = {
name: 'security',
securityManager: null,
init(config = {}, state = null) {
Logger.info('[SecurityModule] Module initialized');
// Create security manager
this.securityManager = SecurityManager.create(config);
// Expose globally for easy access
if (typeof window !== 'undefined') {
window.SecurityManager = this.securityManager;
window.CsrfManager = this.securityManager.csrfManager;
}
return this;
},
/**
* Get security manager instance
*/
getSecurityManager() {
return this.securityManager || SecurityManager.create();
},
/**
* Get CSRF token
*/
getCsrfToken() {
return this.securityManager?.getCsrfToken() || null;
},
/**
* Refresh CSRF token
*/
async refreshCsrfToken() {
if (this.securityManager) {
return await this.securityManager.refreshCsrfToken();
}
},
destroy() {
if (this.securityManager) {
this.securityManager.destroy();
this.securityManager = null;
}
if (typeof window !== 'undefined') {
delete window.SecurityManager;
delete window.CsrfManager;
}
Logger.info('[SecurityModule] Module destroyed');
}
};
// Export for direct usage
export { SecurityManager, CsrfManager };
// Export as default for module system
export default SecurityModule;
// Export init function for module system
export const init = SecurityModule.init.bind(SecurityModule);