No Description

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

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