Skip to content

socram8888/amiitool

Folders and files

NameName
Last commit message
Last commit date

Latest commit

author
Marcos Del Sol Vives
May 23, 2017
adda029 · May 23, 2017

History

57 Commits
Mar 10, 2017
May 23, 2017
Mar 10, 2017
Mar 11, 2017
Mar 10, 2017
Mar 10, 2017
Mar 11, 2017
May 12, 2017
May 23, 2017
May 23, 2017
Mar 10, 2017
Mar 10, 2017
May 23, 2017
Mar 10, 2017
Mar 10, 2017
May 17, 2017

Repository files navigation

amiitool

amiibo™ encryption/decryption/copy tool

Usage

amiitool expects a binary dump. It will not work with XMLs or hexadecimal text files. Aside from this, amiitool is very easy to use and has a very simple syntax.

First, you have to specify an operation, either -e (encrypt and sign), -d (decrypt and check), -c (2 decrypt and check, copy appdata, encrypt)

You need also to specify a file using -k [keys] switch, indicating which file contains the cryptographic master keys. The key is the concatenation of unfixed infos and locked secret keys.

Optionally, you may also specify input and output files using -i [input] and -o [output]. If input or output are unspecified, amiitool will default to stdin and stdout, respectively. This lets you pipe amiitool inputs and outputs with standard shell tools such as xxd.

When decrypting, by default amiitool will be in strict mode, and will abort and raise an error if the cryptographic signature embedded in the encrypted dump is not valid. If you want to disable checking, use -l switch to put amiitool in lenient mode.

The copy function permit to copy saved data from one amiibo™ to another one.

Examples

  • Decryption "mario.bin" and displaying hex to terminal:

    amiitool -d -k retail.bin -i "mario.bin" | xxd

  • Encryption "modified.bin" to "signed.bin":

    amiitool -e -k retail.bin -i "modified.bin" -o "signed.bin"

  • Copy "mario2.bin" Saves (AppData) into "mario1.bin" and save to "mario3.bin"

    amiitool -c -k retail.bin -i "mario1.bin" -s "mario2.bin" -o "mario3.bin"