Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/auth0/simplekeychain
A simple Keychain wrapper for iOS, macOS, tvOS, and watchOS
https://github.com/auth0/simplekeychain
dx-sdk ios keychain security
Last synced: about 5 hours ago
JSON representation
A simple Keychain wrapper for iOS, macOS, tvOS, and watchOS
- Host: GitHub
- URL: https://github.com/auth0/simplekeychain
- Owner: auth0
- License: mit
- Created: 2014-10-16T21:53:59.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2024-10-23T21:12:33.000Z (4 months ago)
- Last Synced: 2024-10-29T09:16:41.353Z (4 months ago)
- Topics: dx-sdk, ios, keychain, security
- Language: Swift
- Homepage: https://auth0.github.io/SimpleKeychain
- Size: 1.43 MB
- Stars: 585
- Watchers: 60
- Forks: 76
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
data:image/s3,"s3://crabby-images/1d6b2/1d6b28d7085e2300a78a690192b4a897c2ca3bb5" alt="SimpleKeychain"
data:image/s3,"s3://crabby-images/ebabf/ebabf870d2a495ef187214175763b8dcc320506a" alt="Version"
data:image/s3,"s3://crabby-images/b56da/b56dabbd9074a6c9c1c0fd889e94dc8780d2f06f" alt="Build Status"
[data:image/s3,"s3://crabby-images/36733/367335587e9ecabbcfecafe46f138b389f1f8f60" alt="Coverage Status"](https://codecov.io/github/auth0/SimpleKeychain)
data:image/s3,"s3://crabby-images/85c39/85c397ec481fe8ec61e996a4e170123d53a0c04f" alt="License"π [**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 15.x
- Swift 5.9+> [!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.