Sin descripción

Eric Betts 4ece979e10 PULL_REQUEST_TEMPLATE hace 8 meses
.catalog f06097e57d sync readme hace 8 meses
.github 4ece979e10 PULL_REQUEST_TEMPLATE hace 8 meses
images 0939786adf Save epassport logos hace 9 meses
lib 7238894af2 Add com reading and asn1 parsing hace 10 meses
reference 37b252d2a2 reference material hace 10 meses
scenes a193ddf9a2 uppercase all letters in passport number hace 8 meses
.clang-format 9fe02b0a3e Clear history hace 10 meses
.gitignore 9fe02b0a3e Clear history hace 10 meses
CODE_OF_CONDUCT.md 16e0bfa0f8 CODE_OF_CONDUCT hace 8 meses
CONTRIBUTING.md 2472d5f5f4 Create CONTRIBUTING.md hace 8 meses
LICENSE b8c7803b36 Create LICENSE hace 9 meses
README.md 5c14da87b3 copilot readme hace 8 meses
SECURITY.md 8c3b9715df Create SECURITY.md hace 8 meses
application.fam 7581bc2191 more changelog items hace 9 meses
bsearch.c 88e7f838eb trying to use asn1c to decode DG1 hace 10 meses
eMRTD.asn1 7238894af2 Add com reading and asn1 parsing hace 10 meses
memmem.c 89e36f2e4e Look for jpeg header in first 100 bytes of DG2 hace 10 meses
passy.c 194c9778d1 For all other DG, grab the header and show that hace 10 meses
passy.h 9ea747ecc9 restructure UI hace 10 meses
passy.png 36d65b1f64 new icon hace 9 meses
passy_common.c 6c42d1b981 Fix for document numbers containing Q-Z hace 9 meses
passy_common.h 68c87dcbe2 Fix calculation of file length hace 10 meses
passy_i.h 80348d61d7 Restart NFC scanner is unhandled protocol is found hace 9 meses
passy_reader.c 81360b90d7 Correct fallback when dg2 image header can't be found hace 9 meses
passy_reader.h 8611f0508c Accept 4A protocol hace 9 meses
secure_messaging.c 7c05345f96 DRY up key diversification hace 10 meses
secure_messaging.h 633e3da57d handle dynamic passport number length hace 10 meses

README.md

Passy: Flipper Zero Passport Reader

Passy is a tool for reading electronic passports (ePassports/eMRTDs) using the Flipper Zero device. It extracts and decodes data securely stored in modern passports, designed for hobbyists, researchers, and security professionals.


Features

  • Reads and decodes ePassport data from a wide range of countries
  • Utilizes MRZ (Machine Readable Zone) information for secure access
  • Extensible for new country support—contribute your flag!
  • Advanced menu for debugging and exploring additional data groups (DGs)

Tested with the following countries

🇺🇸 🇨🇱 🇫🇷 🇬🇧 🇵🇭 🇷🇺 🇹🇼 🇺🇦 🇦🇿 🇨🇦 🇮🇹 🇪🇸 🇪🇪 🇨🇭

If it works for yours, submit a PR to add your country flag!


Usage

eMRTDs are secured to prevent unauthorized reading. The key for accessing the data is derived from:

  • Passport number
  • Date of birth
  • Date of expiry

Use the Flipper Zero to scan your passport’s NFC chip and enter the required information.


Limitations

  • Advanced menu is hidden unless Debug mode is enabled
  • Some data groups (DGs) are not fully parsed under "advanced" menu
  • Country coverage is limited (see above)

Development

Prerequisites

  • Flipper Zero device (updated firmware recommended)
  • ufbt for building
  • asn1c ASN.1 compiler (for protocol/data parsing)

Installation

Clone this repository:

git clone https://github.com/bettse/passy.git
cd passy

Build the ASN.1 code (optional, required for development):

asn1c -D ./lib/asn1 -no-gen-example -pdu=all eMRTD.asn1

Roadmap / To Do

  • Support PACE protocol
  • Add support for more countries' passports
  • Improve parsing of additional DGs

Contributing

Contributions are welcome! If Passy works with a new country, feel free to:

  1. Add your country’s flag to the list above
  2. Submit a pull request

License

MIT License


Acknowledgments

  • Inspired by the global ePassport community
  • Powered by Flipper Zero and open-source tooling