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,85 @@
/**
* Analytics Module
*
* Provides unified analytics system for event tracking, page views, and user behavior.
*
* Usage:
* - Add data-module="analytics" to enable global analytics
* - Or import and use directly: import { Analytics } from './modules/analytics/index.js'
*
* Features:
* - Event tracking
* - Page view tracking
* - User behavior tracking
* - Custom events
* - Integration with LiveComponents
* - GDPR compliance
*/
import { Logger } from '../../core/logger.js';
import { Analytics, AnalyticsProvider, GoogleAnalyticsProvider, CustomProvider } from './Analytics.js';
const AnalyticsModule = {
name: 'analytics',
analytics: null,
init(config = {}, state = null) {
Logger.info('[AnalyticsModule] Module initialized');
// Create analytics instance
this.analytics = Analytics.create(config);
// Expose globally for easy access
if (typeof window !== 'undefined') {
window.Analytics = this.analytics;
}
return this;
},
/**
* Get analytics instance
*/
getAnalytics() {
return this.analytics || Analytics.create();
},
/**
* Track event
*/
async track(eventName, properties = {}) {
const analytics = this.getAnalytics();
return await analytics.track(eventName, properties);
},
/**
* Track page view
*/
async trackPageView(path = null, properties = {}) {
const analytics = this.getAnalytics();
return await analytics.trackPageView(path, properties);
},
destroy() {
if (this.analytics) {
this.analytics.destroy();
this.analytics = null;
}
if (typeof window !== 'undefined' && window.Analytics) {
delete window.Analytics;
}
Logger.info('[AnalyticsModule] Module destroyed');
}
};
// Export for direct usage
export { Analytics, AnalyticsProvider, GoogleAnalyticsProvider, CustomProvider };
// Export as default for module system
export default AnalyticsModule;
// Export init function for module system
export const init = AnalyticsModule.init.bind(AnalyticsModule);