/redwoods-insurance

Sample car insurance app. Redwoods Insurance is a fictitious car insurance company. This application, which consists of a Salesforce Lightning Console app and a mobile application for iOS, helps agents and customers with insurance claims.

Primary LanguageSwiftCreative Commons Zero v1.0 UniversalCC0-1.0

Redwoods Car Insurance - A Salesforce Mobile SDK for iOS Sample Application

CI Workflow codecov

Redwoods Car Insurance is a fictional end-user mobile application for iOS built using Swift and the Mobile SDK for iOS. The application shows a rich user experience for an end-user on iOS while demonstrating key features of the SDK version 7.0.

Table of Contents

  1. Prerequisites
  2. Source Control Setup
  3. Salesforce Metadata Setup
  4. Salesforce Manual Setup
  5. Xcode Setup
  6. Additional Resources

Prerequisites

In order to experience, and experiment with this sample app you'll need:

  1. A working installation of Git.
  2. An Apple Computer with Xcode 10.1 (or possibly higher) installed.
  3. If you want to install the sample app on a physical iOS device, you'll need an Apple Developer Account.
  4. A Salesforce Scratch Org. (More info on that later)

Source Control Setup

This project makes use of git submodules, in addition to Xcode build dependencies to incorporate the SDK. This means you must not only clone this repository, but the submodule repositories as well. If you have not yet cloned this repository, this clone command will clone not only this repo, but the submodules as well.

git clone --recurse-submodules https://github.com/trailheadapps/redwoods-insurance.git

If you've already cloned this repository, please initialize the submodules using this command

git submodule update --init --recursive

Salesforce Metadata Setup

The redwoods-insurance-salesforce folder in this repository contains most of the necessary metadata to setup a Salesforce Scratch Org for use with this mobile app. However, there are several manual steps you must accomplish using the Salesforce UI to finalize your scratch org with this metadata:

  1. Set up your environment. Follow the steps in the Quick Start: Salesforce DX Trailhead Project.

  2. If you haven't already done so, authenticate with your dev hub org and provide it with an alias (devHub):

    sfdx auth:web:login -d -a devHub
    
  3. cd to Salesforce Org Setup folder in a command line:

    cd redwoods-insurance-salesforce
    
  4. Create a scratch org and provide it with an alias (redwoods-insurance):

    sfdx force:org:create -s -f config/project-scratch-def.json -a redwoods-insurance
    
  5. Push the app to your scratch org:

    sfdx force:source:push
    
  6. Create a new Role named redwoods-insuranceAdjuster:

    sfdx force:data:record:create -s userRole -v Name='redwoods-insuranceAdjuster'
    

    Take note of the UserRoleId that's returned, it will start with '00E'.

  7. Find the default users' ID and assign that user the new Role:

    sfdx force:user:display
    

    Identify the users' Id, it will start with '005':

  8. Set the default User's Role to the newly created role:

    sfdx force:data:record:update -s user -i <<<USER-ID>>> -v "userRoleId=<<<USER-ROLE-ID>>>"
    
  9. Assign the redwoods_insurance_mobile permission set to the default user:

    sfdx force:user:permset:assign -n redwoods_insurance_mobile
    
  10. Open your new scratch org, to the communities setup page in a web browser:

    sfdx force:org:open -p /lightning/setup/SetupNetworks/home
    

Manual steps you must take in your org

