Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ArtSabintsev/Zephyr
Effortlessly synchronize UserDefaults over iCloud.
https://github.com/ArtSabintsev/Zephyr
background-monitoring carthage cocoapods icloud icloud-key icloud-sync nsubiquitouskeyvaluestore nsuserdefaults swift swift-package-manager sync userdefaults
Last synced: 3 months ago
JSON representation
Effortlessly synchronize UserDefaults over iCloud.
- Host: GitHub
- URL: https://github.com/ArtSabintsev/Zephyr
- Owner: ArtSabintsev
- License: mit
- Created: 2015-11-04T23:22:15.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2024-05-16T19:42:12.000Z (6 months ago)
- Last Synced: 2024-07-19T13:46:12.550Z (4 months ago)
- Topics: background-monitoring, carthage, cocoapods, icloud, icloud-key, icloud-sync, nsubiquitouskeyvaluestore, nsuserdefaults, swift, swift-package-manager, sync, userdefaults
- Language: Swift
- Homepage: http://www.sabintsev.com/
- Size: 11.2 MB
- Stars: 933
- Watchers: 19
- Forks: 60
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ios - Zephyr - Effortlessly synchronize NSUserDefaults over iCloud. (Database / Getting Started)
- awesome-swift - Zephyr - Effortlessly synchronize NSUserDefaults over iCloud. (Libs / Data Management)
- awesome-swift - Zephyr - Effortlessly synchronize NSUserDefaults over iCloud. (Libs / Data Management)
- fucking-awesome-swift - Zephyr - Effortlessly synchronize NSUserDefaults over iCloud. (Libs / Data Management)
- awesome-ios-star - Zephyr - Effortlessly synchronize NSUserDefaults over iCloud. (Database / Getting Started)
- awesome-swift-cn - Zephyr - Effortlessly synchronize NSUserDefaults over iCloud. (Libs / Data Management)
- fucking-awesome-ios - Zephyr - Effortlessly synchronize NSUserDefaults over iCloud. (Database / Getting Started)
- fucking-awesome-ios - Zephyr - Effortlessly synchronize NSUserDefaults over iCloud. (Database / Getting Started)
- awesome-swift - Zephyr - Effortlessly synchronize UserDefaults over iCloud. ` 📝 7 months ago` (Data Management [🔝](#readme))
README
# Zephyr 🌬️
### Effortlessly sync UserDefaults over iCloud
![Swift Support](https://img.shields.io/badge/Swift-5.3-orange.svg) [![Platform](https://img.shields.io/badge/Platforms-iOS%20%7c%20tvOS-lightgray.svg?style=flat)](http://cocoadocs.org/docsets/Zephyr) [![CocoaPods](https://img.shields.io/cocoapods/v/Zephyr.svg)]() [![SwiftPM Compatible](https://img.shields.io/badge/SwiftPM-Compatible-brightgreen.svg)](https://swift.org/package-manager/)
---
### AboutZephyr synchronizes specific keys and/or all of your [UserDefaults](https://developer.apple.com/documentation/foundation/userdefaults) over iCloud using [NSUbiquitousKeyValueStore](https://developer.apple.com/library/ios/documentation/Foundation/Reference/NSUbiquitousKeyValueStore_class/).
Zephyr has built in monitoring, allowing it to sync specific keys in the background as they change.
For the latest updates, refer to the [Releases](https://github.com/ArtSabintsev/Zephyr/releases) tab.
### Features
- [x] CocoaPods and SwiftPM Support
- [x] Syncs specific `UserDefaults` keys or all of your `UserDefaults`.
- [x] Background monitoring and synchronization between `UserDefaults` and `NSUbiquitousKeyValueStore`
- [x] Detailed Logging### Installation Instructions
| Swift Version | Branch Name | Will Continue to Receive Updates?
| ------------- | ------------- | -------------
| 5.1+ | master | **Yes**
| 5.0 | swift5.0 | No
| 4.2 | swift4.2 | No
| 4.1 | swift4.1 | No
| 3.2 | swift3.2 | No
| 3.1 | swift3.1 | No#### CocoaPods
```ruby
pod 'Zephyr' # Swift 5.1+
pod 'Zephyr', :git => 'https://github.com/ArtSabintsev/Zephyr.git', :branch => 'swift5.0' # Swift 5.0
pod 'Zephyr', :git => 'https://github.com/ArtSabintsev/Zephyr.git', :branch => 'swift4.2' # Swift 4.2
pod 'Zephyr', :git => 'https://github.com/ArtSabintsev/Zephyr.git', :branch => 'swift4.1' # Swift 4.1
pod 'Zephyr', :git => 'https://github.com/ArtSabintsev/Zephyr.git', :branch => 'swift3.2' # Swift 3.2
pod 'Zephyr', :git => 'https://github.com/ArtSabintsev/Zephyr.git', :branch => 'swift3.1' # Swift 3.1
```### Swift Package Manager
``` swift
.Package(url: "https://github.com/ArtSabintsev/Zephyr.git", majorVersion: 3)
```#### Manual
1. [Download Zephyr](http://github.com/ArtSabintsev/Zephyr/archive/master.zip)
2. Copy `Zephyr.swift` into your project.### Setup
#### Turn on iCloud Sync in Xcode
In Xcode, open your app's project/workspace file:
- Click on your Project
- Click on one of your Targets
- Click on Capabilities
- Turn on iCloud syncing
- Under Services, make sure to check `Key-value storage`
- Repeat for all Targets (if necessary)![How to turn on iCloud Key Value Store Syncing](https://github.com/ArtSabintsev/Zephyr/blob/master/Assets/XcodeSettings.png?raw=true "How to turn on iCloud Key Value Store Syncing")
#### Integrate Zephyr into your App
Before performing each sync, Zephyr automatically checks to see if the data in UserDefaults or NSUbiquitousKeyValueStore is newer. To make sure there's no overwriting going on in a fresh installation of your app on a new device that's connected to the same iCloud account, make sure that your UserDefaults are registered ***BEFORE*** calling any of the Zephyr methods. One way to easily achieve this is by using the [UserDefaults Register API](https://developer.apple.com/documentation/foundation/userdefaults/1417065-register).
**Sync all UserDefaults**
```Swift
Zephyr.sync()
```**Sync a specific key or keys (Variadic Option)**
```Swift
Zephyr.sync(keys: "MyFirstKey", "MySecondKey", ...)
```**Sync a specific key or keys (Array Option)**
```Swift
Zephyr.sync(keys: ["MyFirstKey", "MySecondKey"])
```**Add/Remove Keys for Background Monitoring (Variadic Option)**
```Swift
Zephyr.addKeysToBeMonitored(keys: "MyFirstKey", "MySecondKey", ...)
Zephyr.removeKeysFromBeingMonitored(keys: "MyFirstKey", "MySecondKey", ...)
```**Add/Remove Keys for Background Monitoring (Array Option)**
```Swift
Zephyr.addKeysToBeMonitored(keys: ["MyFirstKey", "MySecondKey"])
Zephyr.removeKeysFromBeingMonitored(keys: ["MyFirstKey", "MySecondKey"])
```
**Toggle Automatic Calling of NSUbiquitousKeyValueStore's Synchronization method**
```
Zephyr.syncUbiquitousKeyValueStoreOnChange = true // Default
Zephyr.syncUbiquitousKeyValueStoreOnChange = false // Turns off instantaneous synchronization
```**Debug Logging**
```Swift
Zephyr.debugEnabled = true // Must be called before sync(_:)
Zephyr.sync()
```**Use a specific `UserDefaults` suite**
```swift
if let suite = UserDefaults(suiteName: "group.com.example.app-name") {
Zephyr.setUserDefaultsSuite(to: suite)
}
```### Sample App
Please ignore the Sample App as I did not add any demo code in the Sample App. It's only in this repo to add support for Carthage.
### Created and maintained by
[Arthur Ariel Sabintsev](http://www.sabintsev.com/)