rspec/rules/S6390/java/rule.adoc
Fred Tingaud 16f6c0aecf
Inline adoc when include has no additional value (#1940)
Inline adoc files when they are included exactly once.

Also fix language tags because this inlining gives us better information
on what language the code is written in.
2023-05-25 14:18:12 +02:00

44 lines
1.4 KiB
Plaintext

== Why is this an issue?
Most modern applications use threads to handle incoming requests or other
long-running tasks concurrently. In some cases, the number of concurrent threads
is limited to avoid system resource exhaustion due to too numerous actions
being run.
When an application uses user-controlled data as a parameter of a thread
suspension operation, a Denial of Service attack can be made possible.
=== What is the potential impact?
An attacker with the capability to insert an arbitrary duration into a thread
suspension operation could suspend the corresponding thread for a long time.
Depending on the application's architecture and the thread handling logic, this
can lead to a complete Denial of Service of the application.
Indeed, if the number of threads, either created by the application or allocated
by a web server, is limited, the attacker will be able to suspend all of them at
the same time. Without any remaining thread to handle actions, the application
might badly answer, be slowed down, or become completely irresponsive.
// How to fix it section
include::./how-to-fix-it/java-se.adoc[]
== Resources
include::../common/resources/standards.adoc[]
ifdef::env-github,rspecator-view[]
'''
== Implementation Specification
(visible only on this page)
=== Message
Change this code to prevent user-controlled data from being used as a thread suspension duration.
endif::env-github,rspecator-view[]