data:image/s3,"s3://crabby-images/75d9f/75d9f25ea723878458c903cd7e20aa427708e017" alt="Frontegg_SwiftUI_SDK"
Frontegg is a web platform where SaaS companies can set up their fully managed, scalable and brand aware - SaaS features
and integrate them into their SaaS portals in up to 5 lines of code.
Table of Contents
Project Requirements
Supported Languages
Swift: The minimum supported Swift version is now 5.3.
Major platform versions are supported, starting from:
Getting Started
Prepare Frontegg workspace
Navigate to Frontegg Portal Settings, If you don’t have application
follow integration steps after signing up.
Copy FronteggDomain to future steps from Frontegg Portal Domain
Setup Hosted Login
Add frontegg package to the project
- Open you project
- Choose File -> Add Packages
- Enter
https://github.com/frontegg/frontegg-ios-swift
in search field
- Press
Add Package
Create Frontegg plist file
To setup your SwiftUI application to communicate with Frontegg, you have to create a new file named Frontegg.plist
under
your root project directory, this file will store values to be used variables by Frontegg SDK:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>baseUrl</key>
<string>https://[DOMAIN_HOST_FROM_PREVIOUS_STEP]</string>
<key>clientId</key>
<string>[CLIENT_ID_FROM_PREVIOUS_STEP]</string>
</dict>
</plist>
SwiftUI integration
UIKit integration
Add Frontegg UIKit Wrapper
Add Frontegg to the AppDelegate file
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
// Override point for customization after application launch.
FronteggApp.shared.didFinishLaunchingWithOptions()
return true
}
Create FronteggController class that extends AbstractFronteggController from FronteggSwift
//
// FronteggController.swift
//
import UIKit
import FronteggSwift
class FronteggController: AbstractFronteggController {
override func navigateToAuthenticated(){
// This function will be called when the user is authenticated
// to navigate your application to the authenticated screen
let mainStoryboard: UIStoryboard = UIStoryboard(name: "Main", bundle: nil)
let viewController = mainStoryboard.instantiateViewController(withIdentifier: "authenticatedScreen")
self.view.window?.rootViewController = viewController
self.view.window?.makeKeyAndVisible()
}
}
Create new ViewController and set FronteggController as view custom class from the previous step
data:image/s3,"s3://crabby-images/dc98c/dc98c7bab350ee7e708a3fca714450fb6085ec80" alt="ViewController custom class"
Mark FronteggController as Storyboard Entry Point
data:image/s3,"s3://crabby-images/946bd/946bd82c11fba103d05d865f7b72c7e7d087b9e1" alt="ViewController entry point"
Setup SceneDelegate for Frontegg universal links:
func scene(_ scene: UIScene, openURLContexts URLContexts: Set<UIOpenURLContext>) {
if let url = URLContexts.first?.url,
url.startAccessingSecurityScopedResource() {
defer {
url.stopAccessingSecurityScopedResource()
}
if url.absoluteString.hasPrefix( FronteggApp.shared.baseUrl ) {
FronteggApp.shared.auth.pendingAppLink = url
window?.rootViewController = FronteggController()
window?.makeKeyAndVisible()
}
}
}
func scene(_ scene: UIScene, continue userActivity: NSUserActivity) {
if let url = userActivity.webpageURL,
url.absoluteString.hasPrefix( FronteggApp.shared.baseUrl ){
FronteggApp.shared.auth.pendingAppLink = url
window?.rootViewController = FronteggController()
window?.makeKeyAndVisible()
}
}
Access authenticated user by FronteggApp.shared.auth
//
// ExampleViewController.swift
//
import UIKit
import SwiftUI
import FronteggSwift
import Combine
class ExampleViewController: UIViewController {
// Label to display logged in user's email
@IBOutlet weak var label: UILabel!
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
// subscribe to isAuthenticated and navigate to login page
// if the user is not authenticated
let sub = AnySubscriber<Bool, Never>(
receiveSubscription: {query in
query.request(.unlimited)
}, receiveValue: { isAuthenticated in
if(!isAuthenticated){
self.view.window?.rootViewController = FronteggController()
self.view.window?.makeKeyAndVisible()
return .none
}
return .unlimited
})
FronteggApp.shared.auth.$isAuthenticated.subscribe(sub)
label.text = FronteggApp.shared.auth.user?.email ?? "Unknown"
}
@IBAction func logoutButton (){
FronteggApp.shared.auth.logout()
}
}
Config iOS associated domain
Configuring your iOS associated domain is required for Magic Link authentication / Reset Password / Activate Account.
In order to add your iOS associated domain to your Frontegg application, you will need to update in each of your integrated Frontegg Environments the iOS associated domain that you would like to use with that Environment. Send a POST request to https://api.frontegg.com/vendors/resources/associated-domains/v1/ios
with the following payload:
{
“appId”:[YOUR_ASSOCIATED_DOMAIN]
}
In order to use our API’s, follow this guide to generate a vendor token.
Frontegg is a web platform where SaaS companies can set up their fully managed, scalable and brand aware - SaaS features and integrate them into their SaaS portals in up to 5 lines of code.
Table of Contents
Project Requirements
Supported Languages
Swift: The minimum supported Swift version is now 5.3.
Supported Platforms
Major platform versions are supported, starting from:
Getting Started
Prepare Frontegg workspace
Navigate to Frontegg Portal Settings, If you don’t have application follow integration steps after signing up. Copy FronteggDomain to future steps from Frontegg Portal Domain
Setup Hosted Login
{{LOGIN_URL}}/mobile/callback
Add frontegg package to the project
https://github.com/frontegg/frontegg-ios-swift
in search fieldAdd Package
Create Frontegg plist file
To setup your SwiftUI application to communicate with Frontegg, you have to create a new file named
Frontegg.plist
under your root project directory, this file will store values to be used variables by Frontegg SDK:SwiftUI integration
Add Frontegg Wrapper
To use Frontegg SDK you have to wrap you Application Scene with FronteggWrapper
Modify
MyApp.swift
file to render content if user is authenticated:@EnvironmentObject var fronteggAuth: FronteggAuth
tofronteggAuth.isAuthenticated
Add custom loading screen
To use your own
LoadingView
/SplashScreen
:LoadingView
as AnyView to the FronteggWrapperUIKit integration
Add Frontegg UIKit Wrapper
Add Frontegg to the AppDelegate file
Create FronteggController class that extends AbstractFronteggController from FronteggSwift
Create new ViewController and set FronteggController as view custom class from the previous stepdata:image/s3,"s3://crabby-images/dc98c/dc98c7bab350ee7e708a3fca714450fb6085ec80" alt="ViewController custom class"
Mark FronteggController as Storyboard Entry Pointdata:image/s3,"s3://crabby-images/946bd/946bd82c11fba103d05d865f7b72c7e7d087b9e1" alt="ViewController entry point"
Setup SceneDelegate for Frontegg universal links:
Access authenticated user by
FronteggApp.shared.auth
Config iOS associated domain
Configuring your iOS associated domain is required for Magic Link authentication / Reset Password / Activate Account.
In order to add your iOS associated domain to your Frontegg application, you will need to update in each of your integrated Frontegg Environments the iOS associated domain that you would like to use with that Environment. Send a POST request to
https://api.frontegg.com/vendors/resources/associated-domains/v1/ios
with the following payload:In order to use our API’s, follow this guide to generate a vendor token.