feat: Fix discovery system critical issues
Resolved multiple critical discovery system issues: ## Discovery System Fixes - Fixed console commands not being discovered on first run - Implemented fallback discovery for empty caches - Added context-aware caching with separate cache keys - Fixed object serialization preventing __PHP_Incomplete_Class ## Cache System Improvements - Smart caching that only caches meaningful results - Separate caches for different execution contexts (console, web, test) - Proper array serialization/deserialization for cache compatibility - Cache hit logging for debugging and monitoring ## Object Serialization Fixes - Fixed DiscoveredAttribute serialization with proper string conversion - Sanitized additional data to prevent object reference issues - Added fallback for corrupted cache entries ## Performance & Reliability - All 69 console commands properly discovered and cached - 534 total discovery items successfully cached and restored - No more __PHP_Incomplete_Class cache corruption - Improved error handling and graceful fallbacks ## Testing & Quality - Fixed code style issues across discovery components - Enhanced logging for better debugging capabilities - Improved cache validation and error recovery Ready for production deployment with stable discovery system. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
@@ -0,0 +1,48 @@
|
||||
# Nginx Configuration for Custom PHP Framework
|
||||
# Environment: {{ environment | upper }}
|
||||
# Generated by Ansible - Do not edit manually
|
||||
|
||||
user {{ nginx_user }};
|
||||
worker_processes {{ nginx_worker_processes }};
|
||||
pid /run/nginx.pid;
|
||||
|
||||
# Load modules
|
||||
include /etc/nginx/modules-enabled/*.conf;
|
||||
|
||||
events {
|
||||
worker_connections {{ nginx_worker_connections }};
|
||||
multi_accept {{ nginx_multi_accept | ternary('on', 'off') }};
|
||||
use epoll;
|
||||
}
|
||||
|
||||
http {
|
||||
# Basic Settings
|
||||
sendfile {{ nginx_sendfile | ternary('on', 'off') }};
|
||||
tcp_nopush {{ nginx_tcp_nopush | ternary('on', 'off') }};
|
||||
tcp_nodelay {{ nginx_tcp_nodelay | ternary('on', 'off') }};
|
||||
keepalive_timeout {{ nginx_keepalive_timeout }};
|
||||
keepalive_requests {{ nginx_keepalive_requests }};
|
||||
types_hash_max_size 2048;
|
||||
server_tokens {{ nginx_server_tokens | ternary('on', 'off') }};
|
||||
|
||||
# Client Settings
|
||||
client_max_body_size {{ nginx_client_max_body_size }};
|
||||
client_body_timeout {{ nginx_client_body_timeout }};
|
||||
client_header_timeout {{ nginx_client_header_timeout }};
|
||||
send_timeout {{ nginx_send_timeout }};
|
||||
|
||||
# MIME Types
|
||||
include /etc/nginx/mime.types;
|
||||
default_type application/octet-stream;
|
||||
|
||||
# Logging Format
|
||||
log_format main {{ nginx_access_log_format | quote }};
|
||||
|
||||
# Default Logging
|
||||
access_log /var/log/nginx/access.log main;
|
||||
error_log /var/log/nginx/error.log {{ nginx_error_log_level }};
|
||||
|
||||
# Include additional configuration files
|
||||
include /etc/nginx/conf.d/*.conf;
|
||||
include /etc/nginx/sites-enabled/*;
|
||||
}
|
||||
@@ -0,0 +1,49 @@
|
||||
# Security Headers Configuration
|
||||
# Custom PHP Framework - {{ environment | upper }}
|
||||
|
||||
# Security Headers
|
||||
{% for header, value in security_headers.items() %}
|
||||
add_header {{ header }} "{{ value }}" always;
|
||||
{% endfor %}
|
||||
|
||||
# HSTS (HTTP Strict Transport Security)
|
||||
{% if hsts_enabled %}
|
||||
add_header Strict-Transport-Security "max-age={{ hsts_max_age }}{% if hsts_include_subdomains %}; includeSubDomains{% endif %}{% if hsts_preload %}; preload{% endif %}" always;
|
||||
{% endif %}
|
||||
|
||||
# Additional Security Measures
|
||||
add_header X-Robots-Tag "noindex, nofollow, nosnippet, noarchive" always;
|
||||
|
||||
# Server Information Hiding
|
||||
more_clear_headers 'Server';
|
||||
more_set_headers 'Server: Custom-Framework/{{ environment }}';
|
||||
|
||||
# Prevent clickjacking for admin areas
|
||||
location /admin {
|
||||
add_header X-Frame-Options "DENY" always;
|
||||
}
|
||||
|
||||
# Additional security for API endpoints
|
||||
location /api {
|
||||
# Rate limiting is handled in separate config
|
||||
add_header X-Content-Type-Options "nosniff" always;
|
||||
add_header X-XSS-Protection "1; mode=block" always;
|
||||
}
|
||||
|
||||
# Disable access to sensitive files
|
||||
location ~* \.(env|git|gitignore|gitattributes|htaccess|htpasswd|ini|log|sh|sql|conf)$ {
|
||||
deny all;
|
||||
return 404;
|
||||
}
|
||||
|
||||
# Prevent access to hidden files and directories
|
||||
location ~ /\. {
|
||||
deny all;
|
||||
return 404;
|
||||
}
|
||||
|
||||
# Block access to backup and temporary files
|
||||
location ~* \.(bak|backup|swp|tmp|temp|~)$ {
|
||||
deny all;
|
||||
return 404;
|
||||
}
|
||||
@@ -0,0 +1,27 @@
|
||||
# SSL Configuration for Custom PHP Framework
|
||||
# Environment: {{ environment | upper }}
|
||||
|
||||
# SSL Protocols and Ciphers
|
||||
ssl_protocols {{ ssl_protocols | join(' ') }};
|
||||
ssl_ciphers {{ ssl_ciphers }};
|
||||
ssl_prefer_server_ciphers {{ ssl_prefer_server_ciphers | ternary('on', 'off') }};
|
||||
|
||||
# SSL Session Caching
|
||||
ssl_session_cache {{ ssl_session_cache }};
|
||||
ssl_session_timeout {{ ssl_session_timeout }};
|
||||
ssl_session_tickets {{ ssl_session_tickets | ternary('on', 'off') }};
|
||||
|
||||
# OCSP Stapling
|
||||
ssl_stapling {{ ssl_stapling | ternary('on', 'off') }};
|
||||
ssl_stapling_verify {{ ssl_stapling_verify | ternary('on', 'off') }};
|
||||
resolver 8.8.8.8 8.8.4.4 valid=300s;
|
||||
resolver_timeout 5s;
|
||||
|
||||
# DH Parameters
|
||||
ssl_dhparam /etc/ssl/certs/dhparam.pem;
|
||||
|
||||
# SSL Security Headers
|
||||
add_header Strict-Transport-Security "max-age={{ hsts_max_age }}; includeSubDomains; preload" always;
|
||||
|
||||
# SSL Buffer Size (performance optimization)
|
||||
ssl_buffer_size 4k;
|
||||
Reference in New Issue
Block a user