Geen omschrijving

Marcin Krzyżanowski bd46e8987e String and NSData extension 11 jaren geleden
CryptoSwift bd46e8987e String and NSData extension 11 jaren geleden
CryptoSwift.xcodeproj edc874ed45 refactor enums, cleanup 11 jaren geleden
CryptoSwiftTests bd46e8987e String and NSData extension 11 jaren geleden
.gitignore 2bb301a771 NSData extension initial 11 jaren geleden
LICENSE 0c22922fb7 Some useful extensions for numbers and initial work of MD5 imlementation. 11 jaren geleden
README.md bd46e8987e String and NSData extension 11 jaren geleden

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:NSData = Cipher.ChaCha20(setup).encrypt(dataToEncrypt)

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

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

##Contact Marcin Krzyżanowski @krzyzanowskim

##Licence see LICENSE file