Card calculator and Proxmark3 Plugin for writing and/or simulating every card type that Doppelgänger Pro, Stealth, and MFAS support. This project is designed to streamline the card-writing process because every second counts in physical penetration testing. Why waste time digging through your disheveled notes to relearn how to write an iCLASS 2k card or fumble with the syntax for a 37-bit HID card? If you use doppelganger, let doppelgagner_assistant do the work for you. That way, you can spend more time creating a viable replica access control card.
You can purchase Doppelgänger Pro, Stealth, and MFAS from the Physical Exploitation Store. Alternatively, you can build the community edition (less card reading support).
Below are the officially supported card types based on Doppelgänger version:
Card Types | Community Edition | Pro | Stealth | MFAS | Notes |
---|---|---|---|---|---|
Keypad PIN Codes | X | ||||
HID H10301 26-bit | X | X | X | X | |
Indala 26-bit | X | X | X | X | Requires Indala reader/module |
Indala 27-bit | X | X | X | X | Requires Indala reader/module |
2804 WIEGAND 28-bit | X | X | X | ||
Indala 29-bit | X | X | X | X | Requires Indala reader/module |
ATS Wiegand 30-bit | X | X | X | ||
HID ADT 31-Bit | X | X | X | ||
EM4102 / Wiegand 32-bit | X | X | |||
HID D10202 33-bit | X | X | X | X | |
HID H10306 34-bit | X | X | X | X | |
HID Corporate 1000 35-bit | X | X | X | X | |
HID Simplex 36-bit (S12906) | X | X | X | ||
HID H10304 37-bit | X | X | X | X | |
HID Corporate 1000 48-bit | X | X | X | ||
C910 PIVKey | X | X | |||
MIFARE (Various Types) | X | X | UID Only |
Supported technologies include:
- iCLASS(Legacy/SE/Seos) Note: Captured SE and Seos cards can only be written to iCLASS 2k cards
- PROX
- Indala
- AWID
- EM4102
- PIV
- MIFARE
- Grab your desired package from the release page.
- Ensure that you have the Iceman fork of the Proxmark3 software installed.
- Install dependencies, if required (WSL).
Alternatively, you can use one of the one-liners below to install on Linux and Windows (WSL). These one-liners will install Doppelganger Assistant, any required dependencies, and the latest fork of the (Iceman) Proxmark3 software.
Run the following command in the terminal:
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/tweathers-sec/doppelganger_assistant/main/doppelganger_install_macos.sh)"
Run the following command inside your preferred terminal application:
curl -sSL https://raw.githubusercontent.com/tweathers-sec/doppelganger_assistant/main/doppelganger_install_macos.sh | sudo bash
Download the application (.app) from the release page and place it in the /Applications
directory. You can create a symbolic link to run the application from the terminal or you create an alias in your shell profile.
Only choose one of the following options...
# Symbolic Link
sudo ln -s /Applications/doppelganger_assistant.app/Contents/MacOS/doppelganger_assistant /usr/local/bin/doppelganger_assistant
# Profile Alias
alias doppelganger_assistant='/Applications/doppelganger_assistant.app/Contents/MacOS/doppelganger_assistant'
If you encounter an error stating that the "doppelganger_assistant.app" is damaged and can't be opened. You should move it to the Trash. Run the following command in the directory where the doppelganger assistant resides.
xattr -cr /Applications/doppelganger_assistant.app
Run the following command inside your preferred terminal application:
curl -sSL https://raw.githubusercontent.com/tweathers-sec/doppelganger_assistant/main/doppelganger_install_linux.sh | sudo bash
Install Doppelganger Assistant Dependencies. Note that this step should only be required if you encounter errors that prevent the deployment of doppelganger_assistant.
sudo apt update
sudo apt upgrade
sudo apt install libgl1 xterm git
Grab the Doppelganger Assistant and install it:
sudo apt install make
wget https://github.com/tweathers-sec/doppelganger_assistant/releases/tag/latest/doppelganger_assistant_linux_{amd64/arm64}.tar.xz
tar xvf doppelganger_assistant_*
sudo make install
# Cleanup the directory, if desired
rm -rf usr/
rm doppelganger_assistant*
rm Makefile
To launch the Doppelganger Assistant GUI:
doppelganger_assistant
This process will install WSL, Doppelganger Assistant, Proxmark3 software, and create a desktop shortcut.
Open PowerShell as Administrator and run the following command.
powershell -ExecutionPolicy Bypass -Command "Invoke-WebRequest -Uri 'https://raw.githubusercontent.com/tweathers-sec/doppelganger_assistant/refs/heads/main/doppelganger_install_windows.ps1' -OutFile 'C:\doppelganger_assistant_install.ps1'; & 'C:\doppelganger_assistant_install.ps1'"
Alternatively, you can download the files and run them in this order:
- wsl_enable.ps1
- Reboot the system
- doppelganger_install_windows.ps1
If needed, create an Ubuntu WSL environment. From cmd.exe run:
wsl --install -d Ubuntu
Reboot Windows. When Windows starts up, WSL will finish setting up. When prompted, enter the Username and Password for your Ubuntu system.
Install Doppelganger Assistant Dependencies:
sudo apt update
sudo apt upgrade
sudo apt install libgl1 xterm make git
Grab the Doppelganger Assistant and install it:
wget https://github.com/tweathers-sec/doppelganger_assistant/releases/tag/latest/doppelganger_assistant_linux_{amd64/arm64}.tar.xz
tar xvf doppelganger_assistant_*
sudo make install
# Cleanup the directory, if desired
rm -rf usr/
rm doppelganger_assistant*
rm Makefile
To launch the Doppelganger Assistant GUI:
doppelganger_assistant
Install Proxmark3 Dependencies:
sudo apt install --no-install-recommends git ca-certificates build-essential pkg-config \
libreadline-dev gcc-arm-none-eabi libnewlib-dev qtbase5-dev \
libbz2-dev liblz4-dev libbluetooth-dev libpython3-dev libssl-dev libgd-dev
Clone the Proxmark3 Repo:
git clone https://github.com/RfidResearchGroup/proxmark3.git
cd proxmark3
If desired, modify the Makefile to support the Blueshark Device
cp Makefile.platform.sample Makefile.platform
#uncomment #PLATFORM_EXTRAS=BTADDON
nano Makefile.platform
Compile and Install Proxmark3 software
make clean && make -j
make install
Install USBipd to passthrough the Proxmark3 device to WSL. From cmd.exe run:
winget install --interactive --exact dorssel.usbipd-win
To Connect the Proxmark3 device to WSL. Open cmd.exe as an Administrator and run:
usbipd list // This will list the usb devices attach to your computer
usbipd bind --busid 9-1 // {9-1 Should be your Proxmark3's ID}
usbipd attach --wsl --busid 9-1 // {9-1 Should be your Proxmark3's ID}
Don't want to bumble through the commandline? Run the GUI version by double-clicking the launcher or through the commandline:
doppelganger_assistant -g
Below is a quick video demo of the usage:
This command will generate the commands needed to write captured iCLASS (Legacy/SE/Seos) card data to an iCLASS 2k card:
doppelganger_assistant -t iclass -bl 26 -fc 123 -cn 4567
Write the following values to an iCLASS 2k card:
hf iclass wrbl --blk 6 -d 030303030003E014 --ki 0
hf iclass wrbl --blk 7 -d 0000000006f623ae --ki 0
hf iclass wrbl --blk 8 -d 0000000000000000 --ki 0
hf iclass wrbl --blk 9 -d 0000000000000000 --ki 0
By adding the —w (write) and —v (verify) flags, the application will use your PM3 installation to write and verify the card data.
doppelganger_assistant -t iclass -bl 26 -fc 123 -cn 4567 -w -v
The following will be written to an iCLASS 2k card:
hf iclass wrbl --blk 6 -d 030303030003E014 --ki 0
hf iclass wrbl --blk 7 -d 0000000006f623ae --ki 0
hf iclass wrbl --blk 8 -d 0000000000000000 --ki 0
hf iclass wrbl --blk 9 -d 0000000000000000 --ki 0
Connect your Proxmark3 and place an iCLASS 2k card flat on the antenna. Press Enter to continue...
Writing block #6...
[=] Session log /Users/tweathers/.proxmark3/logs/log_20240614013815.txt
[+] loaded `/Users/tweathers/.proxmark3/preferences.json`
[+] execute command from commandline: hf iclass wrbl --blk 6 -d 030303030003E014 --ki 0
[+] Using UART port /dev/tty.usbmodem101
[+] Communicating with PM3 over USB-CDC
[usb|script] pm3 --> hf iclass wrbl --blk 6 -d 030303030003E014 --ki 0
[+] Using key[0] AE A6 84 A6 DA B2 32 78
[+] Wrote block 6 / 0x06 ( ok )
Writing block #7...
[=] Session log /Users/tweathers/.proxmark3/logs/log_20240614013818.txt
[+] loaded `/Users/tweathers/.proxmark3/preferences.json`
[+] execute command from commandline: hf iclass wrbl --blk 7 -d 0000000006f623ae --ki 0
[+] Using UART port /dev/tty.usbmodem101
[+] Communicating with PM3 over USB-CDC
[usb|script] pm3 --> hf iclass wrbl --blk 7 -d 0000000006f623ae --ki 0
[+] Using key[0] AE A6 84 A6 DA B2 32 78
[+] Wrote block 7 / 0x07 ( ok )
Writing block #8...
[=] Session log /Users/tweathers/.proxmark3/logs/log_20240614013820.txt
[+] loaded `/Users/tweathers/.proxmark3/preferences.json`
[+] execute command from commandline: hf iclass wrbl --blk 8 -d 0000000000000000 --ki 0
[+] Using UART port /dev/tty.usbmodem101
[+] Communicating with PM3 over USB-CDC
[usb|script] pm3 --> hf iclass wrbl --blk 8 -d 0000000000000000 --ki 0
[+] Using key[0] AE A6 84 A6 DA B2 32 78
[+] Wrote block 8 / 0x08 ( ok )
Writing block #9...
[=] Session log /Users/tweathers/.proxmark3/logs/log_20240614013821.txt
[+] loaded `/Users/tweathers/.proxmark3/preferences.json`
[+] execute command from commandline: hf iclass wrbl --blk 9 -d 0000000000000000 --ki 0
[+] Using UART port /dev/tty.usbmodem101
[+] Communicating with PM3 over USB-CDC
[usb|script] pm3 --> hf iclass wrbl --blk 9 -d 0000000000000000 --ki 0
[+] Using key[0] AE A6 84 A6 DA B2 32 78
[+] Wrote block 9 / 0x09 ( ok )
Verifying that the card data was successfully written. Set your card flat on the reader...
[=] Session log /Users/tweathers/.proxmark3/logs/log_20240614013825.txt
[+] loaded `/Users/tweathers/.proxmark3/preferences.json`
[+] execute command from commandline: hf iclass dump --ki 0
[+] Using UART port /dev/tty.usbmodem101
[+] Communicating with PM3 over USB-CDC
[usb|script] pm3 --> hf iclass dump --ki 0
[+] Using AA1 (debit) key[0] AE A6 84 A6 DA B2 32 78
[=] Card has at least 2 application areas. AA1 limit 18 (0x12) AA2 limit 31 (0x1F)
.
[=] --------------------------- Tag memory ----------------------------
[=] block# | data | ascii |lck| info
[=] ---------+-------------------------+----------+---+----------------
[=] 0/0x00 | 28 66 8B 15 FE FF 12 E0 | (f... | | CSN
[=] 1/0x01 | 12 FF FF FF 7F 1F FF 3C | ...< | | Config
[=] 2/0x02 | FF FF FF FF D9 FF FF FF | | | E-purse
[=] 3/0x03 | 84 3F 76 67 55 B8 DB CE | .?vgU | | Debit
[=] 4/0x04 | FF FF FF FF FF FF FF FF | | | Credit
[=] 5/0x05 | FF FF FF FF FF FF FF FF | | | AIA
[=] 6/0x06 | 03 03 03 03 00 03 E0 14 | ....... | | User / HID CFG
[=] 7/0x07 | 00 00 00 00 06 F6 23 AE | .....# | | User / Cred
[=] 8/0x08 | 00 00 00 00 00 00 00 00 | ........ | | User / Cred
[=] 9/0x09 | 00 00 00 00 00 00 00 00 | ........ | | User / Cred
[=] 10/0x0A | FF FF FF FF FF FF FF FF | | | User
[=] 11/0x0B | FF FF FF FF FF FF FF FF | | | User
[=] 12/0x0C | FF FF FF FF FF FF FF FF | | | User
[=] 13/0x0D | FF FF FF FF FF FF FF FF | | | User
[=] 14/0x0E | FF FF FF FF FF FF FF FF | | | User
[=] 15/0x0F | FF FF FF FF FF FF FF FF | | | User
[=] 16/0x10 | FF FF FF FF FF FF FF FF | | | User
[=] 17/0x11 | FF FF FF FF FF FF FF FF | | | User
[=] 18/0x12 | FF FF FF FF FF FF FF FF | | | User
[=] ---------+-------------------------+----------+---+----------------
[?] yellow = legacy credential
[+] saving dump file - 19 blocks read
[+] Saved 152 bytes to binary file `/Users/tweathers/hf-iclass-28668B15FEFF12E0-dump-008.bin`
[+] Saved to json file `/Users/tweathers/hf-iclass-28668B15FEFF12E0-dump-008.json`
[?] Try `hf iclass decrypt -f` to decrypt dump file
[?] Try `hf iclass view -f` to view dump file
[=] Session log /Users/tweathers/.proxmark3/logs/log_20240614013827.txt
[+] loaded `/Users/tweathers/.proxmark3/preferences.json`
[+] execute command from commandline: hf iclass view -f /Users/tweathers/hf-iclass-28668B15FEFF12E0-dump-008.json
[+] Using UART port /dev/tty.usbmodem101
[+] Communicating with PM3 over USB-CDC
[usb|script] pm3 --> hf iclass view -f /Users/tweathers/hf-iclass-28668B15FEFF12E0-dump-008.json
[+] loaded `/Users/tweathers/hf-iclass-28668B15FEFF12E0-dump-008.json`
[=] --------------------------- Card ---------------------------
[+] CSN... 28 66 8B 15 FE FF 12 E0 uid
[+] Config... 12 FF FF FF 7F 1F FF 3C card configuration
[+] E-purse... FF FF FF FF D9 FF FF FF card challenge, CC
[+] Kd... 84 3F 76 67 55 B8 DB CE debit key
[+] Kc... FF FF FF FF FF FF FF FF credit key ( hidden )
[+] AIA... FF FF FF FF FF FF FF FF application issuer area
[=] -------------------- Card configuration --------------------
[=] Raw... 12 FF FF FF 7F 1F FF 3C
[=] 12 ( 18 )............. app limit
[=] FFFF ( 65535 )...... OTP
[=] FF............ block write lock
[=] 7F......... chip
[=] 1F...... mem
[=] FF... EAS
[=] 3C fuses
[=] Fuses:
[+] mode......... Application (locked)
[+] coding....... ISO 14443-2 B / 15693
[+] crypt........ Secured page, keys not locked
[=] RA........... Read access not enabled
[=] PROD0/1...... Default production fuses
[=] -------------------------- Memory --------------------------
[=] 2 KBits/2 App Areas ( 256 bytes )
[=] 1 books / 1 pages
[=] First book / first page configuration
[=] Config | 0 - 5 ( 0x00 - 0x05 ) - 6 blocks
[=] AA1 | 6 - 18 ( 0x06 - 0x12 ) - 13 blocks
[=] AA2 | 19 - 31 ( 0x13 - 0x1F ) - 18 blocks
[=] ------------------------- KeyAccess ------------------------
[=] * Kd, Debit key, AA1 Kc, Credit key, AA2 *
[=] Read AA1..... debit
[=] Write AA1.... debit
[=] Read AA2..... credit
[=] Write AA2.... credit
[=] Debit........ debit or credit
[=] Credit....... credit
[=] --------------------------- Tag memory ----------------------------
[=] block# | data | ascii |lck| info
[=] ---------+-------------------------+----------+---+----------------
[=] 0/0x00 | 28 66 8B 15 FE FF 12 E0 | (f... | | CSN
[=] ......
[=] 6/0x06 | 03 03 03 03 00 03 E0 14 | ....... | | User / HID CFG
[=] 7/0x07 | 00 00 00 00 06 F6 23 AE | .....# | | User / Cred
[=] 8/0x08 | 00 00 00 00 00 00 00 00 | ........ | | User / Cred
[=] 9/0x09 | 00 00 00 00 00 00 00 00 | ........ | | User / Cred
[=] 10/0x0A | FF FF FF FF FF FF FF FF | | | User
[=] 11/0x0B | FF FF FF FF FF FF FF FF | | | User
[=] 12/0x0C | FF FF FF FF FF FF FF FF | | | User
[=] 13/0x0D | FF FF FF FF FF FF FF FF | | | User
[=] 14/0x0E | FF FF FF FF FF FF FF FF | | | User
[=] 15/0x0F | FF FF FF FF FF FF FF FF | | | User
[=] 16/0x10 | FF FF FF FF FF FF FF FF | | | User
[=] 17/0x11 | FF FF FF FF FF FF FF FF | | | User
[=] 18/0x12 | FF FF FF FF FF FF FF FF | | | User
[=] ---------+-------------------------+----------+---+----------------
[?] yellow = legacy credential
[=] Block 7 decoder
[+] Binary..................... 110111101100010001110101110
[=] Wiegand decode
[+] [H10301 ] HID H10301 26-bit FC: 123 CN: 4567 parity ( ok )
[+] [ind26 ] Indala 26-bit FC: 1969 CN: 471 parity ( ok )
[=] found 2 matching formats
Verification successful: Facility Code and Card Number match.
Using the UID provided by Doppelgänger (v1.2.0 Doppelgänger Pro, Stealth, and MFAS), you can simulate the exact wiegand signal with a Proxmark3.
doppelganger_assistant -uid 5AF70D9D -s -t piv
Handling PIV card...
Simulating the PIV card on your Proxmark3:
Executing command: hf 14a sim -t 3 --uid 5AF70D9D
[=] Session log /Users/tweathers/.proxmark3/logs/log_20240614152754.txt
[+] loaded `/Users/tweathers/.proxmark3/preferences.json`
[+] execute command from commandline: hf 14a sim -t 3 --uid 5AF70D9D
[+] Using UART port /dev/tty.usbmodem2134301