16 releases
new 0.2.1 | Jan 23, 2025 |
---|---|
0.2.0 | Dec 22, 2024 |
0.1.4 | Oct 31, 2024 |
0.0.9 | Jul 21, 2024 |
0.0.3 | Dec 30, 2023 |
#306 in Cryptography
308 downloads per month
Used in 3 crates
85KB
1.5K
SLoC
VirusTotal Client
This is logic for interacting with VirusTotal's V3 API. At present, only the following actions are supported:
- Fetch file report: this gets the anti-virus scan data for a given sample, and there are examples in the
testdata/
directory. - Request re-scan: ask VirusTotal to run a given sample through their collection of anti-virus applications and analysis tools.
- Submit a sample: send a sample to VirusTotal for analysis.
- Download a sample: download the original sample from VirusTotal (not fully tested, requires VirusTotal Premium).
- Search: find the hashes of files which match some search criteria (not fully tested, requires VirusTotal Premium, uses older V2 API). See VirusTotal's doc for more information.
- The file report object and error types can be useful when interacting with VirusTotal using another crate or using VT's API directly; you don't have to use the client object in this crate to use the data (and error) types in this crate.
VirusTotal supports these actions given a MD5, SHA-1, or SHA-256 hash.
Additionally, this provides a client application (in bin/
, or malwaredb-virustotal-bin) for the supported operations on the command line.
MUSL Targets
It's recommended to use the native-tls-vendored
feature to avoid OpenSSL build errors when compiling for Linux MUSL targets. See the example Cargo.toml
entry below:
[target.'cfg(target_env = "musl")'.dependencies]
malwaredb-virustotal = { version = "0.2", features = ["native-tls-vendored"] }
Dependencies
~8–22MB
~329K SLoC