/Securing-Apikeys

Securing secrets using CloudKit

Primary LanguageSwiftMIT LicenseMIT

Securing Apikeys

Swift Version platforms License

This repository is part of NSCoder Night Madrid Talk "Securing Apikeys using Cloudkit".

The repository include:

  • Talk Slides.
  • Initial Project
  • Final Project

The sample project is a simple app that uses an api service to show a grid with pictures. It present a picture on full screen when is selected and allow to make a mask with de logo of NSCoder Night Madrid. The initial project just store the access key in a constant and uses it. The final project in order to secure the access key:

  • Get the access key from Cloud kit in a secure way.
  • When the app gets the access key stores it in keychain to be resused after.
  • As an extra layer of security the access key in encrypted and decrypted using Secure Enclave
  • To avoid the called "Man in the middle", la app makes use of SSL pining.
  • SSl pining can be performed using the host certificate or a hash of certificate public key

The app can be tested on iPhone, iPad, AppleTv o Mac

Usage

The api used is unsplash In order to test sample projects yout need an access key. Your can register and create a free new one on Join Unsplash

To test initial project just replace the placeholder in class UnplashClient:

private let apikey_unsplash = "UNSPLASH ACCESS KEY"

To test final sample project, the slides information maybe is useful:

  • You must create a container in CloudKit
  • Create a new record type. Named it "ApiKeys"
  • Add a field to new record type created. Named it "unplash"
  • Add a new record with your api unsplash access key.

After this steps you must replace this with real values in class ApiKeyManager:

let ckRecordId = "CLOUDKIT RECORD ID"

Screenshots

Alt text Alt text Alt text

License

MIT

Authors

🚀 About Me

I'm a iOS, tvOS and MacOS freelance developer since 2011