No Description

Marcin Krzyżanowski 72a6ec3cf9 cleanup code. Separate Int and UInt32 Extensions. New operators defined in Operators.swift. Byte.shiftRight addedd. Poly1305 minor improvements 11 years ago
CryptoSwift 72a6ec3cf9 cleanup code. Separate Int and UInt32 Extensions. New operators defined in Operators.swift. Byte.shiftRight addedd. Poly1305 minor improvements 11 years ago
CryptoSwift.xcodeproj 72a6ec3cf9 cleanup code. Separate Int and UInt32 Extensions. New operators defined in Operators.swift. Byte.shiftRight addedd. Poly1305 minor improvements 11 years ago
CryptoSwiftTests 72a6ec3cf9 cleanup code. Separate Int and UInt32 Extensions. New operators defined in Operators.swift. Byte.shiftRight addedd. Poly1305 minor improvements 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 f8001533fa update README with installation section 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.

##Installation

Drag the CryptoSwift.xcodeproj file into your Xcode project, and add CryptoSwift.framework as a dependency for your target.

##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(data).calculate() {
    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 tuple
let setup = (key: keyData, iv: ivData)

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

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

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

    }
}

with extensions

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

if let encrypted = dataToEncrypt.encrypt(Cipher.ChaCha20(setup)) {
    if let decrypted = encrypted.decrypt(Cipher.ChaCha20(setup)) {
        println(decrypted)
    }
}

##Contact Marcin Krzyżanowski @krzyzanowskim

##Licence see LICENSE file