How to Setup Firebase
You might need to use Firebase for Firebase authentication of users in your app via phone number.
It might look a bit scary at first. But don’t panic and let’s check how to do this right step by step.
Firebase account and project registration
Section titled “Firebase account and project registration”Follow these steps to register your Firebase account and create a Firebase project:
- 
Register a Firebase account at Firebase console . You can use your Google account to authenticate at Firebase. 
- 
Click Create project  Note: If you have a Google project registered for your mobile app, select it from the Project name dropdown menu. You can also edit your Project ID if you need. A unique ID is assigned automatically to each project. This ID is used in publicly visible Firebase features. For example, it will be used in database URLs and in your Firebase Hosting subdomain. If you need to use a specific subdomain, you can change it. 
- 
Fill in the fields required (Project name, Project ID, etc.) and click Continue.   
- 
Configure Google Analytics for your project and click Create project.  Then click Continue.  
- 
Select platform for which you need Firebase  
- 
Fill in the fields on Add Firebase to your iOS App screen and click Register App  Note: Please pay attention to add the bundle ID your app is using. It can be set only when you add an app to your Firebase project. 
Connect Firebase SDK
Section titled “Connect Firebase SDK”For iOS projects Firebase has the following requirements to be added successfully:
- Xcode 9.0 or later
- An Xcode project for iOS 8 version or above
- For Swift projects - Swift 3.0 or later
- Your app’s bundle identifier
- CocoaPods 1.4.0 or later
- For Cloud Messaging:
- A physical iOS device
- Your Apple Developer account’s Apple Push Notification Authentication Key
- In Xcode you need to enable Push Notifications in App > Capabilities
 
Here is a step by step guide how to connect Firebase SDK to your iOS Project:
- 
Download GoogleService-Info.plist config file. It can be also downloaded later if you need. 
- 
Add Firebase SDK A. With CocoaPods It is recommended using CocoaPods to install the libraries. CocoaPods can be installed according to this guide. You need to add the pods for the libraries you need to use. - 
If you don’t have an Xcode project yet, you need to create it. 
- 
Create a Podfile if you don’t have one. You can do that as follows: 
 $ cd your-project directory$ pod init
