This repo contains CocoaPods plugin code for implementing Sequencing.com's OAuth2 authentication for your Swift iOS app so that your app can securely access Sequencing.com's API and app chains.
- CocoaPods integration
- Resources
- Maintainers
- Contribute
Please follow instruction below if you want to install and use OAuth logic in your existed or new project.
-
Create a new project in Xcode
-
Install pod
-
see CocoaPods guides
-
create Podfile in your project directory:
$ pod init
-
don't forget to uncomment the row (as this is Swift pod)
use_frameworks!
-
specify "sequencing-oauth-api-swift" pod parameters:
pod 'sequencing-oauth-api-swift', '~> 2.5.0'
-
install the dependency in your project:
$ pod install
-
always open the Xcode workspace instead of the project file:
$ open *.xcworkspace
-
-
Add Application Transport Security setting
- open project settings > Info tab
- add
App Transport Security Settings
row parameter (as Dictionary) - add subrow to App Transport Security Settings parameter as
Exception Domains
dictionary parameter - add subrow to Exception Domains parameter with
sequencing.com
string value - add subrow to App Transport Security Settings parameter with
Allow Arbitrary Loads
boolean value - set
Allow Arbitrary Loads
boolean value asYES
-
Register framework to use in Swift code
-
first of all you need to create bridging header file. Select File > New > File > Header File > name it as
project-name-Bridging-Header.h
-
add SQOAuthFramework class import in the bridging header file
#import <OAuth/SQOAuthFramework.h>
-
register your bridging header file in the project settings. select your project > project target > Build Settings > Objective-C Bridging Header specify path for bridging header file
$(PROJECT_DIR)/project-name-Bridging-Header.h
-
-
Register app parameters and delegate
-
subscribe your class for Authorization protocol
SQAuthorizationProtocol
-
have access to SQOAuth via
shared instance
methodSQOAuth.sharedInstance()
-
register your app parameters and delegate
SQOAuth.sharedInstance().registerApplicationParametersCliendID("your CLIENT_ID here", clientSecret: "your CLIENT_SECRET here", redirectUri: "your REDIRECT_URI here", scope: "your SCOPE here", delegate: <your delegate>, viewControllerDelegate: <your VC delegate>)
where:
client_id - your app CLIENT_ID client_secret - your app CLIENT_SECRET redirect_uri - your app REDIRECT_URI scope - your app SCOPE delegate - class that conforms to "SQAuthorizationProtocol" protocol viewControllerDelegate - provide your class instance as UI delegate
-
-
Use authorization method
-
implement methods from SQAuthorizationProtocol
func userIsSuccessfullyAuthorized(_ token: SQToken) -> Void { } func userIsNotAuthorized() -> Void { } func userDidCancelAuthorization() -> Void { }
-
you can authorize your user via
authorizeUser
methodSQOAuth.sharedInstance().authorizeUser()
-
in method
userIsSuccessfullyAuthorized
you'll receive the SQToken object:accessToken: String expirationDate: NSDate tokenType: String scope: String refreshToken: String
-
-
Access to up-to-date token
-
to receive up-to-date token use related method from SQOAuth API (it returns the updated token):
SQOAuth.sharedInstance().token({ (SQToken?, String?) in })
where are SQToken of token object, and String of accessToken value
-
-
Register new account / Reset password methods
- just call
callRegisterResetAccountFlow
method - it will open dialog popupSQOAuth.sharedInstance().callRegisterResetAccountFlow()
- just call
-
Connect To Sequencing method
-
call
connectToSequencing(withCliendSecret: userEmail: filesArray: viewControllerDelegate:)
method fromSQConnectTo
classlet connetManager = SQConnectTo.init() connetManager.connectToSequencing(withCliendSecret: SQOAuth.sharedInstance(), userEmail: "your email address", filesArray: <your files Array> as! [Any], viewControllerDelegate: <your VC gelegate>)
where
clientSecretProvider - provide SQOAuth instance (as ```SQOAuth.sharedInstance()```) emailAddress - your account email address filesArray - NSArray of genetic files (see details below) viewControllerDelegate - provide your class instance as UI delegate
files should be passed on as NSArray object with NSDictionary file objects inside. Following keys and values should be used:
"name" : file name as NSString "type" : NSString "url" : file url as NSString "hashType" : NSString "hashValue" : NSString "size" : NSString
-
-
23andMe files import
-
call
importFrom23AndMe(withToken: viewControllerDelegate)
method fromSQ3rdPartyImportAPI
classlet importAPI: SQ3rdPartyImportAPI = SQ3rdPartyImportAPI.init() importAPI.importFrom23AndMe(withToken: SQOAuth.sharedInstance(), viewControllerDelegate: <your VC gelegate>)
where
tokenProvider - provide SQOAuth instance (as ```SQOAuth.sharedInstance()```) viewControllerDelegate - provide your class instance as UI delegate
-
-
Ancestry.com files import
-
call
importFromAncestry(withToken: viewControllerDelegate:)
method fromSQ3rdPartyImportAPI
classlet importAPI: SQ3rdPartyImportAPI = SQ3rdPartyImportAPI.init() importAPI.importFromAncestry(withToken: SQOAuth.sharedInstance(), viewControllerDelegate: <your VC gelegate>)
where
tokenProvider - provide SQOAuth instance (as ```SQOAuth.sharedInstance()```) viewControllerDelegate - provide your class instance as UI delegate
-
This repo is actively maintained by Sequencing.com. Email the Sequencing.com bioinformatics team at gittaca@sequencing.com if you require any more information or just to say hola.
We encourage you to passionately fork us. If interested in updating the master branch, please send us a pull request. If the changes contribute positively, we'll let it ride.