philips-software/cogito

View on GitHub
workspaces/cogito-ios-app/Cogito/Encryption service/KeyPairCreator.swift

Summary

Maintainability
A
0 mins
Test Coverage
A
100%
import Foundation
import Security

struct KeyPairCreator: KeyPairCreatorType {
    func create(tag: String) {
        let accessFlags = SecAccessControlCreateWithFlags(kCFAllocatorDefault,
                                                          kSecAttrAccessibleAfterFirstUnlock,
                                                          .userPresence,
                                                          nil)!
        let parameters: [String: Any] = [
            kSecAttrKeyType as String: kSecAttrKeyTypeRSA,
            kSecAttrKeySizeInBits as String: 2048,
            kSecAttrApplicationTag as String: tag.data(using: .utf8)!,
            kSecAttrIsPermanent as String: true,
            kSecPrivateKeyAttrs as String: [
                kSecAttrAccessControl as String: accessFlags
            ]
        ]
        var error: Unmanaged<CFError>?
        SecKeyCreateRandomKey(parameters as CFDictionary, &error)

    }
}

protocol KeyPairCreatorType {
    func create(tag: String)
}