Tripian Rest Kit makes it easy to connect your iOS application to the Tripian APIs. It provides you all the tools you need to create personalized recommendations and itineraries for your customers.
The Tripian Rest Kit is powered by the Tripian Rest API and Tripian recommendation engines. For more information, see the Tripian Recommendation API Page.
Tripian Rest Kit pairs well with Tripian Core Kit SDK for iOS.
Tripian Rest Kit framework is written in Swift.
The key features are:
- Features
- Component Frameworks
- Requirements
- Installation
- Usage
- Use Cases
- Examples
- Communication
- License
- Cities
- Tripian features over 250 cities world-wide. Each city has a unique id (cityId) that you will need to use in creating trips, trip related questions and getting quick recommendations.
- Places of Interest
- To reach over 1M places of interests, call TRPRestKit().poi(..) functions.
- User Management
- Login, Obtain personal user information, Updating user information , Obtaining user payment history, User’s past and upcoming trips, User's all favorite place of interests list, User's companions, Password reset requests, etc.
- Trip Planner
- Getting trip questions, Creating a personolized trip, Obtaining trip info, Getting daily plan info, Adding place of interests into daily plans, etc.
- Quick Recommendations
- Getting quick recommendation with a given cityId or trip hash.
- Comprehensive Unit and Integration Test Coverage.
- English and French Language Support.
In order to keep Tripian Rest kit focused specifically on networking implementations of Tripian Rest API, additional component frameworks have been created by the Tripian Software Team to bring additional functionality to the Tripian IOS Frameworks ecosystem.
-
TRPCoreKit - A Core framework which includes all the operations of Tripian Rest Kit in view controllers including with core functionalities. Such as creating trip, getting daily plan list, performing user management, viewing or editing user's upcoming & past trips, etc.
-
TRPFoundationKit - A Foundation framework which defines a base layer of functionality among Tripian IOS Frameworks. It provides primitive classes and introduces several paradigms that makes developing with TRPRestKit more easier by introducing consistent conventions.
Tripian Rest Kit and Tripian Core Kit are compatible with applications written in Swift 5 in Xcode 10.2 and above. Tripian Rest Kit and Tripian Core Kit frameworks run on iOS 11.0 and above.
To install TRP Rest Kit using CocoaPods:
-
Create a Podfile with the following specification:
pod 'TRPRestKit', :git => 'https://github.com/tripian/trRestKit.git'
The platform specified in your Podfile should be
:iOS '11'
-
Run
pod repo update && pod install
and open the resulting Xcode workspace. -
In
Info.plist
, addTripianAccessToken
with your Tripian Access Token as the value.
Tripian APIs require a Tripian account and API access token. In the project editor, select the application target, then go to the Info tab. Under the “Custom iOS Target Properties” section, set TripianAccessToken
to your access token. You can obtain an access token from the Tripian Recommendation API Page.
Adding internet permission: The TRPRestKit SDK requires internet permission to work properly. Under the “NSAppTransportSecurity” section, set NSAllowsArbitraryLoads
to NO
.
import TRPRestKit
TRPRestKit() is an NSObject instance which monitors all the Tripian Rest Api calls.
Getting Cities
- Call
cities
function to get all the cities.
TRPRestKit().cities {(result, error, pagination) in
if let error = error {
//TODO: Check whether there is an error.
return
}
guard let result = result as? [TRPCityInfoModel] else {
//TODO: Check the result.
return
}
}
Trip Planner
//Create TrpTripSettings instance with cityId,arrivalTime and departureTime.
let cityId: Int = 0 //cityId refers to an integer value as an id of the city where trip will be generated.
let arrivalTime: TRPTime = getToday()//arrivalTime parameter refers to a TRPTime instance to specify arrival time of the trip.
let departureTime: TRPTime = getTomorrow()//departureTime parameter refers to a TRPTime instance to specify departure time of the trip.
let tripSettings = TRPTripSettings(cityId: cityId, arrivalTime: arrivalTime, departureTime: departureTime)
//Call create trip function with the tripSettings param.
TRPRestKit().createTrip(settings: settings) {(result, error) in
if let error = error {
//TODO: Check whether there is an error.
return
}
guard let result = result as? TRPTripInfoModel else {
//TODO: Check the result.
return
}
}
// Get Trip with a given trip hash.
TRPRestKit().getTrip(withHash: hash) {(result, error) in
if let error = error {
//TODO: Check whether there is an error.
return
}
if let result = result as? TRPTripInfoModel {
//TODO: Check the result.
return
}
}
//Edit trip with a given editedTripSettings including with selected trip hash.
let editedTripHash = ""
let editedArrivalTime: TRPTime = getToday()
let editedDepartureTime: TRPTime = getTomorrow()
let editedTripSettings = TRPTripSettings(hash: editedTripHash, arrivalTime: editedArrivalTime, departureTime: editedDepartureTime)
//Call edit trip function with the created editedTripSettings variable including with the selected trip hash.
TRPRestKit().editTrip(settings: editedTripSettings) {(result, error) in
if let error = error {
//TODO: Check whether there is an error.
return
}
guard let result = result as? TRPTripInfoModel else {
//TODO: Check the result.
return
}
}
//Delete trip with a given trip hash.
let tripHash = ""
TRPRestKit().deleteTrip(hash: tripHash) {(result, error) in
if let error = error {
//TODO: Check whether there is an error.
return
}
guard let result = result as? TRPParentJsonModel else {
//TODO: Check the result.
return
}
}
Places of Interest
- To reach over 1M places of interests, call
TRPRestKit().poi(..)
functions.
let cityId:Int = 0 //To define city location, cityId parameter must be used in calling places of interests.
let autoPagination:Bool = false //Autopagination param refers to disable auto pagination during the call.
TRPRestKit().poi(withCityId: cityId, autoPagination: autoPagination) {(result, error, pagination) in
if let error = error {
//TODO: Check whether there is an error.
return
}
guard let result = result as? [TRPPoiInfoModel] else {
//TODO: Check the result.
return
}
}
Daily Plans
let dailyPlanId:Int = 0 // dailyPlanId variable refers to the requested daily plan id.
TRPRestKit().dailyPlan(id: dailyPlanId) {(result, error) in
if let error = error {
//TODO: Check whether there is an error.
return
}
guard let result = dailyPlan as? TRPDailyPlanInfoModel else {
//TODO: Check the result.
return
}
}
//Below function updates daily plan starting and ending hours with given dailyPlanId, start and end times.
let dailyPlanId:Int = 0 //dailyPlanId variable refers to the requested daily plan id.
let startTime:String = "10:00" //startTime variable refers to daily plan's start time.
let endTime:String = "21:00" //endTime variable refers to daily plan's end time.
//Update daily plan with requested times.
TRPRestKit().updateDailyPlanHour(dailyPlanId: dailyPlanId, start: startTime, end: endTime) {(dailyPlan, error) in
if let error = error {
//TODO: Check whether there is an error.
return
}
guard let result = dailyPlan as? TRPDailyPlanInfoModel else {
//TODO: Check the result.
return
}
}
//Changing daily plan place of interest with the requested place.
let oldDailyPlanID:Int = 0 //oldDailyPlanID variable refers to the place which will be replaced soon.
let newDailyPlanPoiID:Int = 1 //newDailyPlanPoiID variable refers to the requested place.
//oldDailyPlanID will be replaced by newDailyPlanPoiID.
TRPRestKit().replacePlanPoiFrom(dailyPlanPoiId: oldDailyPlanID, poiId: newDailyPlanPoiID) {(result, error) in
if let error = error {
//TODO: Check whether there is an error.
return
}
guard let result = result as? TRPPlanPoi else {
//TODO: Check the result.
return
}
}
User Management
let email:String = "someEmail@example.com"
let password:String = "somepassword"
TRPRestKit().login(email: email, password: password) {(result, error) in
if error != nil {
//TODO: Check whether there is an error.
return
}
guard let result = result as? TRPLoginInfoModel else {
//TODO: Check the result.
return
}
}
TRPRestKit().userInfo {(result, error) in
if let error = error {
//TODO: Check whether there is an error.
return
}
guard let result = result as? TRPUserInfoModel else {
//TODO: Check the result.
return
}
}
Quick Recommendations
- Getting quick recommendation with a given
TRPRecommendationSettings
instance.
//Recommendation function used among trip operations.
let cityId:Int = 0 //To define city location, cityId parameter must be used in getting recommendations.
let recommendationSetting:TRPRecommendationSettings = TRPRecommendationSettings(cityId: cityId)//recommendationSetting variable refers to an TRPRecommendationSettings instance.
//Call quickRecommendation function with the created recommendationSetting variable.
TRPRestKit().quickRecommendation(settings: settings) { (result, error, pagination) in
if let error = error {
//TODO: Check whether there is an error.
return
}
guard let result = result as? [TRPRecommendationInfoJsonModel] else {
//TODO: Check the result.
return
}
}
The TRPRestKit-IOS-Examples includes example code for accomplishing common tasks that exercises a variety of Tripian Rest Kit SDK features:
- Clone the repository or download the .zip file
- Run
pod repo update && pod install
and open the resulting Xcode workspace. - Open
TrpRestKitIOSExample.xcodeproj
. - Sign up or log in to your Tripian account and grab a Tripian Access Token.
- Open the Info.plist in the
Example
target and paste your Tripian Access Token intoTripianAccessToken
. (Alternatively, you can set the access token while calling theTrpRestKit(withAccessToken: AccessToken)
instead of adding it to Info.plist.) - Build and run the
Example
target.
- TrpRestKitiOS.Tests includes comprehensive Unit and Integration Tests of Tripian Rest Kit SDK features.
- If you need help with TRPRest Kit, use Stack Overflow and tag
trprestkit
. - If you need to find or understand the Tripian Recommendation Engine API, check our documentation.
- If you found a bug, open an issue here on GitHub and follow the guide. The more detail the better!
- TRPFoundationKit - framework is created by the Tripian Software Team to provide primitive classes and introduce several paradigms that makes developing with TRPRestKit more easier by introducing consistent conventions.