if NimbleLoyalty.shared.isAuthenticated() {
// The user is authenticated, do something
} else {
// The user is not authenticated, show a login button
}
authenticate(completion:)
Initiates the authentication flow.
NimbleLoyalty.shared.authenticate { result in
switch result {
case .success:
// The user is authenticated, do something
case .failure(let error):
print("Error authenticating: \(error.localizedDescription)")
}
}
clearSession()
Remove the session, effectively logging the user out.
// Clear the user's session
NimbleLoyalty.shared.clearSession()
Get Reward List
Retrieves the list of available rewards for the authenticated user.
NimbleLoyalty.shared.getRewardList { result in
switch result {
case .success(let rewardList):
// Display the list of rewards to the user
for reward in rewardList.rewards {
print("Reward name: \(reward.name)")
}
case .failure(let error):
print("Error retrieving rewards: \(error.localizedDescription)")
}
}
Get Reward Detail
Retrieves the detail of a specific reward.
NimbleLoyalty.shared.getRewardDetail(code: "reward_id") { result in
switch result {
case .success(let rewardDetail):
// Display the reward detail to the user
case .failure(let error):
print("Error retrieving reward detail: \(error.localizedDescription)")
}
}
Redeem a Reward
Redeems a reward with the given reward’s code for the authenticated user.
NimbleLoyalty.shared.redeemReward(code: "ABC123") { result in
switch result {
case .success(let rewardList):
print("Reward redeemed with ID: \(redeemReward.id)")
case .failure(let error):
print("Error redeeming reward: \(error.localizedDescription)")
}
}
Get Reward History
Retrieves the reward history for the authenticated user.
NimbleLoyalty.shared.getRewardHistory { result in
switch result {
case .success(let rewardHistory):
// Display the reward history to the user
for reward in rewardHistory {
print("Reward name: \(reward.name)")
}
case .failure(let error):
print("Error retrieving reward history: \(error.localizedDescription)")
}
}
Get Product List
Retrieves the list of available products for the authenticated user.
NimbleLoyalty.shared.getProductList { result in
switch result {
case .success(let products):
// Display the list of products to the user
for product in products {
print("Product name: \(product.name)")
}
case .failure(let error):
print("Error retrieving products: \(error.localizedDescription)")
}
}
Get Product Detail
Retrieves the detail of a specific product.
NimbleLoyalty.shared.getProductDetail(id: "product_id") { result in
switch result {
case .success(let productDetail):
// Display the reward detail to the user
case .failure(let error):
print("Error retrieving reward detail: \(error.localizedDescription)")
}
}
Samples
Navigate to the Example folder.
Fill environment values in .env.example and rename it to .env
This NimbleLoyalty SDK library allows developers to easily integrate loyalty programs into their iOS applications.
Features
Component Libraries
Requirements
Installation
The iOS Loyalty SDK can be installed using CocoaPods or Swift Package Manager.
CocoaPods
To install using CocoaPods, add the following line to your Podfile:
Swift Package Manager
To install using Swift Package Manager, add the following line to your dependencies:
Usage
Authentication
Before authenticating the user, remember to set the clientId and clientSecret.
isAuthenticated()
Checks if the user is authenticated.
authenticate(completion:)
Initiates the authentication flow.
clearSession()
Remove the session, effectively logging the user out.
Get Reward List
Retrieves the list of available rewards for the authenticated user.
Get Reward Detail
Retrieves the detail of a specific reward.
Redeem a Reward
Redeems a reward with the given reward’s code for the authenticated user.
Get Reward History
Retrieves the reward history for the authenticated user.
Get Product List
Retrieves the list of available products for the authenticated user.
Get Product Detail
Retrieves the detail of a specific product.
Samples
bundle install
bundle exec arkana
bundle exec pod install
.Home screen that demonstrate features from SDK
• Sign-in
• Reward List
• Reward History
Reward List screen that show reward information.
• Image
• Title & description
• Expiration
• Reward redemption
Reward Details screen that show reward information.
• Image
• Title & description
• Expiration
• Reward redemption
• Terms
Reward History screen that show redeemed reward information.
• Image
• Title
• Expiration
Product List screen that show product information.
• Image
• Title & description
Product Details screen that shows product information.
• Image
• Title & description
Credits
This project is maintained and funded by Nimble.
License
This project is Copyright (c) 2023 and onwards Nimble. It is free software and may be redistributed under the terms specified in the LICENSE file.