Development tools and frameworks usually have options to make debugging easier for developers, but these features should never be enabled for applications deployed in production.
Debug instructions or error messages can leak detailed information about the system, such as the application’s path, file names, or stack traces. The rule flags configurations and API calls that enable debug features, including stack trace printing, verbose logging, debug mode flags, and remote debugging endpoints.
Attackers can exploit debug output to learn internal application details, file paths, stack traces, and configuration data that can be leveraged to craft further attacks.
Debug features may expose remote debugging endpoints, profiling APIs, or detailed error pages that significantly increase the attack surface of the application.
Debug features should be disabled or guarded by environment checks before deploying to production.
FROM example # Noncompliant ENV APP_DEBUG=true # Noncompliant ENV ENV=development CMD /run.sh
FROM example ENV APP_DEBUG=false ENV ENV=production CMD /run.sh