The mobile application is configured to allow only Customer Community Login users to log in. You'll need to manually setup, activate and publish a community through the UI.

  1. Create the Community:
    1. If opening the org didn't take you to the 'All Communities' setup page, navigate there via Setup -> Feature Settings -> Communities -> All Communities.
    2. Click the 'New Community' Button.
    3. Select the 'Customer Account Portal' experience.
    4. Click 'Get Started'.
    5. When prompted, enter 'Redwoods Car Insurance' as the name.
    6. Click 'Create'.
    7. Allow the community wizard to finish.
  2. Adding a Profile for community users:
    1. In the upper left-hand menu, select 'Salesforce Setup' which will open in a new tab/window.
    2. Using either the menu, or the quick find bar, navigate to Profiles:
      1. Click 'New Profile'.
      2. Select 'Customer Community Login User' as the profile to clone from.
      3. Give the profile the name 'redwoods_insurance_mobileUser'.
      4. Click 'Save'.
      5. On the newly created profile screen, click the 'Edit' button.
      6. Under 'Administrative Permissions' find the checkbox labeled: 'API Enabled' and check it.
      7. Click 'Save'.
  3. Add the profile to your Community:
    1. Navigate to your original tab -- where you're configuring your community -- and using the menu on the left, click 'Administration'.
    2. Using the menu on the left hand side of the screen, select 'Members'
    3. On the members page, use the drop down to select 'Customer' from the list of available profile groups. If you do not see 'redwoods_insurance_mobileUser' listed, please ensure you created the profile as a clone of 'Customer Community Login User' profile.
    4. Select 'redwoods_insurance_mobileUser' on the left side, and click the 'Add' button.
    5. Scroll to the bottom of the page and click 'Save'
  4. Activate the Community:
    1. Using the menu on the left, click 'Settings'.
    2. You'll see the URL of your community listed just above an 'Activate Community' button. Copy that url as you'll need it later.
    3. Click the 'Activate Community' button.
  5. Publish the Community:
    1. Using the drop-down menu in the upper left, click on the 'Builder' workspace.
    2. Click the 'Publish' button in the upper right of the Community Builder.
    3. Click 'Publish' to confirm.
  6. Create a Community User:
    1. From the Builder screen, click the upper left drop down menu, and select 'Salesforce Setup'.
    2. Using the App Launcher, select 'Service'.
    3. Click on the 'Accounts' tab, and create a new account. Populate the information as you see fit.
    4. From your newly created Account's detail page, click 'New' button on the Contacts related list view.
    5. Create a new contact.
    6. From the Account detail page, click on the name of your newly created contact to navigate to the Contact detail page.
    7. Click the disclosure icon in the upper right of the contact's Highlights Panel, and select 'Enable Customer User'.
    8. Make sure to fill in an email address you can check, as you'll need to verify your user's email before you can login.
    9. Select 'Customer Community Login' as the User License.
    10. Select 'redwoods_insurance_mobileUser' as the Profile.
    11. Populate all other required fields.
    12. Click 'Save', and click 'OK' to acknowledge that the user will receive an email.
  7. Finalize your Customer Community Login User:
    1. You'll soon receive an email from Salesforce welcoming your user to the community. Click the provided link to verify your email and set your user's password.
  8. Assign your new Customer Community Login User the 'Redwoods-Insurance Mobile' permission set:
    1. Navigate to Setup -> Users -> Permission Sets.
    2. Click on 'Redwoods-Insurance Mobile'.
    3. Click on 'Manage Assignments'.
    4. Click on 'Add Assignment'.
    5. Click the checkbox next to your Redwoods-Insurance Mobile' username.
    6. Click 'Assign'.
    7. Click 'Done'.

iOS App Setup

Note: Salesforce Communities Users can only authenticate to the community they're part of. Thus, when writing apps with the Salesforce mobile SDK for iOS it's best practice to manually set the login host for your application as part of your build.

  1. Open the file info.plist found in the 'Supporting Files' group in Xcode.
  2. Locate the key SFDCOAuthLoginHost, which by default says login.salesforce.com. Edit the default value, replacing it with the community url you copied down earlier. Please note, while the community url likely starts with https:// DO NOT include the https:// portion of the URL in this plist value.

Note: The source ships with a valid connected app consumer key. However, if you'd like to use your own, ensure it has the following oAuth scopes:

  • Access your basic information (id, profile, email, address, phone)
  • Access and manage your data (api)
    • Provide access to your data via the Web (web)
    • Access and manage your Chatter data (chatter_api)
  • Perform requests on your behalf at any time (refresh_token, offline_access)

Once you have established your connected app, copy the consumer key into the TrailIsurance/bootconfig.plist file using Xcode.

Xcode Setup

To load the project in Xcode, open the redwoods-insurance.xcodeproj file.

This project should build and run on the simulator 'out of the box' if the submodules have been properly initialized. However, if you would like to run this on a physical iOS device, you'll need to specify your Team name in the project's settings.

Note: If you're running this in the simulator, and everything seems really slow, check to ensure you've not accidentally toggled 'Slow Animations' in the Debug menu of the simulator app. It's hotkey is Cmd-t, so it can be accidentally toggled fairly easily.

Additional Resources

For more information on the Salesforce Mobile SDK for iOS check out these resources:

  1. Salesforce Mobile SDK Basics
  2. Native iOS Trailhead Module
  3. Get Started with iOS App Development
  4. Swift Essentials