Skip to main content

Mobile Verification Toolkit

Project description

Mobile Verification Toolkit

[!IMPORTANT] We recently merged the "v3" branch. This introduced breaking changes. If you relied on mvt output in other scripts They might have broken. More details: https://github.com/mvt-project/mvt/issues/757

Documentation Status CI Downloads

Mobile Verification Toolkit (MVT) is a collection of utilities to simplify and automate the process of gathering forensic traces helpful to identify a potential compromise of Android and iOS devices.

It has been developed and released by the Amnesty International Security Lab in July 2021 in the context of the Pegasus Project along with a technical forensic methodology. It continues to be maintained by Amnesty International and other contributors.

Note MVT is a forensic research tool intended for technologists and investigators. It requires understanding digital forensics and using command-line tools. This is not intended for end-user self-assessment. If you are concerned with the security of your device please seek reputable expert assistance.

Indicators of Compromise

MVT supports using public indicators of compromise (IOCs) to scan mobile devices for potential traces of targeting or infection by known spyware campaigns. This includes IOCs published by Amnesty International and other research groups.

Warning Public indicators of compromise are insufficient to determine that a device is "clean", and not targeted with a particular spyware tool. Reliance on public indicators alone can miss recent forensic traces and give a false sense of security.

Reliable and comprehensive digital forensic support and triage requires access to non-public indicators, research and threat intelligence.

Such support is available to civil society through Amnesty International's Security Lab or through our forensic partnership with Access Now’s Digital Security Helpline.

More information about using indicators of compromise with MVT is available in the documentation.

Installation

MVT can be installed from sources or from PyPI (you will need some dependencies, check the documentation):

pip3 install mvt

You can also install MVT from PyPI with uv. First, install uv:

curl -LsSf https://astral.sh/uv/install.sh | sh

Then install MVT as a command-line tool:

uv tool install mvt

For alternative installation options and known issues, please refer to the documentation as well as GitHub Issues.

Usage

MVT provides two commands mvt-ios and mvt-android. Check out the documentation to learn how to use them!

License

The purpose of MVT is to facilitate the consensual forensic analysis of devices of those who might be targets of sophisticated mobile spyware attacks, especially members of civil society and marginalized communities. We do not want MVT to enable privacy violations of non-consenting individuals. In order to achieve this, MVT is released under its own license. Read more here.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mvt-2026.5.12.tar.gz (125.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mvt-2026.5.12-py3-none-any.whl (208.0 kB view details)

Uploaded Python 3

File details

Details for the file mvt-2026.5.12.tar.gz.

File metadata

  • Download URL: mvt-2026.5.12.tar.gz
  • Upload date:
  • Size: 125.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mvt-2026.5.12.tar.gz
Algorithm Hash digest
SHA256 f7ab15a890f0acaac1a6d9cac34192fd59358d342ca865d9b204c878360440a5
MD5 6c34c99d6829ece4da25b80bf621d7ac
BLAKE2b-256 b26034490817503381fa6e9effe0215224c74fb19770e90d05cb4bc4725cf2fa

See more details on using hashes here.

Provenance

The following attestation bundles were made for mvt-2026.5.12.tar.gz:

Publisher: mvt.yml on mvt-project/release-workflows

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mvt-2026.5.12-py3-none-any.whl.

File metadata

  • Download URL: mvt-2026.5.12-py3-none-any.whl
  • Upload date:
  • Size: 208.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mvt-2026.5.12-py3-none-any.whl
Algorithm Hash digest
SHA256 fb1180bd6c82c5332b02e13b8a1066c190c25144a09592f167d27f11c78fc657
MD5 ac75bd80a6c66b51d6201297cabc0fc7
BLAKE2b-256 33879556ade4934299ae5af6962d6e7124847cc469738d108bf334121ca08879

See more details on using hashes here.

Provenance

The following attestation bundles were made for mvt-2026.5.12-py3-none-any.whl:

Publisher: mvt.yml on mvt-project/release-workflows

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page