Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/oauthswift/oauthswift
Swift based OAuth library for iOS
https://github.com/oauthswift/oauthswift
oauth oauth-client oauth1 oauth2 oauth2-authentication oauth2-client oauthswift
Last synced: about 1 hour ago
JSON representation
Swift based OAuth library for iOS
- Host: GitHub
- URL: https://github.com/oauthswift/oauthswift
- Owner: OAuthSwift
- License: mit
- Created: 2014-06-29T02:27:16.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2024-05-15T16:46:29.000Z (8 months ago)
- Last Synced: 2024-10-29T09:22:59.493Z (3 months ago)
- Topics: oauth, oauth-client, oauth1, oauth2, oauth2-authentication, oauth2-client, oauthswift
- Language: Swift
- Homepage:
- Size: 3.84 MB
- Stars: 3,273
- Watchers: 91
- Forks: 591
- Open Issues: 49
-
Metadata Files:
- Readme: README.md
- Contributing: .github/CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# OAuthSwift
Swift based OAuth library for iOS and macOS.
## Support OAuth1.0, OAuth2.0
Twitter, Flickr, Github, Instagram, Foursquare, Fitbit, Withings, Linkedin, Dropbox, Dribbble, Salesforce, BitBucket, GoogleDrive, Smugmug, Intuit, Zaim, Tumblr, Slack, Uber, Gitter, Facebook, Spotify, Typetalk, SoundCloud, Twitch, Reddit, etc
## Installation
OAuthSwift is packaged as a Swift framework. Currently this is the simplest way to add it to your app:
* Drag OAuthSwift.xcodeproj to your project in the Project Navigator.
* Select your project and then your app target. Open the Build Phases panel.
* Expand the Target Dependencies group, and add OAuthSwift framework.
* import OAuthSwift whenever you want to use OAuthSwift.### Support Carthage
* Install Carthage (https://github.com/Carthage/Carthage)
* Create `Cartfile` file```text
github "OAuthSwift/OAuthSwift" ~> 2.2.0
```* Run `carthage update`.
* On your application targets’ “General” settings tab, in the “Embedded Binaries”
section, drag and drop OAuthSwift.framework from the Carthage/Build/iOS folder on disk.### Support CocoaPods
* Podfile
```ruby
platform :ios, '10.0'
use_frameworks!pod 'OAuthSwift', '~> 2.2.0'
```### Swift Package Manager Support
```swift
import PackageDescriptionlet package = Package(
name: "MyApp",
dependencies: [
.package(name: "OAuthSwift",
url: "https://github.com/OAuthSwift/OAuthSwift.git",
.upToNextMajor(from: "2.2.0"))
]
)
```### Old versions
#### Swift 3
Use the `swift3` branch, or the tag `1.1.2` on main branch
#### Swift 4
Use the tag `1.2.0` on main branch
#### Objective-C
Use the tag `1.4.1` on main branch
## How to
### Setting URL Schemes
In info tab of your target
![Image](Assets/URLSchemes.png "Image")
Replace oauth-swift by your application name### Handle URL in AppDelegate
- On iOS implement `UIApplicationDelegate` method
```swift
func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey : Any] = [:]) -> Bool {
if url.host == "oauth-callback" {
OAuthSwift.handle(url: url)
}
return true
}
```- On iOS 13, UIKit will notify `UISceneDelegate` instead of `UIApplicationDelegate`.
- Implement `UISceneDelegate` method```swift
func scene(_ scene: UIScene, openURLContexts URLContexts: Set) {
guard let url = URLContexts.first?.url else {
return
}
if url.host == "oauth-callback" {
OAuthSwift.handle(url: url)
}
}
```:warning: Any other application may try to open a URL with your url scheme. So you can check the source application, for instance for safari controller :
```swift
if options[.sourceApplication] as? String == "com.apple.SafariViewService" {
```- On macOS you must register a handler on `NSAppleEventManager` for event type `kAEGetURL` (see demo code)
```swift
func applicationDidFinishLaunching(_ aNotification: NSNotification) {
NSAppleEventManager.shared().setEventHandler(self, andSelector:#selector(AppDelegate.handleGetURL(event:withReplyEvent:)), forEventClass: AEEventClass(kInternetEventClass), andEventID: AEEventID(kAEGetURL))
}
func handleGetURL(event: NSAppleEventDescriptor!, withReplyEvent: NSAppleEventDescriptor!) {
if let urlString = event.paramDescriptor(forKeyword: AEKeyword(keyDirectObject))?.stringValue, let url = URL(string: urlString) {
OAuthSwift.handle(url: url)
}
}
```### Authorize with OAuth1.0
```swift
// create an instance and retain it
oauthswift = OAuth1Swift(
consumerKey: "********",
consumerSecret: "********",
requestTokenUrl: "https://api.twitter.com/oauth/request_token",
authorizeUrl: "https://api.twitter.com/oauth/authorize",
accessTokenUrl: "https://api.twitter.com/oauth/access_token"
)
// authorize
let handle = oauthswift.authorize(
withCallbackURL: "oauth-swift://oauth-callback/twitter") { result in
switch result {
case .success(let (credential, response, parameters)):
print(credential.oauthToken)
print(credential.oauthTokenSecret)
print(parameters["user_id"])
// Do your request
case .failure(let error):
print(error.localizedDescription)
}
}
```### OAuth1 without authorization
No urls to specify here
```swift
// create an instance and retain it
oauthswift = OAuth1Swift(
consumerKey: "********",
consumerSecret: "********"
)
// do your HTTP request without authorize
oauthswift.client.get("https://api.example.com/foo/bar") { result in
switch result {
case .success(let response):
//....
case .failure(let error):
//...
}
}
```### Authorize with OAuth2.0
```swift
// create an instance and retain it
oauthswift = OAuth2Swift(
consumerKey: "********",
consumerSecret: "********",
authorizeUrl: "https://api.instagram.com/oauth/authorize",
responseType: "token"
)
let handle = oauthswift.authorize(
withCallbackURL: "oauth-swift://oauth-callback/instagram",
scope: "likes+comments", state:"INSTAGRAM") { result in
switch result {
case .success(let (credential, response, parameters)):
print(credential.oauthToken)
// Do your request
case .failure(let error):
print(error.localizedDescription)
}
}
```### Authorize with OAuth2.0 and proof key flow (PKCE)
```swift
// create an instance and retain it
oauthswift = OAuth2Swift(
consumerKey: "********",
consumerSecret: "********",
authorizeUrl: "https://server.com/oauth/authorize",
responseType: "code"
)
oauthswift.accessTokenBasicAuthentification = trueguard let codeVerifier = generateCodeVerifier() else {return}
guard let codeChallenge = generateCodeChallenge(codeVerifier: codeVerifier) else {return}let handle = oauthswift.authorize(
withCallbackURL: "myApp://callback/",
scope: "requestedScope",
state:"State01",
codeChallenge: codeChallenge,
codeChallengeMethod: "S256",
codeVerifier: codeVerifier) { result in
switch result {
case .success(let (credential, response, parameters)):
print(credential.oauthToken)
// Do your request
case .failure(let error):
print(error.localizedDescription)
}
}
```See demo for more examples
### Handle authorize URL
The authorize URL allows the user to connect to a provider and give access to your application.By default this URL is opened into the external web browser (ie. safari), but apple does not allow it for app-store iOS applications.
To change this behavior you must set an `OAuthSwiftURLHandlerType`, simple protocol to handle an `URL`
```swift
oauthswift.authorizeURLHandler = ..
```For instance you can embed a web view into your application by providing a controller that displays a web view (`UIWebView`, `WKWebView`).
Then this controller must implement `OAuthSwiftURLHandlerType` to load the URL into the web view```swift
func handle(_ url: NSURL) {
let req = URLRequest(URL: targetURL)
self.webView.loadRequest(req)
...
```and present the view (`present(viewController`, `performSegue(withIdentifier: `, ...)
*You can extend `OAuthWebViewController` for a default implementation of view presentation and dismiss*#### Use the SFSafariViewController (iOS9)
A default implementation of `OAuthSwiftURLHandlerType` is provided using the `SFSafariViewController`, with automatic view dismiss.
```swift
oauthswift.authorizeURLHandler = SafariURLHandler(viewController: self, oauthSwift: oauthswift)
```Of course you can create your own class or customize the controller by setting the variable `SafariURLHandler#factory`.
### Make signed request
Just call HTTP functions of `oauthswift.client`
```swift
oauthswift.client.get("https://api.linkedin.com/v1/people/~") { result in
switch result {
case .success(let response):
let dataString = response.string
print(dataString)
case .failure(let error):
print(error)
}
}
// same with request method
oauthswift.client.request("https://api.linkedin.com/v1/people/~", .GET,
parameters: [:], headers: [:],
completionHandler: { ...
```See more examples in the demo application: [ViewController.swift](/Demo/Common/ViewController.swift)
## OAuth provider pages
* [Twitter](https://dev.twitter.com/oauth)
* [Flickr](https://www.flickr.com/services/api/auth.oauth.html)
* [Github](https://developer.github.com/v3/oauth/)
* [Instagram](https://developers.facebook.com/docs/instagram-basic-display-api/guides/getting-access-tokens-and-permissions)
* [Foursquare](https://developer.foursquare.com/overview/auth)
* [Fitbit](https://dev.fitbit.com/build/reference/web-api/oauth2/)
* [Withings](http://oauth.withings.com/api)
* [LinkedIn](https://docs.microsoft.com/en-us/linkedin/shared/authentication/authentication)
* [Dropbox](https://www.dropbox.com/developers/documentation/http/documentation)
* [Dribbble](https://developer.dribbble.com/v2/#authentication)
* [Salesforce](https://developer.salesforce.com/docs/atlas.en-us.api_rest.meta/api_rest/)
* [BitBucket](https://confluence.atlassian.com/bitbucket/oauth-on-bitbucket-cloud-238027431.html)
* [GoogleDrive](https://developers.google.com/drive/v2/reference/)
* [Smugmug](https://smugmug.atlassian.net/wiki/display/API/OAuth)
* [Intuit](https://developer.intuit.com/app/developer/qbo/docs/develop/authentication-and-authorization)
* [Zaim](https://dev.zaim.net/home/api/authorize)
* [Tumblr](https://www.tumblr.com/docs/en/api/v2#auth)
* [Slack](https://api.slack.com/docs/oauth)
* [Uber](https://developer.uber.com/docs/ride-requests/guides/authentication/introduction#oauth-20)
* [Gitter](https://developer.gitter.im/docs/authentication)
* [Facebook](https://developers.facebook.com/docs/facebook-login)
* [Spotify](https://developer.spotify.com/web-api/authorization-guide/)
* [Trello](https://developers.trello.com/authorize)
* [Buffer](https://buffer.com/developers/api/oauth)
* [Goodreads](https://www.goodreads.com/api/documentation#oauth)
* [Typetalk](http://developer.nulab-inc.com/docs/typetalk/auth)
* [SoundCloud](https://developers.soundcloud.com/docs/api/guide#authentication)
* [Doper](https://doper.io/developer/oauth)
* [NounProject](http://api.thenounproject.com/getting_started.html#authentication)
* [Reddit](https://github.com/reddit-archive/reddit/wiki/oauth2)## Images
![Image](Assets/Services.png "Image")
![Image](Assets/TwitterOAuth.png "Image")
![Image](Assets/TwitterOAuthTokens.png "Image")## Contributing
See [CONTRIBUTING.md](.github/CONTRIBUTING.md)
[Add a new service in demo app](https://github.com/OAuthSwift/OAuthSwift/wiki/Demo-application#add-a-new-service-in-demo-app)
## Integration
OAuthSwift could be used with others frameworks
You can sign [Alamofire](https://github.com/Alamofire/Alamofire) request with [OAuthSwiftAlamofire](https://github.com/OAuthSwift/OAuthSwiftAlamofire)
To achieve great asynchronous code you can use one of these integration frameworks
- [OAuthSwiftFutures](https://github.com/OAuthSwift/OAuthSwiftFutures) - [BrightFutures](https://github.com/Thomvis/BrightFutures)
- [OAuthRxSwift](https://github.com/OAuthSwift/OAuthRxSwift) - [RxSwift](https://github.com/ReactiveX/RxSwift)
- [OAuthReactiveSwift](https://github.com/OAuthSwift/OAuthReactiveSwift) - [ReactiveSwift](https://github.com/ReactiveCocoa/ReactiveSwift)## License
OAuthSwift is available under the MIT license. See the LICENSE file for more info.
[![License](https://img.shields.io/badge/license-MIT-blue.svg?style=flat
)](http://mit-license.org) [![Platform](https://img.shields.io/badge/platform-iOS_OSX_TVOS-lightgrey.svg?style=flat
)](https://developer.apple.com/resources/) [![Language](https://img.shields.io/badge/language-swift-orange.svg?style=flat
)](https://developer.apple.com/swift) [![Cocoapod](https://img.shields.io/cocoapods/v/OAuthSwift.svg?style=flat)](http://cocoadocs.org/docsets/OAuthSwift/)
[![Carthage compatible](https://img.shields.io/badge/Carthage-compatible-4BC51D.svg?style=flat)](https://github.com/Carthage/Carthage) [![Build Status](https://travis-ci.org/OAuthSwift/OAuthSwift.svg?branch=master)](https://travis-ci.org/OAuthSwift/OAuthSwift)