SlideShare a Scribd company logo
How to build APIs
Target - Dan Cundiff (@pmotch) - MHacks 2016
What are APIs?
Why do companies have
them?
Building APIs
We’re really talking about
building web apps.
● We know how to test web apps
● We know how to scale web apps
● Infra-as-code
● Continuous integration
● Continuous delivery
● Immutable infrastructure
● etc
Designing APIs
Use an spec framework:
● OpenAPI (aka Swagger)
● API Blueprint
● RAML
Design-first approach using
API spec.
About REST
There is no one REST.
There are choices to make.
Collections of resources
Plural noun (let the http
method be the verb)
/cars/
5 things I can do to that
collection:
● GET /cars/v1/ - list of cars
● POST /cars/v1/ - create a car
● GET /cars/v1/{car_id} - get a car
● PUT /cars/v1/{car_id} - update a car
● DELETE /cars/v1/{car_id} - delete a car
Version after collection:
/cars/v1/
● Version your APIs
● Breaking change = new
major version
● Just follow semver.org
Filter the list:
GET /cars/v1?model=ford&color=red
For attributes that don’t
appear in the data model,
do:
GET /cars/v1/search?
some_attribute_not_included_in_data_
model=xyz
Even transactional events
are collections (e.g. sending
an email, a door opening,
etc.)
POST /door_openings/v1
● POSTs and GETs
● Give door opening event
an id
POST /inventory_updates/v1
● Avoid race conditions
● Don’t do: PUT /inventory/{item_id}
Use paging for lists of things.
Use a chosen query param
for partial responses.
Use normal http codes.
Use http caching.
Avoid:
● Avoid XML
● SOAP died in 2007
Use TLS, just do it.
istlsfastyet.com
Oauth, HMAC, basic auth.
● /cars/v1/{car_id}/owners/{owner_id}
is cool too
● Rate limiting
● Operators
API Gateways are useful.
Measure your APIs:
● Centralize logs
● Collect metrics
Monitor your APIs
You need a developer portal.
Dev portal:
● docs
● forums
● key material, etc.
Making your API public or not
Reading:
● Follow API devs on twitter
● HN, API Evangelist, InfoQ
conf vids, etc
You should come work for
Target.
Questions?

More Related Content

ODP
Seminar globalize3 - DungNV
PDF
Standing out as a new grad candidate
PPTX
Into to GraphQL
PDF
Elixir + GraphQL = Absinthe 2019.04.10
PDF
Mobile development with JBoss Tools
PPTX
React vs angular what to choose for your app
PPTX
London SDET Meetup main presentation - How SDET can transform your organisati...
PPTX
Dynamic content with Angular
Seminar globalize3 - DungNV
Standing out as a new grad candidate
Into to GraphQL
Elixir + GraphQL = Absinthe 2019.04.10
Mobile development with JBoss Tools
React vs angular what to choose for your app
London SDET Meetup main presentation - How SDET can transform your organisati...
Dynamic content with Angular

What's hot (14)

PDF
React js vs angularjs
PDF
React vs Angular, who wins the competition?
PPTX
Dimpact wim bumpy road of building reusable platform for municipalities from...
PDF
How to GraphQL
PDF
React vs angular (mobile first battle)
PPTX
Comparison of-angular-8 vs react-js
PPTX
What after BCA
PDF
Coding Dojo: Mars Rover (2014)
KEY
Railsで春から始めるtdd生活
PDF
DevOps Toolchain v1.0
PPTX
The Bleeding Edge - Whats New in Angular 2
PDF
Implementing AutoComplete for Freemarker and Velocity languages in ACE Editor
PPTX
Using Ruby in Android Development
PDF
Why angular?
React js vs angularjs
React vs Angular, who wins the competition?
Dimpact wim bumpy road of building reusable platform for municipalities from...
How to GraphQL
React vs angular (mobile first battle)
Comparison of-angular-8 vs react-js
What after BCA
Coding Dojo: Mars Rover (2014)
Railsで春から始めるtdd生活
DevOps Toolchain v1.0
The Bleeding Edge - Whats New in Angular 2
Implementing AutoComplete for Freemarker and Velocity languages in ACE Editor
Using Ruby in Android Development
Why angular?

Similar to How to Build APIs - MHacks 2016 (20)

