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>
51 lines
1.4 KiB
YAML
51 lines
1.4 KiB
YAML
- name: Certbot + Plugin installieren
|
|
apt:
|
|
name:
|
|
- certbot
|
|
- python3-certbot-nginx
|
|
state: present
|
|
update_cache: yes
|
|
when: letsencrypt_enabled
|
|
|
|
- name: Challenge-Verzeichnis für Let's Encrypt anlegen
|
|
file:
|
|
path: "{{ app_public }}/.well-known/acme-challenge"
|
|
state: directory
|
|
owner: www-data
|
|
group: www-data
|
|
mode: '0755'
|
|
recurse: yes
|
|
when: letsencrypt_enabled and letsencrypt_certbot_method == 'webroot'
|
|
|
|
- name: Stoppe Nginx für Standalone-Methode
|
|
service:
|
|
name: nginx
|
|
state: stopped
|
|
when: letsencrypt_enabled and letsencrypt_certbot_method == 'standalone'
|
|
|
|
- name: Let's Encrypt Zertifikat anfordern (Standalone)
|
|
command: >
|
|
certbot certonly --standalone -n --agree-tos
|
|
-m {{ app_email }}
|
|
-d {{ app_domain }}
|
|
args:
|
|
creates: /etc/letsencrypt/live/{{ app_domain }}/fullchain.pem
|
|
when: letsencrypt_enabled and letsencrypt_certbot_method == 'standalone'
|
|
|
|
- name: Let's Encrypt Zertifikat anfordern (Webroot)
|
|
command: >
|
|
certbot certonly --webroot -w {{ app_public }} -n --agree-tos
|
|
-m {{ app_email }}
|
|
-d {{ app_domain }}
|
|
args:
|
|
creates: /etc/letsencrypt/live/{{ app_domain }}/fullchain.pem
|
|
when: letsencrypt_enabled and letsencrypt_certbot_method == 'webroot'
|
|
|
|
- name: Kopiere SSL-Zertifikate für Docker
|
|
copy:
|
|
src: "/etc/letsencrypt/live/{{ app_domain }}/"
|
|
dest: "{{ app_root }}/ssl/"
|
|
remote_src: yes
|
|
mode: '0644'
|
|
when: letsencrypt_enabled
|