Skip to content

Card calculator and Proxmark3 Plugin for writing and/or simulating every card type that Doppelgänger Community, Pro, Stealth, and MFAS support.

Notifications You must be signed in to change notification settings

tweathers-sec/doppelganger_assistant

Repository files navigation

Doppelgänger Assistant

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.

Doppelgänger Devices

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).

Officially Supported Card Types

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

Installation

Manual Installation

  1. Grab your desired package from the release page.
  2. Ensure that you have the Iceman fork of the Proxmark3 software installed.
  3. Install dependencies, if required (WSL).

Automated Installation

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.

Installation MacOS

Automated MacOS Installation (RECOMMENDED)

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)"

Manual MacOS Installation

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

Manual MacOS Installation

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

Installation Linux

Automated Linux Installation (RECOMMEND)

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

Manual Linux Installation

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

Installation Windows (WSL)

Automated Installation of Doppelganger Assistant (RECOMMENDED)

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:

  1. wsl_enable.ps1
  2. Reboot the system
  3. doppelganger_install_windows.ps1

Manual Installation

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}

Example Usage

Doppelgänger Assistant GUI

Don't want to bumble through the commandline? Run the GUI version by double-clicking the launcher or through the commandline:

doppelganger_assistant -g

Doppelgänger Assistant GUI

Below is a quick video demo of the usage:

Doppelgänger Assistant Demo

Commandline Usage Examples

Generating commands for writing iCLASS cards

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 

Generating commands, writing card data, and verification of data

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.

Simulating PIV/MF Cards

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

About

Card calculator and Proxmark3 Plugin for writing and/or simulating every card type that Doppelgänger Community, Pro, Stealth, and MFAS support.

Topics

Resources

Stars

Watchers

Forks