SlideShare a Scribd company logo
Exploring the
Salesforce REST
API
Jay Hurst
Director, Product Management
@extraidea
Forward-Looking Statements
Statement under the Private Securities Litigation Reform Act of 1995:
This presentation may contain forward-looking statements that involve risks, uncertainties, and assumptions. If any such uncertainties
materialize or if any of the assumptions proves incorrect, the results of salesforce.com, inc. could differ materially from the results expressed or
implied by the forward-looking statements we make. All statements other than statements of historical fact could be deemed forward-looking,
including any projections of product or service availability, subscriber growth, earnings, revenues, or other financial items and any statements
regarding strategies or plans of management for future operations, statements of belief, any statements concerning new, planned, or upgraded
services or technology developments and customer contracts or use of our services.
The risks and uncertainties referred to above include – but are not limited to – risks associated with developing and delivering new functionality
for our service, new products and services, our new business model, our past operating losses, possible fluctuations in our operating results and
rate of growth, interruptions or delays in our Web hosting, breach of our security measures, the outcome of any litigation, risks associated with
completed and any possible mergers and acquisitions, the immature market in which we operate, our relatively limited operating history, our
ability to expand, retain, and motivate our employees and manage our growth, new releases of our service and successful customer
deployment, our limited history reselling non-salesforce.com products, and utilization and selling to larger enterprise customers. Further
information on potential factors that could affect the financial results of salesforce.com, inc. is included in our annual report on Form 10-K for the
most recent fiscal year and in our quarterly report on Form 10-Q for the most recent fiscal quarter. These documents and others containing
important disclosures are available on the SEC Filings section of the Investor Information section of our Web site.
Any unreleased services or features referenced in this or other presentations, press releases or public statements are not currently available
and may not be delivered on time or at all. Customers who purchase our services should make the purchase decisions based upon features that
are currently available. Salesforce.com, inc. assumes no obligation and does not intend to update these forward-looking statements.
Many customers are facing a set of challenges around
building client applications against the Salesforce REST
API.
Raise your hand if you:
• Have used the REST API in Salesforce
• Have tried to build a client application using the REST API but have
faced issues with the number of round trips
• Have a need to design efficient APIs and want to reduce the number of
API round trips to the Salesforce server
Building Streamlined APIs
Bulk
REST
Metadata
SOAP
Tooling
Streaming
INTEGRATIONLAYER
Point & Click
Integration Tools
Page
Builder
DECLARATIVE DEVELOPMENT
GLOBAL ENTERPRISE CLOUD INFRASTRUCTURE
PLATFORM SERVICES
APP MANAGEMENT & DEPLOYMENT
Workflow
Engine
UI FrameworkSharing &
Permissions
Global
Search
Reports &
Dashboards
Files
& Content
Authentication CollaborationEvent Log
Framework
Translation
Workbench
App
Builder
Process
Builder
Schema
Builder
Multi-Tenant Network
& Firewall
Auto
Updates
Backup &
Geodiversity
Security Trust
IDECLI Agile
Accelerator
Store
Builder
Dev
Console
Sandbox
Metadata
Heroku DX node.js
PROGRAMMATIC DEVELOPMENT
Database Smart
Containers
Heroku
Add-ons
Heroku
Button
Ruby
Identity
Global
Data Centers
Data
Storage
Single code
base
Python Java APEXPHP
Offline
Salesforce1 Mobile
Container Geolocation
Push
NotificationsSDK Mobile Identity
MOBILE SERVICES
Community
Builder
Page
Builder
App Cloud Gives You Tools for Building Any App
Full spectrum of capabilities from enterprise control to elastic flexibility
REST API
• Best suited for browser or mobile applications which do not
need to access high amounts of records
• Access data over REST
• XML or JSON
• Synchronous
• Authenticate with OAuth 2.0 (connected app)
https://www.salesforce.com/us/developer/docs/api_rest/
Anatomy of a REST API Call
https://na44.salesforce.com/services/data/v37.0/sobjects/Account/0010000000ABc12
Instance of Saleforce
API Type
API Version
API Subtype
Entity
Record ID
Traditional REST API Diagram
What is a Composite API?
What is a Composite API?
• An API that is built by combining existing API functions
• A single request to an API can perform multiple functions
• Orchestration of the composite APIs allow developer
controlled business logic and functionality
• Responses from one API method can be directed as inputs into another method
• Multiple APIs can be used in a single call to improve performance
• Compositions are key for designing efficient API for use in
mobile development
Salesforce Composite Resources
Batching REST Resource
• Resource which accepts multiple REST calls to execute
• A single Batch REST request can execute up to 25 sub-requests
• Sub-requests contains the resource (URI) and the method to execute
• Each sub-request is an unrelated API call
• Sub-requests are executed serially, in order, and as the running user
• As each sub-request completes, the call is committed
• Has one optional parameter
• haltOnError - indicates if the batch should stop on any error that is encountered
• The response will be a JSON object of responses from the
sub requests
Batch REST API Diagram
/services/data/v37.0/sobjects/Account
/services/data/v37.0/sobjects/Account
/services/data/v37.0/sobjects/Contact
/services/data/v37.0/sobjects/Contact
/services/data/v37.0/sobjects/Contact
/services/data/v37.0/sobjects/Case
/services/data/v37.0/sobjects/Case
/services/data/v37.0/sobjects/Task
/services/data/v37.0/sobjects/Task
/services/data/v37.0/composite/batch
Example Batch Request
{"batchRequests" : haltonerror:true, [
{"method" : "POST",
"url" : "v34.0/sobjects/account/",
"richInput" : {"Name" : "NewName", "Industry" : "Tech"}},
{"method" : "GET",
"url" : "v34.0/sobjects/account/describe/"},
{"method" : "GET",
"url" : "v34.0/query?q=select id, name, industry from
account order by createddate desc limit 10"
}]
}
Example Successful Batch Response
{"hasErrors" : false,
"results" : [{
"statusCode" : 201,
"result": {"id" : "001B0000003xiArIAI”, "success" : true, "errors" : [ ]}
},
{
"statusCode" : 200,
"result": {"actionOverrides" : [ ], "activateable" : false, ...,
"undeletable" : true, "updateable" : true}
},
{
"statusCode" : 200,
"result": {"totalSize" : 10, "done" : true,
"records" : [{
"attributes" : {"type" : "Account”, "url" : "/services/data/v34.0/
sobjects/Account/001B0000003xiArIAI”},
...
}]
}
}]
}
Example Unsuccessful Batch Response
{"hasErrors" : true,
"results" : [{
"result" : [{"message" : "Required fields are missing: [Name]”,"errorCode" :
"REQUIRED_FIELD_MISSING",
"fields" : [ "Name" ]}],
"statusCode" : 400
},{
"result”:[{"message”:"Cannot access this resource in a batch request”,
"errorCode”: "INVALID_BATCH_REQUEST”}],
"statusCode" : 400
},{
"result" : [{
"message" : "nselect ids, name, industry from accountn^nERROR at Row:
1:Column:8nNo such column 'ids' on entity 'Account'. If you are
attempting to use a custom field, be sure to append the
'__c' after the custom field name. Please reference your WSDL or
the describe call for the appropriate names.”, "errorCode" :
"INVALID_FIELD"}],
"statusCode" : 400
}]}
Batching REST API Demo
TreeSave REST Resource
• Creates SObject trees with the same top level object type
• A recursive data structure that contains a root record, its data, and its child
records represented as other sObject trees
• The REST resource manages all of the ID creations and mapping
• Create an Account, Contact, Opportunity, and Note in a single call
• The request can contain the following:
• Up to a total of 200 records across all trees
• Up to five records of different types
• SObject trees up to five levels deep
• You can create 200 top level records, by only providing the top level
TreeSave API Diagram
/services/data/v37.0/sobjects/Account
/services/data/v37.0/sobjects/Account
/services/data/v37.0/sobjects/Contact
/services/data/v37.0/sobjects/Contact
/services/data/v37.0/sobjects/Contact
/services/data/v37.0/sobjects/Case
/services/data/v37.0/sobjects/Case
/services/data/v37.0/sobjects/Task
/services/data/v37.0/sobjects/Task
/services/data/v37.0/composite/tree/Account
Using the TreeSave REST Resource
• The dev provides the record relations via a reference ID
• ReferenceId is used to link related records and to return errors
• Only Insert is supported
• Triggers, processes, and workflow rules fire separately for each of the
object levels
• EX – All triggers fire for all the top level records, then all fire for the second level
records, then third, etc…
• All records are rolled back on any error
• Error will indicate which referenceId had the error so that the developer can take
the appropriate action
Example TreeSave Request
{"records" :[
{"attributes" : {"type" : "Account", "referenceId" : "ref1"},
"name" : "SampleAccount”, "phone" : "1234567890”, "website" :
"www.salesforce.com", "numberOfEmployees”: "100”, "type" : "Analyst”,
"industry" : "Banking",
"Contacts" : {
"records" : [
{"attributes" : {"type" : "Contact", "referenceId" : "ref2"},
"lastname" : "Smith”, "title" : "President”, "email" :
"sample@salesforce.com" },
{"attributes" : {"type" : "Contact", "referenceId" : "ref3"},
"lastname" : "Evans”, "title" : "Vice President”, "email" :
"sample@salesforce.com”}]
}},
{"attributes" : {"type" : "Account", "referenceId" : "ref4"},
"name”: "SampleAccount2”, "phone”: "1234567890”, "website" :
"www.salesforce2.com", "numberOfEmployees”: "100”, "type" : "Analyst”,
"industry" : "Banking”}]
}
Example Successful TreeSave Response
{
"hasErrors" : false,
"results" : [ {
"referenceId" : "ref1",
"id" : "001B0000003xiAwIAI"
}, {
"referenceId" : "ref4",
"id" : "001B0000003xiAxIAI"
}, {
"referenceId" : "ref2",
"id" : "003B0000003l3L5IAI"
}, {
"referenceId" : "ref3",
"id" : "003B0000003l3L6IAI"
} ]
}
Example Unsuccessful TreeSave Response
{
"hasErrors" : true,
"results" : [ {
"referenceId" : "ref4",
"errors" : [ {
"statusCode" : "REQUIRED_FIELD_MISSING",
"message" : "Required fields are missing: [Name]",
"fields" : [ "Name" ]
} ]
} ]
}
TreeSave REST API Demo
Current Composite APIs on Salesforce
• There are a number of existing Composite resources
• The Batching REST resource allows for the sending of multiple REST calls in a
single round trip
• The calls are unrelated, simply reduces round trips
• The TreeSave REST resource allows creation of multiple records in a single call
• Limited to insert and all-or-none saves
• Apex REST can be used to build custom logic
• Requires complete design by the developer
Building a Composite API on Salesforce
• A new API which will be a combination of Batch and
TreeSave
• Outputs from one API call can be Inputs into another using the developer
assigned referenceId
• Ex - @Account1.id can be used in a later query, as a reference field, or in an action
• Friendly URLs will assist in navigating the resource hierarchy
• Ability to crawl the resource tree easily
• Ex - /services/data/v36.0/sobjects/Account/001X00000000123/Contacts will give you a list
of all Contacts on a the designated Account
• This will allow multiple CRUD operations to collections
• This will allow a simple layer of orchestration to the REST API
Composite REST API Diagram
/services/data/v37.0/sobjects/Account
/services/data/v37.0/sobjects/Account
/services/data/v37.0/sobjects/Contact
/services/data/v37.0/sobjects/Contact
/services/data/v37.0/sobjects/Case
/services/data/v37.0/sobjects/Case
/services/data/v37.0/sobjects/Task
/services/data/v37.0/sobjects/Task
/services/data/v37.0/query/?q=select id
from account limit 4
/services/data/v37.0/sobjects/Case/describ
e
/services/data/v37.0/tree/Account
Query
Describe
Composite API Request
{"compositeRequest" : [{
"type" : "rest", "method" : "POST",
"url" : "/v30.0/sobjects/Account",
"referenceId" : "Account1",
"richInput" : {"Name" : "Salesforce"}
},{
"type" : "rest", "method" : "PATCH",
"referenceId" : "Contact1",
"url" : "/v30.0/sobjects/Contact/0030000000AB3d",
"richInput" : {"accountId" : "@{Account1.Id}"}
},{
"type" : "rest", "method" : "GET",
"referenceId" : "ContactsOfAccount1",
"url" : "/v30.0/sobjects/Account/@{Account1.Id}/Contacts"
}]}
Example Successful Composite Response
[{
"id" : "001B000000E8mNSIAZ",
"success" : true,
"errors" : [ ]
},
null,
{
"totalSize" : 1,
"done" : true,
"records" : [ {
"attributes" : {
"type" : "Contact",
"url" : "/services/data/v37.0/sobjects/Contact/003B0000006dUZMIA2"
},
"Id" : "003B0000006dUZMIA2",
…
} ]
} ]
Composite API Demo
What did we Learn?
• What is the Salesforce REST API
• Existing Features that begin to support
composite actions
• Batching API
• TreeSave API
• Composite API
• Demos of existing resources
Q&A
thank y u

More Related Content

PPTX
Salesforce Development Best Practices
PPT
Salesforce Integration
PPT
Salesforce REST API
PDF
Best Practices with Apex in 2022.pdf
PPTX
Salesforce Integration Patterns
PPT
Salesforce Presentation
PPTX
Salesforce Integration Pattern Overview
PPTX
Introduction to lightning Web Component
Salesforce Development Best Practices
Salesforce Integration
Salesforce REST API
Best Practices with Apex in 2022.pdf
Salesforce Integration Patterns
Salesforce Presentation
Salesforce Integration Pattern Overview
Introduction to lightning Web Component

What's hot (20)

PDF
Lwc presentation
PDF
Introduction to the Salesforce Security Model
PDF
Introduction to Apex Triggers
PDF
All About Test Class in #Salesforce
PDF
Two-Way Integration with Writable External Objects
PPTX
Apex Trigger in Salesforce
PDF
Salesforce Winter ’23 Release Highlights
PPTX
Data model in salesforce
PDF
Getting started with Salesforce security
PPTX
Salesforce integration best practices columbus meetup
PPTX
Introduction to Salesforce Platform - Basic
PPTX
Salesforce Cross-Cloud Architecture
PPT
Security and Your Salesforce Org
PDF
Introduction to Salesforce | Salesforce Tutorial for Beginners | Salesforce T...
PPTX
Integrating with salesforce
PPTX
SOQL in salesforce || Salesforce Object Query Language || Salesforce
PPTX
Salesforce data model
PPTX
Apex code (Salesforce)
ODP
Relationships in Salesforce
PDF
Salesforce Training For Beginners | Salesforce Tutorial | Salesforce Training...
Lwc presentation
Introduction to the Salesforce Security Model
Introduction to Apex Triggers
All About Test Class in #Salesforce
Two-Way Integration with Writable External Objects
Apex Trigger in Salesforce
Salesforce Winter ’23 Release Highlights
Data model in salesforce
Getting started with Salesforce security
Salesforce integration best practices columbus meetup
Introduction to Salesforce Platform - Basic
Salesforce Cross-Cloud Architecture
Security and Your Salesforce Org
Introduction to Salesforce | Salesforce Tutorial for Beginners | Salesforce T...
Integrating with salesforce
SOQL in salesforce || Salesforce Object Query Language || Salesforce
Salesforce data model
Apex code (Salesforce)
Relationships in Salesforce
Salesforce Training For Beginners | Salesforce Tutorial | Salesforce Training...
Ad

Viewers also liked (20)

PPTX
Using Apex for REST Integration
PDF
SalesForce WebServices part 2
PDF
Secure Salesforce: External App Integrations
PPT
Advanced Platform Series - OAuth and Social Authentication
PPTX
Lighting up the Bay, Real-World App Cloud
PPTX
Lightning Developer Experience, Eclipse IDE Evolved
PPTX
Introduction to the Wave Platform API
PPTX
Introduction to Apex for Developers
PPTX
Process Automation on Lightning Platform Workshop
PPTX
REST API in Salesforce
PPTX
Mastering the Lightning Framework - Part 2
PDF
SLDS and Lightning Components
PPTX
Mastering the Lightning Framework - Part 1
PPTX
Build, Manage, and Deploy Mobile Apps Faster with App Cloud Mobile
PDF
Javascript Security and Lightning Locker Service
PPTX
Unleash the Power of Apex Realtime Debugger
PPTX
Reinvent your App Dev Lifecycle with Continuous Delivery on Heroku
PPTX
Snap-in Service to Web and Mobile Apps
PPTX
Building apps faster with lightning and winter '17
PPTX
Lightning Experience with Visualforce Best Practices
Using Apex for REST Integration
SalesForce WebServices part 2
Secure Salesforce: External App Integrations
Advanced Platform Series - OAuth and Social Authentication
Lighting up the Bay, Real-World App Cloud
Lightning Developer Experience, Eclipse IDE Evolved
Introduction to the Wave Platform API
Introduction to Apex for Developers
Process Automation on Lightning Platform Workshop
REST API in Salesforce
Mastering the Lightning Framework - Part 2
SLDS and Lightning Components
Mastering the Lightning Framework - Part 1
Build, Manage, and Deploy Mobile Apps Faster with App Cloud Mobile
Javascript Security and Lightning Locker Service
Unleash the Power of Apex Realtime Debugger
Reinvent your App Dev Lifecycle with Continuous Delivery on Heroku
Snap-in Service to Web and Mobile Apps
Building apps faster with lightning and winter '17
Lightning Experience with Visualforce Best Practices
Ad

Similar to Exploring the Salesforce REST API (20)

PDF
Building towards a Composite API Framework in Salesforce
PDF
Boxcars and Cabooses: When one more XHR is too much - Peter Chittum - Codemot...
PPTX
All Aboard the Boxcar! Going Beyond the Basics of REST
PDF
Enterprise API New Features and Roadmap
PPTX
New Powerful API Enhancements for Summer '15
PDF
Designing Custom REST and SOAP Interfaces on Force.com
PPTX
February 2020 Salesforce API Review
PPT
Designing custom REST and SOAP interfaces on Force.com
PDF
Sharing APIs at Scale for a Great Developer Experience
PPTX
Replicating One Billion Records with Minimal API Usage
PPTX
SFDC REST API
PDF
Getting Started With Apex REST Services
POTX
Using the Google SOAP API
PPTX
Navi Mumbai Salesforce DUG meetup on integration
PDF
Boxcars and Cabooses: When One More XHR Is Too Much
PDF
[MBF2] Webinar plate-forme Salesforce #1
PDF
[MBF2] Webinar plate-forme Salesforce #1
DOCX
Salesforce Integration
PPTX
The Power of Salesforce APIs World Tour Edition
PDF
How One Billion Salesforce records Can Be Replicated with Minimal API Usage
Building towards a Composite API Framework in Salesforce
Boxcars and Cabooses: When one more XHR is too much - Peter Chittum - Codemot...
All Aboard the Boxcar! Going Beyond the Basics of REST
Enterprise API New Features and Roadmap
New Powerful API Enhancements for Summer '15
Designing Custom REST and SOAP Interfaces on Force.com
February 2020 Salesforce API Review
Designing custom REST and SOAP interfaces on Force.com
Sharing APIs at Scale for a Great Developer Experience
Replicating One Billion Records with Minimal API Usage
SFDC REST API
Getting Started With Apex REST Services
Using the Google SOAP API
Navi Mumbai Salesforce DUG meetup on integration
Boxcars and Cabooses: When One More XHR Is Too Much
[MBF2] Webinar plate-forme Salesforce #1
[MBF2] Webinar plate-forme Salesforce #1
Salesforce Integration
The Power of Salesforce APIs World Tour Edition
How One Billion Salesforce records Can Be Replicated with Minimal API Usage

More from Salesforce Developers (20)

PDF
Sample Gallery: Reference Code and Best Practices for Salesforce Developers
PDF
Maximizing Salesforce Lightning Experience and Lightning Component Performance
PDF
Local development with Open Source Base Components
PPTX
TrailheaDX India : Developer Highlights
PDF
Why developers shouldn’t miss TrailheaDX India
PPTX
CodeLive: Build Lightning Web Components faster with Local Development
PPTX
CodeLive: Converting Aura Components to Lightning Web Components
PPTX
Enterprise-grade UI with open source Lightning Web Components
PPTX
TrailheaDX and Summer '19: Developer Highlights
PDF
Live coding with LWC
PDF
Lightning web components - Episode 4 : Security and Testing
PDF
LWC Episode 3- Component Communication and Aura Interoperability
PDF
Lightning web components episode 2- work with salesforce data
PDF
Lightning web components - Episode 1 - An Introduction
PDF
Migrating CPQ to Advanced Calculator and JSQCP
PDF
Scale with Large Data Volumes and Big Objects in Salesforce
PDF
Replicate Salesforce Data in Real Time with Change Data Capture
PDF
Modern Development with Salesforce DX
PDF
Get Into Lightning Flow Development
PDF
Integrate CMS Content Into Lightning Communities with CMS Connect
Sample Gallery: Reference Code and Best Practices for Salesforce Developers
Maximizing Salesforce Lightning Experience and Lightning Component Performance
Local development with Open Source Base Components
TrailheaDX India : Developer Highlights
Why developers shouldn’t miss TrailheaDX India
CodeLive: Build Lightning Web Components faster with Local Development
CodeLive: Converting Aura Components to Lightning Web Components
Enterprise-grade UI with open source Lightning Web Components
TrailheaDX and Summer '19: Developer Highlights
Live coding with LWC
Lightning web components - Episode 4 : Security and Testing
LWC Episode 3- Component Communication and Aura Interoperability
Lightning web components episode 2- work with salesforce data
Lightning web components - Episode 1 - An Introduction
Migrating CPQ to Advanced Calculator and JSQCP
Scale with Large Data Volumes and Big Objects in Salesforce
Replicate Salesforce Data in Real Time with Change Data Capture
Modern Development with Salesforce DX
Get Into Lightning Flow Development
Integrate CMS Content Into Lightning Communities with CMS Connect

Recently uploaded (20)

PDF
How to Choose the Right IT Partner for Your Business in Malaysia
PDF
Odoo Companies in India – Driving Business Transformation.pdf
PPTX
Transform Your Business with a Software ERP System
PPTX
L1 - Introduction to python Backend.pptx
PPTX
Agentic AI Use Case- Contract Lifecycle Management (CLM).pptx
PDF
top salesforce developer skills in 2025.pdf
PPTX
CHAPTER 2 - PM Management and IT Context
PDF
Nekopoi APK 2025 free lastest update
PPTX
Odoo POS Development Services by CandidRoot Solutions
PPTX
CHAPTER 12 - CYBER SECURITY AND FUTURE SKILLS (1) (1).pptx
PPTX
ManageIQ - Sprint 268 Review - Slide Deck
PDF
Understanding Forklifts - TECH EHS Solution
PDF
Design an Analysis of Algorithms II-SECS-1021-03
PPTX
ai tools demonstartion for schools and inter college
PDF
Design an Analysis of Algorithms I-SECS-1021-03
PPTX
Oracle E-Business Suite: A Comprehensive Guide for Modern Enterprises
PDF
Internet Downloader Manager (IDM) Crack 6.42 Build 41
PPTX
Online Work Permit System for Fast Permit Processing
PDF
PTS Company Brochure 2025 (1).pdf.......
PDF
System and Network Administration Chapter 2
How to Choose the Right IT Partner for Your Business in Malaysia
Odoo Companies in India – Driving Business Transformation.pdf
Transform Your Business with a Software ERP System
L1 - Introduction to python Backend.pptx
Agentic AI Use Case- Contract Lifecycle Management (CLM).pptx
top salesforce developer skills in 2025.pdf
CHAPTER 2 - PM Management and IT Context
Nekopoi APK 2025 free lastest update
Odoo POS Development Services by CandidRoot Solutions
CHAPTER 12 - CYBER SECURITY AND FUTURE SKILLS (1) (1).pptx
ManageIQ - Sprint 268 Review - Slide Deck
Understanding Forklifts - TECH EHS Solution
Design an Analysis of Algorithms II-SECS-1021-03
ai tools demonstartion for schools and inter college
Design an Analysis of Algorithms I-SECS-1021-03
Oracle E-Business Suite: A Comprehensive Guide for Modern Enterprises
Internet Downloader Manager (IDM) Crack 6.42 Build 41
Online Work Permit System for Fast Permit Processing
PTS Company Brochure 2025 (1).pdf.......
System and Network Administration Chapter 2

Exploring the Salesforce REST API

  • 1. Exploring the Salesforce REST API Jay Hurst Director, Product Management @extraidea
  • 2. Forward-Looking Statements Statement under the Private Securities Litigation Reform Act of 1995: This presentation may contain forward-looking statements that involve risks, uncertainties, and assumptions. If any such uncertainties materialize or if any of the assumptions proves incorrect, the results of salesforce.com, inc. could differ materially from the results expressed or implied by the forward-looking statements we make. All statements other than statements of historical fact could be deemed forward-looking, including any projections of product or service availability, subscriber growth, earnings, revenues, or other financial items and any statements regarding strategies or plans of management for future operations, statements of belief, any statements concerning new, planned, or upgraded services or technology developments and customer contracts or use of our services. The risks and uncertainties referred to above include – but are not limited to – risks associated with developing and delivering new functionality for our service, new products and services, our new business model, our past operating losses, possible fluctuations in our operating results and rate of growth, interruptions or delays in our Web hosting, breach of our security measures, the outcome of any litigation, risks associated with completed and any possible mergers and acquisitions, the immature market in which we operate, our relatively limited operating history, our ability to expand, retain, and motivate our employees and manage our growth, new releases of our service and successful customer deployment, our limited history reselling non-salesforce.com products, and utilization and selling to larger enterprise customers. Further information on potential factors that could affect the financial results of salesforce.com, inc. is included in our annual report on Form 10-K for the most recent fiscal year and in our quarterly report on Form 10-Q for the most recent fiscal quarter. These documents and others containing important disclosures are available on the SEC Filings section of the Investor Information section of our Web site. Any unreleased services or features referenced in this or other presentations, press releases or public statements are not currently available and may not be delivered on time or at all. Customers who purchase our services should make the purchase decisions based upon features that are currently available. Salesforce.com, inc. assumes no obligation and does not intend to update these forward-looking statements.
  • 3. Many customers are facing a set of challenges around building client applications against the Salesforce REST API. Raise your hand if you: • Have used the REST API in Salesforce • Have tried to build a client application using the REST API but have faced issues with the number of round trips • Have a need to design efficient APIs and want to reduce the number of API round trips to the Salesforce server Building Streamlined APIs
  • 4. Bulk REST Metadata SOAP Tooling Streaming INTEGRATIONLAYER Point & Click Integration Tools Page Builder DECLARATIVE DEVELOPMENT GLOBAL ENTERPRISE CLOUD INFRASTRUCTURE PLATFORM SERVICES APP MANAGEMENT & DEPLOYMENT Workflow Engine UI FrameworkSharing & Permissions Global Search Reports & Dashboards Files & Content Authentication CollaborationEvent Log Framework Translation Workbench App Builder Process Builder Schema Builder Multi-Tenant Network & Firewall Auto Updates Backup & Geodiversity Security Trust IDECLI Agile Accelerator Store Builder Dev Console Sandbox Metadata Heroku DX node.js PROGRAMMATIC DEVELOPMENT Database Smart Containers Heroku Add-ons Heroku Button Ruby Identity Global Data Centers Data Storage Single code base Python Java APEXPHP Offline Salesforce1 Mobile Container Geolocation Push NotificationsSDK Mobile Identity MOBILE SERVICES Community Builder Page Builder App Cloud Gives You Tools for Building Any App Full spectrum of capabilities from enterprise control to elastic flexibility
  • 5. REST API • Best suited for browser or mobile applications which do not need to access high amounts of records • Access data over REST • XML or JSON • Synchronous • Authenticate with OAuth 2.0 (connected app) https://www.salesforce.com/us/developer/docs/api_rest/
  • 6. Anatomy of a REST API Call https://na44.salesforce.com/services/data/v37.0/sobjects/Account/0010000000ABc12 Instance of Saleforce API Type API Version API Subtype Entity Record ID
  • 8. What is a Composite API?
  • 9. What is a Composite API? • An API that is built by combining existing API functions • A single request to an API can perform multiple functions • Orchestration of the composite APIs allow developer controlled business logic and functionality • Responses from one API method can be directed as inputs into another method • Multiple APIs can be used in a single call to improve performance • Compositions are key for designing efficient API for use in mobile development
  • 11. Batching REST Resource • Resource which accepts multiple REST calls to execute • A single Batch REST request can execute up to 25 sub-requests • Sub-requests contains the resource (URI) and the method to execute • Each sub-request is an unrelated API call • Sub-requests are executed serially, in order, and as the running user • As each sub-request completes, the call is committed • Has one optional parameter • haltOnError - indicates if the batch should stop on any error that is encountered • The response will be a JSON object of responses from the sub requests
  • 12. Batch REST API Diagram /services/data/v37.0/sobjects/Account /services/data/v37.0/sobjects/Account /services/data/v37.0/sobjects/Contact /services/data/v37.0/sobjects/Contact /services/data/v37.0/sobjects/Contact /services/data/v37.0/sobjects/Case /services/data/v37.0/sobjects/Case /services/data/v37.0/sobjects/Task /services/data/v37.0/sobjects/Task /services/data/v37.0/composite/batch
  • 13. Example Batch Request {"batchRequests" : haltonerror:true, [ {"method" : "POST", "url" : "v34.0/sobjects/account/", "richInput" : {"Name" : "NewName", "Industry" : "Tech"}}, {"method" : "GET", "url" : "v34.0/sobjects/account/describe/"}, {"method" : "GET", "url" : "v34.0/query?q=select id, name, industry from account order by createddate desc limit 10" }] }
  • 14. Example Successful Batch Response {"hasErrors" : false, "results" : [{ "statusCode" : 201, "result": {"id" : "001B0000003xiArIAI”, "success" : true, "errors" : [ ]} }, { "statusCode" : 200, "result": {"actionOverrides" : [ ], "activateable" : false, ..., "undeletable" : true, "updateable" : true} }, { "statusCode" : 200, "result": {"totalSize" : 10, "done" : true, "records" : [{ "attributes" : {"type" : "Account”, "url" : "/services/data/v34.0/ sobjects/Account/001B0000003xiArIAI”}, ... }] } }] }
  • 15. Example Unsuccessful Batch Response {"hasErrors" : true, "results" : [{ "result" : [{"message" : "Required fields are missing: [Name]”,"errorCode" : "REQUIRED_FIELD_MISSING", "fields" : [ "Name" ]}], "statusCode" : 400 },{ "result”:[{"message”:"Cannot access this resource in a batch request”, "errorCode”: "INVALID_BATCH_REQUEST”}], "statusCode" : 400 },{ "result" : [{ "message" : "nselect ids, name, industry from accountn^nERROR at Row: 1:Column:8nNo such column 'ids' on entity 'Account'. If you are attempting to use a custom field, be sure to append the '__c' after the custom field name. Please reference your WSDL or the describe call for the appropriate names.”, "errorCode" : "INVALID_FIELD"}], "statusCode" : 400 }]}
  • 17. TreeSave REST Resource • Creates SObject trees with the same top level object type • A recursive data structure that contains a root record, its data, and its child records represented as other sObject trees • The REST resource manages all of the ID creations and mapping • Create an Account, Contact, Opportunity, and Note in a single call • The request can contain the following: • Up to a total of 200 records across all trees • Up to five records of different types • SObject trees up to five levels deep • You can create 200 top level records, by only providing the top level
  • 19. Using the TreeSave REST Resource • The dev provides the record relations via a reference ID • ReferenceId is used to link related records and to return errors • Only Insert is supported • Triggers, processes, and workflow rules fire separately for each of the object levels • EX – All triggers fire for all the top level records, then all fire for the second level records, then third, etc… • All records are rolled back on any error • Error will indicate which referenceId had the error so that the developer can take the appropriate action
  • 20. Example TreeSave Request {"records" :[ {"attributes" : {"type" : "Account", "referenceId" : "ref1"}, "name" : "SampleAccount”, "phone" : "1234567890”, "website" : "www.salesforce.com", "numberOfEmployees”: "100”, "type" : "Analyst”, "industry" : "Banking", "Contacts" : { "records" : [ {"attributes" : {"type" : "Contact", "referenceId" : "ref2"}, "lastname" : "Smith”, "title" : "President”, "email" : "sample@salesforce.com" }, {"attributes" : {"type" : "Contact", "referenceId" : "ref3"}, "lastname" : "Evans”, "title" : "Vice President”, "email" : "sample@salesforce.com”}] }}, {"attributes" : {"type" : "Account", "referenceId" : "ref4"}, "name”: "SampleAccount2”, "phone”: "1234567890”, "website" : "www.salesforce2.com", "numberOfEmployees”: "100”, "type" : "Analyst”, "industry" : "Banking”}] }
  • 21. Example Successful TreeSave Response { "hasErrors" : false, "results" : [ { "referenceId" : "ref1", "id" : "001B0000003xiAwIAI" }, { "referenceId" : "ref4", "id" : "001B0000003xiAxIAI" }, { "referenceId" : "ref2", "id" : "003B0000003l3L5IAI" }, { "referenceId" : "ref3", "id" : "003B0000003l3L6IAI" } ] }
  • 22. Example Unsuccessful TreeSave Response { "hasErrors" : true, "results" : [ { "referenceId" : "ref4", "errors" : [ { "statusCode" : "REQUIRED_FIELD_MISSING", "message" : "Required fields are missing: [Name]", "fields" : [ "Name" ] } ] } ] }
  • 24. Current Composite APIs on Salesforce • There are a number of existing Composite resources • The Batching REST resource allows for the sending of multiple REST calls in a single round trip • The calls are unrelated, simply reduces round trips • The TreeSave REST resource allows creation of multiple records in a single call • Limited to insert and all-or-none saves • Apex REST can be used to build custom logic • Requires complete design by the developer
  • 25. Building a Composite API on Salesforce • A new API which will be a combination of Batch and TreeSave • Outputs from one API call can be Inputs into another using the developer assigned referenceId • Ex - @Account1.id can be used in a later query, as a reference field, or in an action • Friendly URLs will assist in navigating the resource hierarchy • Ability to crawl the resource tree easily • Ex - /services/data/v36.0/sobjects/Account/001X00000000123/Contacts will give you a list of all Contacts on a the designated Account • This will allow multiple CRUD operations to collections • This will allow a simple layer of orchestration to the REST API
  • 26. Composite REST API Diagram /services/data/v37.0/sobjects/Account /services/data/v37.0/sobjects/Account /services/data/v37.0/sobjects/Contact /services/data/v37.0/sobjects/Contact /services/data/v37.0/sobjects/Case /services/data/v37.0/sobjects/Case /services/data/v37.0/sobjects/Task /services/data/v37.0/sobjects/Task /services/data/v37.0/query/?q=select id from account limit 4 /services/data/v37.0/sobjects/Case/describ e /services/data/v37.0/tree/Account Query Describe
  • 27. Composite API Request {"compositeRequest" : [{ "type" : "rest", "method" : "POST", "url" : "/v30.0/sobjects/Account", "referenceId" : "Account1", "richInput" : {"Name" : "Salesforce"} },{ "type" : "rest", "method" : "PATCH", "referenceId" : "Contact1", "url" : "/v30.0/sobjects/Contact/0030000000AB3d", "richInput" : {"accountId" : "@{Account1.Id}"} },{ "type" : "rest", "method" : "GET", "referenceId" : "ContactsOfAccount1", "url" : "/v30.0/sobjects/Account/@{Account1.Id}/Contacts" }]}
  • 28. Example Successful Composite Response [{ "id" : "001B000000E8mNSIAZ", "success" : true, "errors" : [ ] }, null, { "totalSize" : 1, "done" : true, "records" : [ { "attributes" : { "type" : "Contact", "url" : "/services/data/v37.0/sobjects/Contact/003B0000006dUZMIA2" }, "Id" : "003B0000006dUZMIA2", … } ] } ]
  • 30. What did we Learn? • What is the Salesforce REST API • Existing Features that begin to support composite actions • Batching API • TreeSave API • Composite API • Demos of existing resources
  • 31. Q&A