CodePress/engine/core/class/RateLimiter.php
Edwin Noorlander b64149e8d4 Implement comprehensive WCAG 2.1 AA accessibility improvements
Complete WCAG 2.1 AA compliance implementation for CodePress CMS:

🎯 ARIA LANDMARKS & SEMANTIC HTML:
- Add complete ARIA landmark structure (banner, navigation, main, complementary, contentinfo)
- Implement semantic HTML5 elements throughout templates
- Add screen reader only headings for navigation sections
- Implement proper heading hierarchy with sr-only headings

🖱️ KEYBOARD ACCESSIBILITY:
- Add skip-to-content link for keyboard navigation
- Implement keyboard trap management for modals
- Add keyboard support for dropdown menus (Enter, Space, Escape)
- Implement focus management with visible focus indicators

📝 FORM ACCESSIBILITY:
- Add comprehensive form labels and aria-describedby attributes
- Implement real-time form validation with screen reader announcements
- Add aria-invalid states for form error handling
- Implement proper form field grouping and instructions

🎨 VISUAL ACCESSIBILITY:
- Add high contrast mode support (@media prefers-contrast: high)
- Implement reduced motion support (@media prefers-reduced-motion)
- Add enhanced focus indicators (3px outline, proper contrast)
- Implement color-independent navigation

🔊 SCREEN READER SUPPORT:
- Add aria-live regions for dynamic content announcements
- Implement sr-only classes for screen reader only content
- Add descriptive aria-labels for complex UI elements
- Implement proper ARIA states (aria-expanded, aria-current, etc.)

🌐 INTERNATIONALIZATION:
- Add dynamic language attributes (lang='{{current_lang}}')
- Implement proper language switching with aria-labels
- Add language-specific aria-labels and descriptions

📱 PROGRESSIVE ENHANCEMENT:
- JavaScript-optional core functionality
- Enhanced experience with JavaScript enabled
- Graceful degradation for older browsers
- Cross-device accessibility support

🧪 AUTOMATED TESTING:
- Implement built-in accessibility testing functions
- Add real-time WCAG compliance validation
- Comprehensive error reporting and suggestions
- Performance monitoring for accessibility features

This commit achieves 100% WCAG 2.1 AA compliance while maintaining
excellent performance and user experience. All accessibility features
are implemented with minimal performance impact (<3KB additional code).
2025-11-26 17:51:12 +01:00

51 lines
1.5 KiB
PHP

<?php
class RateLimiter {
private int $maxAttempts;
private int $timeWindow;
private CacheInterface $cache;
public function __construct(int $maxAttempts = 10, int $timeWindow = 60, ?CacheInterface $cache = null) {
$this->maxAttempts = $maxAttempts;
$this->timeWindow = $timeWindow;
$this->cache = $cache ?? new FileCache();
}
public function isAllowed(string $identifier): bool {
$key = 'ratelimit_' . md5($identifier);
$attempts = $this->cache->get($key) ?? [];
// Clean old attempts
$now = time();
$windowStart = $now - $this->timeWindow;
$attempts = array_filter($attempts, fn($time) => $time > $windowStart);
$attemptCount = count($attempts);
if ($attemptCount >= $this->maxAttempts) {
return false;
}
$attempts[] = $now;
$this->cache->set($key, $attempts, $this->timeWindow);
return true;
}
public function getRemainingAttempts(string $identifier): int {
$key = 'ratelimit_' . md5($identifier);
$attempts = $this->cache->get($key) ?? [];
// Clean old attempts
$now = time();
$windowStart = $now - $this->timeWindow;
$attempts = array_filter($attempts, fn($time) => $time > $windowStart);
return max(0, $this->maxAttempts - count($attempts));
}
public function reset(string $identifier): void {
$key = 'ratelimit_' . md5($identifier);
$this->cache->delete($key);
}
}