# SimpleKeychain **Repository Path**: mirrors_auth0/SimpleKeychain ## Basic Information - **Project Name**: SimpleKeychain - **Description**: A simple Keychain wrapper for iOS, macOS, tvOS, and watchOS - **Primary Language**: Unknown - **License**: MIT - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2020-08-08 - **Last Updated**: 2026-05-16 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README    [](https://codecov.io/github/auth0/SimpleKeychain) [](https://deepwiki.com/auth0/SimpleKeychain)  📚 [**Documentation**](#documentation) • 🚀 [**Getting Started**](#getting-started) • 📃 [**Support Policy**](#support-policy) • 💬 [**Feedback**](#feedback) Migrating from 0.x? Check the [Migration Guide](V1_MIGRATION_GUIDE.md). ## Documentation - [**Examples**](EXAMPLES.md) - explains how to use more advanced features. - [**API Documentation**](https://auth0.github.io/SimpleKeychain/documentation/simplekeychain) - documentation auto-generated from the code comments that explains all the available features. + [SimpleKeychain](https://auth0.github.io/SimpleKeychain/documentation/simplekeychain/simplekeychain) + [Accessibility](https://auth0.github.io/SimpleKeychain/documentation/simplekeychain/accessibility) + [SimpleKeychainError](https://auth0.github.io/SimpleKeychain/documentation/simplekeychain/simplekeychainerror) - [**Auth0 Documentation**](https://auth0.com/docs) - explore our docs site and learn more about Auth0. ## Getting Started ### Requirements - iOS 14.0+ / macOS 11.0+ / tvOS 14.0+ / watchOS 7.0+ - Xcode 16.x - Swift 6.0+ > [!IMPORTANT] > Check the [Support Policy](#support-policy) to learn when dropping Xcode, Swift, and platform versions will not be considered a **breaking change**. ### Installation #### Swift Package Manager Open the following menu item in Xcode: **File > Add Packages...** In the **Search or Enter Package URL** search box enter this URL: ```text https://github.com/auth0/SimpleKeychain ``` Then, select the dependency rule and press **Add Package**. #### Cocoapods Add the following line to your `Podfile`: ```ruby pod 'SimpleKeychain', '~> 1.0' ``` Then, run `pod install`. #### Carthage Add the following line to your `Cartfile`: ```text github "auth0/SimpleKeychain" ~> 1.0 ``` Then, run `carthage bootstrap --use-xcframeworks`. ### Usage **Learn about more advanced features in [Examples ↗](EXAMPLES.md)** **See all the available features in the [API documentation ↗](https://auth0.github.io/SimpleKeychain/documentation/simplekeychain)** ```swift let simpleKeychain = SimpleKeychain() ``` You can specify a service name under which to save items. By default the bundle identifier of your app is used. ```swift let simpleKeychain = SimpleKeychain(service: "Auth0") ``` #### Store a string or data item ```swift try simpleKeychain.set(accessToken, forKey: "auth0-access-token") ``` #### Check if an item is stored ```swift let isStored = try simpleKeychain.hasItem(forKey: "auth0-access-token") ``` #### Retrieve a string item ```swift let accessToken = try simpleKeychain.string(forKey: "auth0-access-token") ``` #### Retrieve a data item ```swift let accessToken = try simpleKeychain.data(forKey: "auth0-credentials") ``` #### Retrieve the keys of all stored items ```swift let keys = try simpleKeychain.keys() ``` #### Remove an item ```swift try simpleKeychain.deleteItem(forKey: "auth0-access-token") ``` #### Remove all items ```swift try simpleKeychain.deleteAll() ``` #### Error handling All methods will throw a `SimpleKeychainError` upon failure. ```swift catch let error as SimpleKeychainError { print(error) } ``` ## Support Policy This Policy defines the extent of the support for Xcode, Swift, and platform (iOS, macOS, tvOS, and watchOS) versions in SimpleKeychain. ### Xcode The only supported versions of Xcode are those that can be currently used to submit apps to the App Store. Once a Xcode version becomes unsupported, dropping it from SimpleKeychain **will not be considered a breaking change**, and will be done in a **minor** release. ### Swift The minimum supported Swift minor version is the one released with the oldest-supported Xcode version. Once a Swift minor becomes unsupported, dropping it from SimpleKeychain **will not be considered a breaking change**, and will be done in a **minor** release. ### Platforms We support only the last four major versions of any platform, including the current major version. Once a platform version becomes unsupported, dropping it from SimpleKeychain **will not be considered a breaking change**, and will be done in a **minor** release. For example, iOS 14 will cease to be supported when iOS 18 gets released, and SimpleKeychain will be able to drop it in a minor release. In the case of macOS, the yearly named releases are considered a major platform version for the purposes of this Policy, regardless of the actual version numbers. ## Feedback ### Contributing We appreciate feedback and contribution to this repo! Before you get started, please see the following: - [Auth0's general contribution guidelines](https://github.com/auth0/open-source-template/blob/master/GENERAL-CONTRIBUTING.md) - [Auth0's code of conduct guidelines](https://github.com/auth0/open-source-template/blob/master/CODE-OF-CONDUCT.md) - [SimpleKeychain's contribution guide](CONTRIBUTING.md) ### Raise an issue To provide feedback or report a bug, please [raise an issue on our issue tracker](https://github.com/auth0/SimpleKeychain/issues). ### Vulnerability reporting Please do not report security vulnerabilities on the public GitHub issue tracker. The [Responsible Disclosure Program](https://auth0.com/responsible-disclosure-policy) details the procedure for disclosing security issues. ---
Auth0 is an easy-to-implement, adaptable authentication and authorization platform. To learn more check out Why Auth0?
This project is licensed under the MIT license. See the LICENSE file for more info.