-
Notifications
You must be signed in to change notification settings - Fork 168
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Security Vulnerability Report: Arbitrary Code Execution via Deserialization in dlrover's GRPC Service #1400
Comments
Thanks for your suggestion. Can we mitigate this risk if we replace GRPC and pickle with HTTP and JSON? IMO, JSON is more safe than pickle. |
Replacing GRPC and pickle with HTTP and JSON can reduce the risk associated with pickle deserialization vulnerabilities. JSON is indeed generally safer as it doesn't have the same built-in ability to execute arbitrary code like pickle. However, it's not a silver bullet.Proper input validation and sanitization still need to be implemented carefully to prevent other types of attacks. Also, the overall security architecture, including access controls and authentication, needs to be reevaluated and strengthened. If the security of the master cannot be guaranteed, companies using dlrover may encounter the "insider" problem that Bytedance had before. |
@12end thanks for investigating this issue, let our team to check this again. |
The deserialization code is used from here on e92fc20#diff-55f4adaa04015061f621cf129479695bfb877e1dad2d16c5caacb8c14959e7fc |
In fact, regardless of whether gRPC or HTTP is used, the current internal communication implementation of DLROver is very vulnerable from a security perspective. There are significant risks if it is used in non-intranet environments. If there are security requirements for internal production, they will certainly be given high priority. However, the plan for implementing security on the open-source side is still uncertain at this point. We can take this back for further discussion. |
Summary
A critical security vulnerability has been identified in the dlrover project, specifically within the Python module python/common/grpc.py. The function deserialize_message is susceptible to a deserialization flaw when handling gRPC messages. This issue can be exploited by an attacker with access to the dlrover-master gRPC service running on port 50001, potentially allowing for arbitrary code execution and unauthorized system access.
Affected Components
dlrover version(s) affected: All versions up until the date of this report.
Component: python/common/grpc.py
Function: deserialize_message
Impact
The dlrover-master exposes a gRPC endpoint on port 50001 for worker nodes to connect. When this service is deployed in a Kubernetes cluster, the port is exposed as a service, making it accessible by any container within the cluster under default configurations. An attacker could exploit this vulnerability by sending a maliciously crafted pickle data through the Message's data field, leading to remote code execution upon deserialization.
Technical Details
The Message protocol buffer message includes a bytes field named data, which is intended to carry serialized Python objects using the pickle format. However, pickle is known to be unsafe for deserializing untrusted data as it can execute arbitrary code during the deserialization process.
Proof of Concept (PoC)
Below is a simplified PoC demonstrating how an attacker might exploit this vulnerability:
elastic_training.proto
exp.py
gen_pickle.py
command:
By executing the above scripts, an attacker can create a payload that, when deserialized by the dlrover-master, will execute the command touch /tmp/pwned, creating a file at /tmp/pwned on the master.
data:image/s3,"s3://crabby-images/42637/4263729a984e1d2b69a8e72c1fc3c7a100045fb8" alt=""
Recommendations
To mitigate this risk, it is recommended that:
Implementation of RestrictedUnpickler
By implementing a custom unpickler that overrides the find_class method, you can enforce a whitelist of classes that are allowed to be instantiated during the deserialization process. This approach ensures that only trusted classes can be created, thereby reducing the attack surface.
authentication
The dlrover-master gRPC service should implement authentication and authorization mechanisms to restrict access only to trusted entities.
Best regards,
12end@cyberkl
The text was updated successfully, but these errors were encountered: