mirror of
https://github.com/mukul975/Anthropic-Cybersecurity-Skills.git
synced 2026-06-11 21:54:56 +03:00
27c6414ca5
Complete skill folder anatomy across all cybersecurity skills: - scripts/agent.py: 80-150 line Python agents using real libraries (impacket, boto3, azure-mgmt-*, kubernetes, pefile, yara, scapy, shodan, stix2, etc.) - references/api-reference.md: real API documentation with method signatures - LICENSE: MIT license for all skill folders
2.0 KiB
2.0 KiB
API Reference: Insecure Deserialization Detection Agent
Dependencies
| Library | Version | Purpose |
|---|---|---|
| requests | >=2.28 | HTTP requests for scanning cookies and responses |
| pickle | stdlib | Python pickle payload generation for testing |
CLI Usage
python scripts/agent.py --url https://target.example.com/dashboard \
--callback oob.attacker.com --output deser_report.json
Functions
detect_serialization_format(data) -> str
Identifies serialization format from a string: java_serialized, dotnet_viewstate, php_serialized, python_pickle.
scan_cookies(url, session) -> list
Fetches the URL and checks each response cookie value for serialization markers.
scan_response_body(url, method, data) -> list
Scans the HTTP response body for Java Base64 (rO0AB), PHP serialized objects, and __VIEWSTATE fields.
test_java_deserialization(url, cookie_name, callback_host) -> dict
Injects a URLDNS-style probe into a cookie to trigger DNS callback on deserialization.
test_php_deserialization(url, param_name) -> dict
Sends PHP serialized object payloads attempting role escalation.
test_python_pickle(url, param_name, callback_host) -> dict
Generates a pickle payload with __reduce__ that triggers a DNS lookup for OOB detection.
run_assessment(url, callback_host) -> dict
Orchestrates cookie and body scanning.
Serialization Markers
| Format | Magic / Prefix | Example |
|---|---|---|
| Java binary | \xac\xed\x00\x05 |
Raw bytes |
| Java Base64 | rO0AB |
Base64-encoded |
| .NET ViewState | /wE |
__VIEWSTATE hidden field |
| PHP | O:4:, a:2: |
Object/array notation |
| Python pickle | \x80 (protocol byte) |
Base64-encoded |
Output Schema
{
"target": "https://target.example.com/",
"serialized_data_found": 2,
"cookie_findings": [{"name": "session", "format": "java_serialized"}],
"formats_detected": ["java_serialized"]
}