1 09-ModernSymmetric


Cryptography [without end-system integrity] is like investing in an armored car,
to carry money between a customer living in a cardboard box,
and a person doing business on a park bench.
- Gene Spafford

This is basically the situation with most smart-phones currently…
Side-channel attacks, backdoors, and hardware compromises,
can negate the good cryptography in your secure open-source apps.
There is hope, and some degree of security, though!

1.1 Screencasts

1.2 Reading

Part II Building Blocks is a quick read:
https://github.com/crypto101/crypto101.github.io/raw/master/Crypto101.pdf

1.3 Video

An easy watch, high level overview:
https://www.crypto101.io/

1.4 Symmetric Encryption

1.4.1 Definitions

1.4.2 Overview

1.4.3 Simplified model

ModernSymmetric/f1-crop.png

What kind of encryption is the Caesar cipher?

1.4.4 Attacking Symmetric Encryption

1.4.4.1 Cryptanalytic Attacks

1.4.4.2 Brute-Force Attack

1.4.5 Modern (or sort-of modern) symmetric algorithms

1.4.5.1 Data Encryption Standard (DES)

https://en.wikipedia.org/wiki/Data_Encryption_Standard
DES is the archetypal block cipher, an algorithm that takes a fixed-length string of plaintext bits and repeatedly transforms it through a series of complicated operations into another ciphertext bitstring of the same length.

ModernSymmetric/des.png
1.4.5.1.1 Time to brute force

ModernSymmetric/image9.png
How much time is required for a brute-force attack for various key sizes?
Right column is supercomputer, second from right is a personal computer.

1.4.5.2 Triple DES

ModernSymmetric/image8.png

The whole 3DES key space can be searched thoroughly by affordable consumer hardware since 2015 or so.

1.4.5.3 Advanced Encryption Standard (AES)

https://en.wikipedia.org/wiki/AES_encryption
The most widely trusted scheme out there.
ModernSymmetric/image8.png

AES operates on a 4 x 4 column-major order matrix of bytes
ModernSymmetric/aes.png

AES is based on a design principle known as a substitution-permutation network, a combination of both substitution and permutation, and is both fast in software, and can be implemented quickly in application-specific hardware.

How big is 256 bits?
https://www.youtube.com/watch?v=S9JGmA5_unY

1.4.6 Practical Security Issues: Modes of operation

1.4.6.1 ECB mode

ModernSymmetric/ecb01.png
ModernSymmetric/ecb00.png

image, ECB mode, ECB Randomized mode
ModernSymmetric/Tux.png ModernSymmetric/Tux_ecb.png ModernSymmetric/Tux_secure.png

1.4.6.2 Cipher Block Chaining (CBC) mode

ModernSymmetric/CBC_encryption.png
ModernSymmetric/CBC_decryption.png
* Kick-start with an initialization vector (IV), which is just another number that has to be really random!
* Each block of plaintext is XOR’ed with the previous ciphertext block before being encrypted.
* This way, each ciphertext block depends on all plaintext blocks processed up to that point.
* To make each message unique, an initialization vector must be used in the first block.
* Can we decrypt in parallel for speed and efficiency?

1.4.7 Block versus Stream Ciphers

1.4.7.1 Block Cipher (top image below)

ModernSymmetric/f2-crop.png

1.4.7.2 Stream Cipher (bottom image above)

++++++++++++++++++++++++++++++++
Cahoot-09.1