No Description

Marcin Krzyżanowski a66cd73281 Current version is 0.0.2 11 years ago
CryptoSwift a66cd73281 Current version is 0.0.2 11 years ago
CryptoSwift.xcodeproj edc874ed45 refactor enums, cleanup 11 years ago
CryptoSwiftTests bd46e8987e String and NSData extension 11 years ago
.gitignore 2bb301a771 NSData extension initial 11 years ago
LICENSE 0c22922fb7 Some useful extensions for numbers and initial work of MD5 imlementation. 11 years ago
README.md 0e1ac73af9 README update regarding cipher extensions 11 years ago

README.md

#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