README.md 2.2 KB

#CryptoSwift Crypto related functions and helpers for Swift implemented in Swift. (#PureSwift)

##Requirements Good mood

##Features

  • Easy to use
  • Convenience extensions

###What implemented?

Hash

#####Cipher

###Why Why? Because I can.

##Usage

import CryptoSwift

Generally you should use CryptoSwift.Hash,CryptoSwift.Cipher enums or convenience extensions

Hash enum usage

/* Hash enum usage */
var data:NSData = NSData(bytes: [49, 50, 51] as [Byte], length: 3)
if let data = CryptoSwift.Hash.md5.calculate(data) {
    println(data.hexString)
}

Hashing a data

let hash = data.md5()
let hash = data.sha1()
let hash = data.sha224()
let hash = data.sha256()
let hash = data.sha384()
let hash = data.sha512()

let crc = data.crc32()

println(hash.hexString)

Hashing a String and printing result

if let hash = "123".md5() {
    println(hash)
}

Working with Cipher

// convenience setup tuplet
let setup = (key: keyData, iv: ivData)

// encrypt
let encrypted = Cipher.ChaCha20(setup).encrypt(dataToEncrypt)

// decrypt
let decrypted = Cipher.ChaCha20(setup).decrypt(encrypted)

// validate result
if (encrypted.isEqual(decrypted)) {
    print("Decryption failed!")
}

with extensions

// convenience setup tuplet
let setup = (key: keyData, iv: ivData)

let encrypted = dataToEncrypt.encrypt(Cipher.ChaCha20(setup))
let decrypted = encrypted.decrypt(Cipher.ChaCha20(setup))

##Contact Marcin Krzyżanowski @krzyzanowskim

##Licence see LICENSE file