DOCX
PPTX
Building a REST API for Longevity
PPTX
How APIs are Changing Software Development
PPTX
As Software eats the World, APIs eat Software
PDF
Past, Present and Future of APIs of Mobile and Web Apps
PDF
How to Develop APIs - Importance, Types, Tools, Terminology, and Best Practic...
PPTX
Api crash
PPTX
Api crash
PPTX
Api crash
PPTX
Api crash
PPTX
Api crash
PPTX
Api crash
PPTX
Api crash
PDF
Guide To API Development – Cost, Importance, Types, Tools, Terminology, and B...
PDF
Building RESTful APIs
PDF
Web Based APIs
PDF
Building Successful APIs Overnight - Orlando K - Codemotion Rome 2015
PPTX
The DNA of a great API
PDF
Building APIs with Node.js and MonogDB
PPTX
API's - Successes to Replicate. Pitfalls to Avoid.
Building a REST API for Longevity
How APIs are Changing Software Development
As Software eats the World, APIs eat Software
Past, Present and Future of APIs of Mobile and Web Apps
How to Develop APIs - Importance, Types, Tools, Terminology, and Best Practic...
Api crash
Api crash
Api crash
Api crash
Api crash
Api crash
Api crash
Guide To API Development – Cost, Importance, Types, Tools, Terminology, and B...
Building RESTful APIs
Web Based APIs
Building Successful APIs Overnight - Orlando K - Codemotion Rome 2015
The DNA of a great API
Building APIs with Node.js and MonogDB
API's - Successes to Replicate. Pitfalls to Avoid.

More from Dan Cundiff (7)

PPTX
Governance to Guidance to Awesome Product - DOES 2018
PDF
How Target Made It Super Easy for Developers to Contribute to Open Source - L...
PDF
From No Git to 3000 GitHub Users and How to Keep Them Happy - GitHub Universe...
PDF
Why DevOps != the Wild West and How Embracing it Can Improve Security - RSA C...
PDF
Jenkins User Conference 2014
PDF
Apache Cassandra at Target - Cassandra Summit 2014
PPTX
Splunk All the Things: Our First 3 Months Monitoring Web Service APIs - Splun...
Governance to Guidance to Awesome Product - DOES 2018
How Target Made It Super Easy for Developers to Contribute to Open Source - L...
From No Git to 3000 GitHub Users and How to Keep Them Happy - GitHub Universe...
Why DevOps != the Wild West and How Embracing it Can Improve Security - RSA C...
Jenkins User Conference 2014
Apache Cassandra at Target - Cassandra Summit 2014
Splunk All the Things: Our First 3 Months Monitoring Web Service APIs - Splun...

Recently uploaded (20)

PDF
Unlocking AI with Model Context Protocol (MCP)
PPTX
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
PDF
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
PPTX
MYSQL Presentation for SQL database connectivity
PDF
Electronic commerce courselecture one. Pdf
PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PDF
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
PDF
Network Security Unit 5.pdf for BCA BBA.
PDF
Optimiser vos workloads AI/ML sur Amazon EC2 et AWS Graviton
PPTX
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
PDF
KodekX | Application Modernization Development
PPT
“AI and Expert System Decision Support & Business Intelligence Systems”
PPTX
Understanding_Digital_Forensics_Presentation.pptx
PPTX
Spectroscopy.pptx food analysis technology
PDF
Per capita expenditure prediction using model stacking based on satellite ima...
PDF
Review of recent advances in non-invasive hemoglobin estimation
PPTX
Cloud computing and distributed systems.
PDF
Mobile App Security Testing_ A Comprehensive Guide.pdf
PPTX
ACSFv1EN-58255 AWS Academy Cloud Security Foundations.pptx
PPTX
20250228 LYD VKU AI Blended-Learning.pptx
Unlocking AI with Model Context Protocol (MCP)
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
MYSQL Presentation for SQL database connectivity
Electronic commerce courselecture one. Pdf
Advanced methodologies resolving dimensionality complications for autism neur...
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
Network Security Unit 5.pdf for BCA BBA.
Optimiser vos workloads AI/ML sur Amazon EC2 et AWS Graviton
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
KodekX | Application Modernization Development
“AI and Expert System Decision Support & Business Intelligence Systems”
Understanding_Digital_Forensics_Presentation.pptx
Spectroscopy.pptx food analysis technology
Per capita expenditure prediction using model stacking based on satellite ima...
Review of recent advances in non-invasive hemoglobin estimation
Cloud computing and distributed systems.
Mobile App Security Testing_ A Comprehensive Guide.pdf
ACSFv1EN-58255 AWS Academy Cloud Security Foundations.pptx
20250228 LYD VKU AI Blended-Learning.pptx

How to Build APIs - MHacks 2016