Skip to main content

HATEOAS for REST APIs

What is HATEOAS?

HATEOAS stands for Hypermedia as the Engine of Application State which is a constraint of the REST application architecture.

REST APIs has no service definition and no formal documentation. The best REST APIs don't need any documentation.


Just like websites have navigation from one page to another, REST APIs are able to do the same using HATEOAS.


In HATEOAS the response will carry links that provide links as to where to find the related resources.


This will let clients know all the things they can do with the received response and make the response navigable.


Eg: An user object may contain the URI to itself. 



{
    "name": "John Doe",
    "links": [ {
        "rel": "self",
        "href": "http://localhost:8080/users/1"
    } ]
}
'rel' attribute here defines the relationship.

If we take a status object of a particular social network site, it could be represented as below.


{
   "title": "Hello World",
   "id": 40,
   "author": "John Doe",
   "links": [ {
                "rel": "profile",
                "href": "http://localhost:8080/profiles/1"
            } 
            {
                "rel": "comments",
                "href": "http://localhost:8080/status/40/comments"
            } ]
} 
If the client requires the link to the comments of a particular status it is included here and will help the client navigate easily without having to figure it out.

Similar to how hypertext will navigate us through websites, Hypermedia will drive the client's interaction through the application state and hence called Hypermedia as the Engine of Application State.

This approach is basically how HAL is used in APIs.[2]

When to use it?

HATEOAS is used in hypermedia-driven sites. 

A hypermedia site is a site that contains non linear information(graphics, audio, video etc.). It provides information to navigate the site's REST interfaces dynamically by including hypermedia links in the response.


This approach is not followed in SOA based systems usually as they have a fixed specification.

Why should we use it?

This approach will allow our API consumers know how to navigate through the API without any documentation and will not require them to hard code any URL to any related resource, instead it can be easily taken from the previous response.

How Paypal API uses this approach can be found at [1].

[1] https://developer.paypal.com/docs/api/hateoas-links/
[2] http://stateless.co/hal_specification.html


Comments

Popular posts from this blog

Fixing 'java RMI - ConnectException: Operation timed out' in WSO2 Enterprise Integrator 6.4

If you ever come across the below exception when running WSO2 Enterprise Integrator 6.4, here is the fix. This error occurs when you have multiple IP addresses from different networks configured in your etc/hosts as below. 10.xxx.x.xxx localhost 192.xxx.x.xxx localhost So simply, removing the unnecessary one and leaving the one of the network that you are currently connected to should resolve this issue. 10.xxx.x.xxx localhost

Student Information System - Java (SLIIT - ST2 PROJECT)

Student Information System (Github Project) This system is developed in Java and mySQL as a group project by me and 3 other members during a period of 1 month. The system allows the administrator to,  enroll students to the system  update enroll information  add/update course and degree program details  generate reports  create exams and edit relevant information  calculate gpa of the relevant exam  assign lecturers to courses  add lecturers/update details Lecturers to,  assign course grades  view their feedback  generate reports  view student / course / degree program details Students to,  view their profile  view their grading information  give feedback to lecturers   view lecturer / course / degree program details and other features. Below are some interfaces of the project. (Splash Screen) (Login) (Admin View) (Student Re...

SIMPLE BLACKJACK GAME IN JAVA (CONSOLE)

import java.util.Scanner; class BlackJack{     public static void main(String[] args)      {         int player_random1 = 100;         int player_random2 = 100;         while(player_random1 >= 12 || player_random2 >= 12  || player_random1 < 3 || player_random2 <3)         {             player_random1 = (int)(Math.random()*100);             player_random2 = (int)(Math.random()*100);         }                  int player_total = player_random1 + player_random2;                  System.out.println("You get a "+player_random1+" and a "+player_random2);         System.out.println("Your total is "+player_total); if(player_total==21)  ...