/Ciphey

Automatically decode encryptions without a key, decode encodings, and crack hashes

Primary LanguagePythonMIT LicenseMIT

Translations
๐Ÿ‡ฎ๐Ÿ‡ฉ ID ๐Ÿ‡ฉ๐Ÿ‡ช DE

โžก๏ธ Documentation | Discord | Installation Guide โฌ…๏ธ
Ciphey

GitHub commit activity Discord Ciphey Ciphey
Fully automated decryption tool using natural language processing & artificial intelligence, along with some common sense.


๐Ÿ Python

๐Ÿ‹ Docker (Universal)

python3 -m pip install ciphey --upgrade docker run -it --rm remnux/ciphey
Linux Mac OS Windows
GitHub Workflow Status GitHub Workflow Status GitHub Workflow Status

๐Ÿค” What is this?

Ciphey is an automated decryption tool. Input encrypted text, get the decrypted text back.

"What type of encryption?"

That's the point. You don't know, you just know it's possibly encrypted. Ciphey will figure it out for you.

Ciphey can solve most things in 3 seconds or less.

Ciphey demo

The technical part. Ciphey uses a custom built artifical intelligence module (AuSearch) with a Cipher Detection Interface to approximate what something is encrypted with. And then a custom-built, customisable natural languge processing Language Checker Interface, which can detect when the given text becomes plaintext.

And that's just the tip of the iceberg. For the full technical explanation, check out our documentation.

โœจ Features

  • 20+ encryptions supported such as encodings (binary, base64) and normal encryptions like Caesar cipher, Transposition and more. For the full list, click here
  • Custom Built Artificial Intelligence with Augmented Search (AuSearch) for answering the question "what encryption was used?" Resulting in decryptions taking less than 3 seconds.
  • Custom built natural language processing module Ciphey can determine whether something is plaintext or not. It has an incredibly high accuracy, along with being fast.
  • Multi Language Support at present, only German & English (with AU, UK, CAN, USA variants).
  • Supports encryptions Which the alternatives such as CyberChef Magic do not.
  • C++ core Blazingly fast.

๐Ÿ”ญ Ciphey vs CyberChef

๐Ÿ” Base64 Encoded 42 times

Name โšก Ciphey โšก ๐Ÿข CyberChef ๐Ÿข
Gif The guy she tells you not to worry about You
Time 2 seconds 6 seconds
Setup
  • Run ciphey on the file
  • Set the regex param to "{"
  • You need to know how many times to recurse
  • You need to know it's Base64 all the way down
  • You need to load CyberChef (it's a bloated JS app)
  • Know enough about CyberChef to create this pipeline
  • Invert the match

Note The gifs may load at different times, so one may appear significantly faster than another.
A note on magic CyberChef's most similar feature to Ciphey is Magic. Magic fails instantly on this input and crashes. The only way we could force CyberChef to compete was to manually define it.

We also tested CyberChef and Ciphey with a 6gb file. Ciphey cracked it in 5 minutes and 54 seconds. CyberChef crashed before it even started.

๐Ÿ“Š Ciphey vs Katana vs CyberChef Magic

Name โšก Ciphey โšก ๐Ÿ—ก๏ธ Katana ๐Ÿ—ก๏ธ ๐Ÿข CyberChef Magic ๐Ÿข
Advanced Language Checker โœ… โŒ โœ…
Supports Encryptions โœ… โœ… โŒ
Releases named after Dystopian themes ๐ŸŒƒ โœ… โŒ โŒ
Supports hashes โœ… โœ… โŒ
Easy to set up โœ… โŒ โœ…
Can guess what something is encrypted with โœ… โŒ โŒ
Created for hackers by hackers โœ… โœ… โŒ

๐ŸŽฌ Getting Started

If you're having trouble with installing Ciphey, read this.

โ€ผ๏ธ Important Links (Docs, Installation guide, Discord Support)

Installation Guide Documentation Discord Docker Image (from REMnux)
๐Ÿ“– Installation Guide ๐Ÿ“š Documentation ๐Ÿฆœ Discord ๐Ÿ‹ Docker Documentation

๐Ÿƒโ€โ™€๏ธRunning Ciphey

There are 3 ways to run Ciphey.

  1. File Input ciphey - encrypted.txt
  2. Unqualified input ciphey -- "Encrypted input"
  3. Normal way ciphey -t "Encrypted input"

Gif showing 3 ways to run Ciphey

To get rid of the progress bars, probability table, and all the noise use the quiet mode.

ciphey -t "encrypted text here" -q

For a full list of arguments, run ciphey --help.

โš—๏ธ Importing Ciphey

You can import Ciphey's main and use it in your own programs and code. from Ciphey.__main__ import main

๐ŸŽช Contributors

Ciphey was invented by Brandon in 2008, and revived in 2019. Ciphey wouldn't be where it was today without Cyclic3 - president of UoL's Cyber Security Society.

Ciphey was revived & recreated by the Cyber Security Society for use in CTFs. If you're ever in Liverpool, consider giving a talk or sponsoring our events. Email us at cybersecurity@society.liverpoolguild.org to find out more ๐Ÿค 

Major Credit to George H for working out how we could use proper algorithms to speed up the search process. Special thanks to varghalladesign for designing the logo. Check out their other design work!

๐Ÿ•โ€๐Ÿฆบ Contributing

Don't be afraid to contribute! We have many, many things you can do to help out. Each of them labelled and easily explained with examples. If you're trying to contribute but stuck, tag @brandonskerritt in the GitHub issue โœจ

Alternatively, join the Discord group and send a message there (link in contrib file) or at the top of this README as a badge.

Please read the contributing file for exact details on how to contribute โœจ

๐Ÿ’ฐ Financial Contributors

The contributions will be used to fund not only the future of Ciphey and its authors, but also Cyber Security Society at the University of Liverpool.

GitHub doesn't support "sponsor this project and we'll evenly distribute the money", so pick a link and we'll sort it out on our end ๐Ÿฅฐ

โœจ Contributors

Thanks goes to these wonderful people (emoji key):


cyclic3

๐ŸŽจ ๐Ÿšง ๐Ÿ’ป ๐Ÿค”

Brandon

๐ŸŽจ ๐Ÿšง ๐Ÿ’ป ๐Ÿค”

michalani

๐Ÿ’ป

ashb07

๐Ÿ’ป

Shardion

๐Ÿ›

Bryan

๐ŸŒ ๐Ÿ“–

Lukas Gabriel

๐Ÿ’ป ๐Ÿ› ๐ŸŒ

Darshan

๐Ÿ›

SkeletalDemise

๐Ÿ’ป

Christian Clauss

๐Ÿ’ป ๐Ÿ›

This project follows the all-contributors specification. Contributions of any kind welcome!