How to design an API: best practises, concepts, technical aspects

When I started to design Piwik I read a lot about APIs, software architecture, service oriented architecture (soa), etc. I really wanted to design a modular architecture that would make it easy to request any data and perform any action from outside the user interface.

Technically speaking, Piwik has been built on the top of Apis. Everything that does some logic in Piwik is available through an API. We basically open all these APIs via a REST API. Of course you must authenticate for some calls eg. when deleting a user. In ther user interface, the AJAX requests are directed to the API module that returns data in HTML or JSON format (javascript friendly).

Main concepts I tried to apply when designing the API:

  • Easy to learn ; the documentation provides simple examples, complete documentation
  • Easy to use ; single entry point, standard parameters
  • Hard to misuse ; explicit error message suggesting parameters values
  • Appropriate to audience ; I had chats about such a service with several phpmyvisites users, and I looked at what the competition was offering

Interesting resources that helped me have a better understanding of the topic:

Of course to design a good API you should have a look at existing APIs, and even use some of them:

If you have good resources or advice, feel free to post a comment

This entry was posted on Saturday, January 19th, 2008 ; category Documentation ; RSS comments.

4 Responses to “How to design an API: best practises, concepts, technical aspects”

  1. zoqaa Says:

    Some information about google search api?

  2. SCE Says:

    Very useful information :) I see there are realy good tips. I am going to use some of them

  3. feporarne Says:

    What we need in this country, instead of Daylight Savings Time, which nobody
    really understands anyway, is a new concept called Weekday Morning Time,
    whereby at 7 a.m. every weekday we go into a space-launch-style “hold” for
    two to three hours, during which it just remains 7 a.m. This way we could
    all wake up via a civilized gradual process of stretching and belching and
    scratching, and it would still be only 7 a.m. when we were ready to actually
    emerge from bed.
    – Dave Barry, “$#$%#^%!^%&@%@!”

    —————————————————————————————————-
    http://xanga.com/antoinehickmankz

  4. Cordless Electric Lawnmower Says:

    Cordless Electric Lawnmower…

    Lawnmower, Cordless Electric Lawnmower and Cordless…

Leave a Reply

Entries (RSS)