Parse Server with Back4App Quick Start - codepath/ios_guides GitHub Wiki
Overview
A quick start guide to setting up a Parse server hosted on Back4App
Sign up
- Go to Back4App and choose a "Sign up" option. The following example shows the "Sign up with GitHub" flow. Make sure you're signed in to GitHub with the account you want to use with Back4App.
- Authorize with GitHub
- "Skip" or "Continue" through the "Welcome" flow.
- Name your server app.
Dashboard
- "Cancel" or "Next" at "Onboarding" flow for a brief dashboard orientation.
Database
- There isn't any data to see yet, but this is where all your Parse user's and objects will be displayed.
App Settings
General
- This is where general info about your app is displayed.
- You'll reference the "Parse API Address" when configuring the Parse SDK in your Xcode project.
Security & Keys
- You'll reference the "Application ID" and "Client Key" when configuring the Parse SDK in your Xcode project.
Configure and initialize the Parse SDK in Xcode
-
Visit the Parse iOS Docs - Getting Started Tab and scroll down to the section titled "Initialise Parse SDK"
-
In the code snippet, tap the "Swift" button to toggle the snippet to show in Swift.
-
As the description mentions, you'll need to configure the Parse SDK in the
application:didFinishLaunchingWithOptions:
method of your app'sAppDelegate.swift
file. (This is a common place for initializing stuff in your app since this method is called very early in the app's lifecycle, right after your app initializes itself).- ⚠️ Make sure you
import Parse
in any file you want to use Parse. In this case, at the top of theAppDelegate
. - ⚠️ The snippet shown in the Parse docs also includes the
application:didFinishLaunchingWithOptions:
method, however that method is already provided by default in the app delegate. So you only need to reference the part related to the configuration and initialization of Parse. Add that inside theapplication:didFinishLaunchingWithOptions:
that already exists in theAppDelegate
.
let parseConfig = ParseClientConfiguration { $0.applicationId = "parseAppId" $0.clientKey = "parseClientKey" $0.server = "parseServerUrlString" } Parse.initialize(with: parseConfig)
- You'll need to replace the
parseAppId
,parseClientKey
andparseServerUrlString
strings with the actual values from your Parse server found in the Dashboard - App Settings
- ⚠️ Make sure you
Test and confirm your server and app setup
- To test if your app is able to communicate with your Parse server, try creating and saving a parse object in your app, and verifying that the object appears in the Dashboard on your Parse server.
- Visit the Parse iOS Docs - Saving Objects tab, and check out the example snippet for saving a Parse Object (aka
PFObject
). - As the docs mention, creating and setting keys and values on a
PFObject
is quite similar to working with a SwiftDictionary
. - Add the save object snippet right after you initialize the Parse SDK in order to test it.
- Feel free to switch up any of the keys and values to help prove to yourself that things are really working as expected. It's also helpful to add print statements in the case of success or errors.
let gameScore = PFObject(className:"GameScore") gameScore["score"] = 5000 gameScore["playerName"] = "Kingsley 🐶" gameScore["cheatMode"] = true gameScore.saveInBackground { success, error in if success { print("👩🔬✅ SUCCESS! Parse object saved") } else if let error = error { print("👩🔬❌ Error saving Parse object: \(error.localizedDescription)") } else { print("👩🔬❌ Unknown error saving Parse object") } }
- Run your app check the Xcode console to see if the save was a success.
- For the final proof, head to your Parse Server Dashboard and verify that your PFObject was successfully saved in the Database section.