SlideShare una empresa de Scribd logo
1 de 57
Descargar para leer sin conexión
RESTful Design at
     Work
      Tom Marrs
       Architect
Your Profile
How?



       What?



          Where?
What’s The Point?

Interface
Design
Matters
Our Agenda

                 RESTful Web     Well-
RESTful Web                               RESTful
                   Service     Designed
   Service                                  API
                   Design      RESTful
Best Practices                            Sources
                  Guidelines     APIs
We’re Not Covering
        :(-
Security


Lots of Code


SOA


Design Patterns
RESTful Design Best
Practices - Roadmap
Determine Data Set

Business Context


Requirements


Models
Our Case Study -
   Mentoring Program
  A Relationship

6 meetings

Face-to-face or Phone

Mentoring Checklist
Mentoring Program -
   User Stories
Discover Resources

      Type                         Example

Things         Order, Member, Product

Associations   Enrollment, Membership, Marriage, Employment

Processes      Onboarding, Underwriting, Mentoring

Functions      Driving Directions, Search
Design Resources
Uniform Interface -
HTTP Methods/Verbs
HTTP Verb/
                Action
 Method
   GET            Read

   POST      Create [Update]

   PUT       Update [Create]

  DELETE         Delete
HTTP Status Codes -
     Typical
  HTTP Verb/   HTTP Status
                                  Meaning
   Method        Code
GET                200       OK
GET                404       Not Found
POST               201       Created
PUT                200       OK
PUT                404       Not Found
PUT                409       Conflict
DELETE             200       OK
DELETE             404       Not Found
DELETE             409       Conflict
HTTP Status Codes -
      Other
                      HTTP
   HTTP Verb/
                      Status                Meaning
    Method
                       Code
POST / PUT / DELETE    202     Accepted - Process request later

POST / PUT / DELETE    204     No Content

GET / PUT / DELETE     301     Moved Permanently

ALL                    400     Bad Request

ALL                    401     Unauthorized

ALL                    500     Internal Server Error
Design URIs
Of Nouns and Verbs

Nouns - Good


Verbs - Bad
Verbs - Really Bad!
/listPairs
/reviewPairStatus
/deletePair
/updateProgress
...
/getAvgWaitTimeForMember - Really??
/provideMemberFeedback
/provideMentorFeedback
Of Nouns and
Verbs ... Cont’d
Use Parameters -
Simplify Associations
Before (Update Progress)
/pairs/{pairId}/mentor/{mentorId}




After (Update Progress)
/pairs/{pairId}?mentor={mentorId}
Pagination

      API              Pagination Params

Facebook      ?offset=100&limit=25


Twitter       ?page=5&rpp=25


LinkedIn      ?start=100&count=25


Recommended   /members?offset=100&limit=25
Searching
Global
/search?q=Fred+Smith




Scoped
/search/mentors/32/feedback/q?=leader
Versioning

         API                   Sample URI

Twilio           /2012-07-11/Accounts/{AccountSid}


SalesForce.com   /services/data/v20.0/sobjects/
                 Account

Facebook         ?v=1.0


Recommended      /v2/members
Versioning ... Cont’d

          Change                        Don’t Change

Deleted / Renamed Resources New Resources

                            New HTTP Methods
Removed HTTP Methods

Different Data (same URI)   New Data Formats

                            New Attributes / Data Elements
Content Negotiation

Format               HTTP Request

         Accept Header - application/json
 JSON
         simplytoast.api/members/243.json

         Accept Header - application/xml
 XML
         simplytoast.api/members/243.xml
Error Handling

HTTP Status Codes


Error Messages?
Error Messages?
      Why or Why Not?
{
  "status" : {
    "user" : {
       "message" : "Member Fred Smith already exists."
    },
    "dev" : {
       "code" : 409,
       "message" : "Member exists. Only a DELETE or UPDATE is
possible at this point."
    }
  }
}
JSON Object Design
   - JSONPad
How to Spot a Hybrid
Reddit
Flickr
Flickr API Call

 http://api.flickr.com/services/rest/?
method=flickr.cameras.getBrandModels&brand=canon&format=json&noj
soncallback=1
Delicious
RESTful Web Service
 Design Guidelines
Alfresco


Apigee


Atlassian
Alfresco
Apigee
Atlassian
Well-Designed
     RESTful APIs
Twitter
LinkedIn
Open Library
Twilio
LinkedIn - People
Twilio - Send SMS
REST API Sources -
ProgrammableWeb
REST API Sources -
ProgrammableWeb
REST API Sources -
 BART API Docs
REST API Sources -
  BART ETA API
REST API Sources -
 BART-RESTClient
Other RESTful APIs

Groupon


GitHub
Roll Your Own
RESTful API - Dyson
Our Agenda

                 RESTful Web     Well-
RESTful Web                               RESTful
                   Service     Designed
   Service                                  API
                   Design      RESTful
Best Practices                            Sources
                  Guidelines     APIs
What’s The Point?

Interface
Design
Matters
Questions?
Tom Marrs

Architect

thomasamarrs@comcast.net

http://www.linkedin.com/in/
TomMarrs

Twitter: @TomMarrs

Skype: t.marrs
RESTful API
             Resources
Teach a Dog to REST - http://blog.apigee.com/detail/restful_api_design/

Apigee API Best Practices - http://blog.apigee.com/taglist/restful

rapi_doc - http://blogs.burnsidedigital.com/2011/12/generating-api-
documentation-with-rapi_doc/

RESTdoclet - https://github.com/IG-Group/RESTdoclet

API Evangelist - http://apievangelist.com/

The Programmable Web (API Directory) - http://
www.programmableweb.com/apis

Stormpath - http://www.stormpath.com/blog/designing-rest-json-apis
RESTful Groups
API Craft - http://groups.google.com/group/api-craft/topics



REST Discuss - http://tech.groups.yahoo.com/group/rest-discuss/
REST in Practice
RESTful Web
  Services
RESTful Web
Services Cookbook
REST API Design
  Handbook
RESTful Java with
   JAX-RS
REST API Design
   Rulebook

Más contenido relacionado

La actualidad más candente

La actualidad más candente (14)

Developers and Designers: Make Your Website Visible In Search Engines
Developers and Designers: Make Your Website Visible In Search EnginesDevelopers and Designers: Make Your Website Visible In Search Engines
Developers and Designers: Make Your Website Visible In Search Engines
 
SEO presentation By Dang HA - ECM team
SEO presentation By Dang HA - ECM teamSEO presentation By Dang HA - ECM team
SEO presentation By Dang HA - ECM team
 
Hands-on with OAuth, Facebook and the Force.com Platform
Hands-on with OAuth, Facebook and the Force.com PlatformHands-on with OAuth, Facebook and the Force.com Platform
Hands-on with OAuth, Facebook and the Force.com Platform
 
10 Steps to SEO Success
10 Steps to SEO Success 10 Steps to SEO Success
10 Steps to SEO Success
 
SharePoint Fest Chicago 2015 - Anatomy of configuring provider hosted add-in...
SharePoint Fest Chicago 2015  - Anatomy of configuring provider hosted add-in...SharePoint Fest Chicago 2015  - Anatomy of configuring provider hosted add-in...
SharePoint Fest Chicago 2015 - Anatomy of configuring provider hosted add-in...
 
SharePoint 2010 Upgrade Chalk Talk with Joel Oleson and Muhanad Omar - Teched...
SharePoint 2010 Upgrade Chalk Talk with Joel Oleson and Muhanad Omar - Teched...SharePoint 2010 Upgrade Chalk Talk with Joel Oleson and Muhanad Omar - Teched...
SharePoint 2010 Upgrade Chalk Talk with Joel Oleson and Muhanad Omar - Teched...
 
#3
#3#3
#3
 
SharePoint 2010 Failed Deployments en English y Español. 10 Pasos Para una Im...
SharePoint 2010 Failed Deployments en English y Español. 10 Pasos Para una Im...SharePoint 2010 Failed Deployments en English y Español. 10 Pasos Para una Im...
SharePoint 2010 Failed Deployments en English y Español. 10 Pasos Para una Im...
 
Symfony framework-An overview and usability for web development
Symfony framework-An overview and usability for web developmentSymfony framework-An overview and usability for web development
Symfony framework-An overview and usability for web development
 
Building Valuable RESTful APIs
Building Valuable RESTful APIsBuilding Valuable RESTful APIs
Building Valuable RESTful APIs
 
Y Boss External 20091017
Y Boss External 20091017Y Boss External 20091017
Y Boss External 20091017
 
Share point apps the good, the bad, and the pot of gold at the end of the r...
Share point apps   the good, the bad, and the pot of gold at the end of the r...Share point apps   the good, the bad, and the pot of gold at the end of the r...
Share point apps the good, the bad, and the pot of gold at the end of the r...
 
SharePoint 2010 enterprise implementation
SharePoint 2010 enterprise implementationSharePoint 2010 enterprise implementation
SharePoint 2010 enterprise implementation
 
Usable REST APIs. BCNdevcon edition.
Usable REST APIs. BCNdevcon edition. Usable REST APIs. BCNdevcon edition.
Usable REST APIs. BCNdevcon edition.
 

Similar a Restful design at work v2.0

[SharePoint Korea Conference 2013 / 강율구] Sharepoint 스마트하게 개발하기
[SharePoint Korea Conference 2013 / 강율구] Sharepoint 스마트하게 개발하기[SharePoint Korea Conference 2013 / 강율구] Sharepoint 스마트하게 개발하기
[SharePoint Korea Conference 2013 / 강율구] Sharepoint 스마트하게 개발하기
lanslote
 
Jordi Romero Api for-the-mobile-era
Jordi Romero Api for-the-mobile-eraJordi Romero Api for-the-mobile-era
Jordi Romero Api for-the-mobile-era
.toster
 

Similar a Restful design at work v2.0 (20)

APIs REST Usables con Hypermedia por Javier Ramirez, para codemotion
APIs REST Usables con Hypermedia por Javier Ramirez, para codemotionAPIs REST Usables con Hypermedia por Javier Ramirez, para codemotion
APIs REST Usables con Hypermedia por Javier Ramirez, para codemotion
 
API Design Tour: Dell
API Design Tour: DellAPI Design Tour: Dell
API Design Tour: Dell
 
Api Design and More (Friday Training at Itnig)
Api Design and More (Friday Training at Itnig)Api Design and More (Friday Training at Itnig)
Api Design and More (Friday Training at Itnig)
 
What is rest. Why is it part of the Rails way?. Railsconf 2014. Javier Ramirez
What is rest. Why is it part of the Rails way?. Railsconf 2014. Javier RamirezWhat is rest. Why is it part of the Rails way?. Railsconf 2014. Javier Ramirez
What is rest. Why is it part of the Rails way?. Railsconf 2014. Javier Ramirez
 
RESTful Web Services
RESTful Web ServicesRESTful Web Services
RESTful Web Services
 
[SharePoint Korea Conference 2013 / 강율구] Sharepoint 스마트하게 개발하기
[SharePoint Korea Conference 2013 / 강율구] Sharepoint 스마트하게 개발하기[SharePoint Korea Conference 2013 / 강율구] Sharepoint 스마트하게 개발하기
[SharePoint Korea Conference 2013 / 강율구] Sharepoint 스마트하게 개발하기
 
Jordi Romero Api for-the-mobile-era
Jordi Romero Api for-the-mobile-eraJordi Romero Api for-the-mobile-era
Jordi Romero Api for-the-mobile-era
 
Api
ApiApi
Api
 
Api testing
Api testingApi testing
Api testing
 
API Design Tour: Digital River
API Design Tour: Digital RiverAPI Design Tour: Digital River
API Design Tour: Digital River
 
API Design Tour with Digital River and Apigee - June 26th, 2012
API Design Tour with Digital River and Apigee - June 26th, 2012API Design Tour with Digital River and Apigee - June 26th, 2012
API Design Tour with Digital River and Apigee - June 26th, 2012
 
Best Practices for Architecting a Pragmatic Web API.
Best Practices for Architecting a Pragmatic Web API.Best Practices for Architecting a Pragmatic Web API.
Best Practices for Architecting a Pragmatic Web API.
 
Creating a World-Class RESTful Web Services API
Creating a World-Class RESTful Web Services APICreating a World-Class RESTful Web Services API
Creating a World-Class RESTful Web Services API
 
OpenTravel Advisory Forum 2012 REST XML Resources
OpenTravel Advisory Forum 2012 REST XML ResourcesOpenTravel Advisory Forum 2012 REST XML Resources
OpenTravel Advisory Forum 2012 REST XML Resources
 
WebApp #3 : API
WebApp #3 : APIWebApp #3 : API
WebApp #3 : API
 
Web API Test Automation Using Frisby & Node.js
Web API Test Automation Using Frisby  & Node.jsWeb API Test Automation Using Frisby  & Node.js
Web API Test Automation Using Frisby & Node.js
 
Web API Test Automation using Frisby & Node.js
Web API Test Automation using Frisby  & Node.jsWeb API Test Automation using Frisby  & Node.js
Web API Test Automation using Frisby & Node.js
 
Unerstanding and Using RESTful APIs
Unerstanding and Using RESTful APIsUnerstanding and Using RESTful APIs
Unerstanding and Using RESTful APIs
 
Integrating External APIs with WordPress
Integrating External APIs with WordPressIntegrating External APIs with WordPress
Integrating External APIs with WordPress
 
mashraqi_farhan
mashraqi_farhanmashraqi_farhan
mashraqi_farhan
 

Más de Boulder Java User's Group

Más de Boulder Java User's Group (8)

Spring insight what just happened
Spring insight   what just happenedSpring insight   what just happened
Spring insight what just happened
 
Introduction To Pentaho Kettle
Introduction To Pentaho KettleIntroduction To Pentaho Kettle
Introduction To Pentaho Kettle
 
Big Data and OSS at IBM
Big Data and OSS at IBMBig Data and OSS at IBM
Big Data and OSS at IBM
 
Json at work overview and ecosystem-v2.0
Json at work   overview and ecosystem-v2.0Json at work   overview and ecosystem-v2.0
Json at work overview and ecosystem-v2.0
 
Introduction To JavaFX 2.0
Introduction To JavaFX 2.0Introduction To JavaFX 2.0
Introduction To JavaFX 2.0
 
55 New Features in Java 7
55 New Features in Java 755 New Features in Java 7
55 New Features in Java 7
 
Watson and Open Source Tools
Watson and Open Source ToolsWatson and Open Source Tools
Watson and Open Source Tools
 
Intro to Redis
Intro to RedisIntro to Redis
Intro to Redis
 

Último

Models in Deira 0567006274 Deira Call girl Service
Models in Deira 0567006274 Deira Call girl ServiceModels in Deira 0567006274 Deira Call girl Service
Models in Deira 0567006274 Deira Call girl Service
Monica Sydney
 
Pakistani Call girls in Deira 0567006274 Deira Call girls
Pakistani Call girls in Deira 0567006274 Deira Call girlsPakistani Call girls in Deira 0567006274 Deira Call girls
Pakistani Call girls in Deira 0567006274 Deira Call girls
Monica Sydney
 
Haridwar Call Girls, 8699214473 Hot Girls Service Haridwar
Haridwar Call Girls, 8699214473 Hot Girls Service HaridwarHaridwar Call Girls, 8699214473 Hot Girls Service Haridwar
Haridwar Call Girls, 8699214473 Hot Girls Service Haridwar
ranekokila
 

Último (20)

Deira call girls 0507330913 Call girls in Deira
Deira call girls 0507330913  Call girls in DeiraDeira call girls 0507330913  Call girls in Deira
Deira call girls 0507330913 Call girls in Deira
 
Call Girls South Tripura Just Call 8617370543 Top Class Call Girl Service Ava...
Call Girls South Tripura Just Call 8617370543 Top Class Call Girl Service Ava...Call Girls South Tripura Just Call 8617370543 Top Class Call Girl Service Ava...
Call Girls South Tripura Just Call 8617370543 Top Class Call Girl Service Ava...
 
Vip Call Girls Bhubaneswar 🐱‍🏍 9777949614 Independent Escorts Service Bhubane...
Vip Call Girls Bhubaneswar 🐱‍🏍 9777949614 Independent Escorts Service Bhubane...Vip Call Girls Bhubaneswar 🐱‍🏍 9777949614 Independent Escorts Service Bhubane...
Vip Call Girls Bhubaneswar 🐱‍🏍 9777949614 Independent Escorts Service Bhubane...
 
Call Girls Bijnor Just Call 8617370543 Top Class Call Girl Service Available
Call Girls Bijnor  Just Call 8617370543 Top Class Call Girl Service AvailableCall Girls Bijnor  Just Call 8617370543 Top Class Call Girl Service Available
Call Girls Bijnor Just Call 8617370543 Top Class Call Girl Service Available
 
Call girls Service in Deira 0507330913 Deira Call girls
Call girls Service in Deira 0507330913 Deira Call girlsCall girls Service in Deira 0507330913 Deira Call girls
Call girls Service in Deira 0507330913 Deira Call girls
 
Turbhe Female Escorts 09167354423 Turbhe Escorts,Call Girls In Turbhe
Turbhe Female Escorts 09167354423  Turbhe Escorts,Call Girls In TurbheTurbhe Female Escorts 09167354423  Turbhe Escorts,Call Girls In Turbhe
Turbhe Female Escorts 09167354423 Turbhe Escorts,Call Girls In Turbhe
 
Models in Deira 0567006274 Deira Call girl Service
Models in Deira 0567006274 Deira Call girl ServiceModels in Deira 0567006274 Deira Call girl Service
Models in Deira 0567006274 Deira Call girl Service
 
Bhubaneswar🌹Call Girls Rasulgada ❤Komal 9777949614 💟 Full Trusted CALL GIRLS ...
Bhubaneswar🌹Call Girls Rasulgada ❤Komal 9777949614 💟 Full Trusted CALL GIRLS ...Bhubaneswar🌹Call Girls Rasulgada ❤Komal 9777949614 💟 Full Trusted CALL GIRLS ...
Bhubaneswar🌹Call Girls Rasulgada ❤Komal 9777949614 💟 Full Trusted CALL GIRLS ...
 
Bhubaneswar🌹Call Girls Kalpana Mesuem ❤Komal 9777949614 💟 Full Trusted CALL ...
Bhubaneswar🌹Call Girls Kalpana Mesuem  ❤Komal 9777949614 💟 Full Trusted CALL ...Bhubaneswar🌹Call Girls Kalpana Mesuem  ❤Komal 9777949614 💟 Full Trusted CALL ...
Bhubaneswar🌹Call Girls Kalpana Mesuem ❤Komal 9777949614 💟 Full Trusted CALL ...
 
Banda call girls 📞 8617370543At Low Cost Cash Payment Booking
Banda call girls 📞 8617370543At Low Cost Cash Payment BookingBanda call girls 📞 8617370543At Low Cost Cash Payment Booking
Banda call girls 📞 8617370543At Low Cost Cash Payment Booking
 
Hire 💕 8617370543 Auraiya Call Girls Service Call Girls Agency
Hire 💕 8617370543 Auraiya Call Girls Service Call Girls AgencyHire 💕 8617370543 Auraiya Call Girls Service Call Girls Agency
Hire 💕 8617370543 Auraiya Call Girls Service Call Girls Agency
 
Call girls Service Berhampur - 9332606886 Our call girls are sure to provide ...
Call girls Service Berhampur - 9332606886 Our call girls are sure to provide ...Call girls Service Berhampur - 9332606886 Our call girls are sure to provide ...
Call girls Service Berhampur - 9332606886 Our call girls are sure to provide ...
 
Pakistani Call girls in Deira 0567006274 Deira Call girls
Pakistani Call girls in Deira 0567006274 Deira Call girlsPakistani Call girls in Deira 0567006274 Deira Call girls
Pakistani Call girls in Deira 0567006274 Deira Call girls
 
Genuine 8617370543 Hot and Beautiful 💕 Gomati Escorts call Girls
Genuine 8617370543 Hot and Beautiful 💕 Gomati Escorts call GirlsGenuine 8617370543 Hot and Beautiful 💕 Gomati Escorts call Girls
Genuine 8617370543 Hot and Beautiful 💕 Gomati Escorts call Girls
 
Dahod Call Girl 📞 8617370543 Low Price Genuine Service
Dahod Call Girl 📞 8617370543 Low Price Genuine ServiceDahod Call Girl 📞 8617370543 Low Price Genuine Service
Dahod Call Girl 📞 8617370543 Low Price Genuine Service
 
Call Girls in Perumbavoor / 9332606886 Genuine Call girls with real Photos an...
Call Girls in Perumbavoor / 9332606886 Genuine Call girls with real Photos an...Call Girls in Perumbavoor / 9332606886 Genuine Call girls with real Photos an...
Call Girls in Perumbavoor / 9332606886 Genuine Call girls with real Photos an...
 
Call Girls Kozhikode - 9332606886 Our call girls are sure to provide you with...
Call Girls Kozhikode - 9332606886 Our call girls are sure to provide you with...Call Girls Kozhikode - 9332606886 Our call girls are sure to provide you with...
Call Girls Kozhikode - 9332606886 Our call girls are sure to provide you with...
 
Call girls Service Bellary - 9332606886 Rs 3000 Free Pickup & Drop Services 2...
Call girls Service Bellary - 9332606886 Rs 3000 Free Pickup & Drop Services 2...Call girls Service Bellary - 9332606886 Rs 3000 Free Pickup & Drop Services 2...
Call girls Service Bellary - 9332606886 Rs 3000 Free Pickup & Drop Services 2...
 
Haridwar Call Girls, 8699214473 Hot Girls Service Haridwar
Haridwar Call Girls, 8699214473 Hot Girls Service HaridwarHaridwar Call Girls, 8699214473 Hot Girls Service Haridwar
Haridwar Call Girls, 8699214473 Hot Girls Service Haridwar
 
Kailashahar Call Girl Whatsapp Number 📞 8617370543 | Girls Number for Friend...
Kailashahar  Call Girl Whatsapp Number 📞 8617370543 | Girls Number for Friend...Kailashahar  Call Girl Whatsapp Number 📞 8617370543 | Girls Number for Friend...
Kailashahar Call Girl Whatsapp Number 📞 8617370543 | Girls Number for Friend...
 

Restful design at work v2.0