- 
   3) Add the pods you are going to install. A Pod can be included in your Podfile as follows:
   ```groovypod 'Firebase/Core'Note: The above pod should add the libraries needed to make Firebase work in your iOS app as well as Google Analytics for Firebase. The list of available pods with their specifications can be found here.
- Install the pods of your choice and open your-project.xcworkspace file to see the project in Xcode.
$ pod install$ open your-project.xcworkspace- Download a GoogleService-Info.plist file from your Firebase account and add it to your app.
Note: Each bundle ID must be connected in Firebase. If you have several bundle IDs in your project, each of them can have its own GoogleService-Info.plist file.
B. Without CocoaPods
SDK frameworks can be imported directly without using CocoaPods as follows:
- 
Download the framework SDK zip (since the file is about 500MB in size, it may take some time). 
- 
Unzip it and find README file. 
- 
Add the ObjC linker flag in your Other Linker Settings in your target’s build settings. 
- 
Add initialisation code: - Import the Firebase module in your UIApplicationDelegate:
 @import Firebase;import Firebase- Configure a FirebaseApp shared instance, typically in your application’s application:didFinishLaunchingWithOptions:method:
 // Use Firebase library to configure APIs[FIRApp configure];// Use Firebase library to configure APIsFirebaseApp.configure()You are done now. 
- Import the Firebase module in your 
Firebase authentication
Section titled “Firebase authentication”This option allows users in your app authenticate themselves via phone number. If you use this method for user authentication, the user receives an SMS with verification code and authenticates via that code in your app.
You need to follow these steps to add Firebase authentication to your iOS project:
- 
Include the following pods in your Podfile: pod 'Firebase/Auth'
- 
Go to Firebase console >> Authentication >> Sign-in method section:  
- 
Enable Phone number sign-in method:  
- 
Enable app verification For Firebase phone authentication to work Firebase must be able to verify that phone number sign-in requests are coming from your app. There are two options how to verify it: - 
Silent APNs notifications In order to enable APNS notifications for Firebase authentication follow these steps: - 
Enable push notifications for your project in Xcode 
- 
Upload your APNS certificate to Firebase. If you do not know how to create APNS certificate - please use our How to generate APNS certificate guide 
 
- 
- 
reCAPTCHA verification If sending silent push notifications fails (user has disabled background refresh or your app or you are testing on a simulator), Firebase uses reCAPTCHA verification to complete the phone log in. In order to enable reCAPTCHA verification follow these steps: - 
Add custom URL schemes to your project in Xcode: A. In your GoogleService-Info.plist configuration file find REVERSED_CLIENT_ID key and copy it. B. Go to your project configuration >> Your Project name, then select your app from the Targets section, choose Info tab and open URL Types section. C. Click + button and add your REVERSED_CLIENT_ID key to URL Schemes field. 
- 
(Optional) It is possible to customize the way your app presents SFSafariViewControllerorUIWebViewwhen displaying the reCAPTCHA to the user. For that purpose you need to create a custom class that conforms to theFIRAuthUIDelegateprotocol, and pass it toverifyPhoneNumber:UIDelegate:completion:.
 
- 
 
- 
- 
Call verifyPhoneNumber:UIDelegate:completion:passing to it the user’s phone number to request that Firebase send an authentication code to the user’s phone by SMS:[[FIRPhoneAuthProvider provider] verifyPhoneNumber:phoneNumberUIDelegate:nilcompletion:^(NSString * _Nullable verificationID, NSError * _Nullable error) {if (error) {[self showMessagePrompt:error.localizedDescription];return;}// Sign in using the verificationID and the code sent to the user// ...}];PhoneAuthProvider.provider().verifyPhoneNumber(phoneNumber, uiDelegate: nil) { (verificationID, error) inif let error = error {self.showMessagePrompt(error.localizedDescription)return}// Sign in using the verificationID and the code sent to the user// ...}Note As a best practice please do not forget to inform your users that if they use phone sign-in, they might receive an SMS message for verification and standard rates apply. 
- 
languageCodeproperty on your Auth instance allows specifying the auth language and therefore localize SMS message sent by Firebase:// Change language code to french.[FIRAuth auth].languageCode = @"fr";// Change language code to french.Auth.auth().languageCode = "fr";
- 
Save the verification ID and restore it when your app loads. This measure should help you to have a valid verification ID if your app closes before the user can sign in (if the user checks SMS app, for instance). A simple way is to save the verification ID with the NSUserDefaultsobject:NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];[defaults setObject:verificationID forKey:@"authVerificationID"];UserDefaults.standard.set(verificationID, forKey: "authVerificationID")Then, you can restore the saved value: NSString *verificationID = [defaults stringForKey:@"authVerificationID"];let verificationID = UserDefaults.standard.string(forKey: "authVerificationID")
- 
Create a FIRPhoneAuthCredentialobject using the verification code and the verification ID:FIRAuthCredential *credential = [[FIRPhoneAuthProvider provider]credentialWithVerificationID:verificationIDverificationCode:verificationCode];let credential = PhoneAuthProvider.provider().credential(withVerificationID: verificationID,verificationCode: verificationCode)
- 
Sign in the user with the FIRPhoneAuthCredential object: [[FIRAuth auth] signInAndRetrieveDataWithCredential:credentialcompletion:^(FIRAuthDataResult * _Nullable authResult,NSError * _Nullable error) {if (error) {// ...return;}// User successfully signed in. Get user data from the FIRUser objectif (authResult == nil) { return; }FIRUser *user = authResult.user;// ...}];Auth.auth().signInAndRetrieveData(with: credential) { (authResult, error) inif let error = error {// ...return}// User is signed in// ...}
- 
Get Firebase access_tokenafter SMS code verification as follows:
[FIRUser getIDTokenWithCompletion:^(NSString * _Nullable token, NSError * _Nullable __unused error) {
}];User.getIDToken { (tokenResult, error) in
}- Add ConnectyCube user sign in to your project as follows:
- Get your Project ID from your Firebase console

- Pass your Firebase project_idand Firebaseaccess_tokenparameters tosignInUsingFirebasePhone(logInWithFirebaseProjectIDv1 deprecated) method:
let projectId = ""let accessToken = ""
ConnectyCube().signInUsingFirebasePhone(projectId: projectId, accessToken: accessToken, successCallback: { user in
}) { (error) in
}NSString *projectId = @"...";NSString *accessToken = @"...";
[CYBRequest logInWithFirebaseProjectID:projectId accessToken:accessToken successBlock:^(CYBUser *user) {
} errorBlock:^(NSError *error) {
}];let projectId = ""let accessToken = ""
Request.logIn(withFirebaseProjectID: projectId, accessToken: accessToken, successBlock: { (user) in
}) { (error) in
}- Run your app to verify installation Once your user is logged in successfully, you will find him/her in your Dashboard >> Your App >> Users section.

So now you know how to use Firebase features in your ConnectyCube apps. If you have any difficulties - please let us know via support channel