Giter Club home page Giter Club logo

aont-tolstoy's Introduction

AONT-Tolstoy

Crypto for the masses

Here’s another submission to everyone, no restrictions imposed. This one is rather more complete, providing GUI interface, as well as precompiled standalone versions for Mac and Windows.

AONT-Tolstoy: 1-click encode / decode of confidential information — no keys needed

First up AONT = All Or Nothing Transforms = a secure way to transmit a document to a recipient in such a way that the recipient either gets the entire unmolested document in originally submitted form, or nothing at all. This idea goes back to Ronald Rivest of MIT. Very clever idea. It is crypto without being crypto in a legal sense.

The tool does the following to text typed into the message pane, or a drag & drop collection of files, or a collection of files from the Files menu:

  1. Compress the text using Lempel-Ziv self-describing lossless compression to squeeze out the waste and heighten innate entropy

  2. Encrypt the compressed data with AES-256 and a randomly chosen key. You don’t know what that key is, and you don’t need to know.

  3. Compute the SHA-256 of the crypto text and append the XOR of that hash with the random key to the crypto text.

Now we have extremely high entropy and it stands out like a sore thumb. To stop drawing attention to yourself, the tool next does

  1. Form the Huffman encoding of English text from Tolstoy’s “War and Peace” using a 3-level Hidden Markov Model to make the resulting plain text look like real sentences. The content is pure gibberish, but you have to look closely to see that. This is a better approach than just choosing random words.

The text is confidentially encoded, not airtight encryption, but it avoids sniffers looking for high-entropy crypto text, and you have to take the whole message or you get nothing. Furthermore, you can’t reveal anything under duress about the key because you truly don’t know what it is. (Warning… that may not save your neck!) But in front of a judge you can truthfully state that you don’t know the decryption key.

However, if you successfully extract the right English content, and shove it through the tool, the decryption key is there at the end of the crypto text, provided you haven’t damaged the crypto text in any manner. And it will decrypt for you.

All characters, punctuation, character case is significant, but arbitrary whitespace can be inserted between the words.

Example:

“This is a test!” —>

---------- SNIP HERE -------------- Mary?" but said he, taking this way!" who had brought for others, attain the laws the Russian nest gave to Moscow, though he spoke with you! one of his thighbone into deep dissatisfaction of Borodino. open-mouthed of musketry removed army, the Russian army- packages tone handkerchiefs broke son such purification. reports true more wars. examples, made with clear Prince Andrew. On day that they have outraged Europe. the old man with bare were eager sufferings, amusement asked a commissariat to kiss his conduct infinite, ---------- SNIP HERE --------------

Each time you run this it will generate totally different apparently random output.

What we are doing here is akin to spectral shaping, but applied to the histogram of the plaintext message. We first whiten the message = maximum entropy encoding, then impress the histogram of “War and Peace” on that white histogram to produce the colored histogram that appears to be English prose. High entropy encoding implies compression. The impressing of English prose statistics implies re-inflation.

What prompted me to write this is the work I was doing for a local Patent Attorney, who had a habit of sending all preliminary documents in the clear. With all the industrial espionage going on, I didn’t think that was serving his clients very well. So I wrote this for him, and made it as tight as I could without requiring the interchange of keys, and realizing that most people aren’t computer savvy.

… apart from that, it was a lot of fun seeing that I could shape histograms at will, much like I shape audio spectra with filtering.

Tolstoy’s “War and Peace” was substantial enough, more than 700K words, 100K sentences, that decent statistics could be gathered. The AONT-Tolstoy actually attempts to break up the structure into paragraphs of varying length, rather than just one big glob of text. The breakup is also structured after the statistics inherent in the original manuscript, showing Exponential distributions of sentences with an average length of 15 words, and another Exponential distribution of paragraphs with an average of 3 sentences.

The 3-layer HMM was also interesting to write.

  • DM

aont-tolstoy's People

Contributors

dbmcclain avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.