A simple wrapper framework for the CommonCrypto C library which can be used in Swift applications and frameworks.
The framework builds with the CommonCrypto version of the selected target SDK of your project. It is compatible with iOS Simulator and Device SDKs. The framework uses LLVM modules to make the CommonCrypto interfaces available to Swift.
You should be aware that CommonCrypto is not designed to be used with Swift and using the C based funtions can be quite challenging. It is recommended to wrap the CommonCrypto functionality inside a separate Swift framework using CommonCrypto in order to use it in Swift applications.
Cou can add the framework to your Cartfile just like any other Carthage compatible framework:
github "wiedem/CommonCrypto"
Follow the other common steps as described on the Carthage website for the integration into your project. No further steps are required, you don't need to create or add any modulemap files.
You can use CommonCrypt after integrating the wrapper framework into your project just like any other Swift framework.
Example:
import CommonCrypto
open class CryptoTest {
open class func hashString(_ string: String) -> Data {
let ctx = UnsafeMutablePointer<CC_SHA1_CTX>.allocate(capacity: 1)
defer { ctx.deallocate(capacity: 1) }
let data: Data = string.data(using: .utf8)!
CC_SHA1_Init(ctx)
data.withUnsafeBytes { (rawPtr: UnsafePointer<UInt8>) -> Void in
CC_SHA1_Update(ctx, rawPtr, UInt32(data.count))
}
var hashData = Data(count: Int(CC_SHA1_DIGEST_LENGTH))
hashData.withUnsafeMutableBytes { (rawPtr: UnsafeMutablePointer<UInt8>) -> Void in
CC_SHA1_Final(rawPtr, ctx)
}
return hashData
}
}
The CommonCrypto wrapper framework is released under the the MIT license.