HATEOAS

Summary

Hypermedia as the Engine of Application State (HATEOAS), en español, hipermedia como motor del estado de la aplicación, es un componente de la arquitectura de aplicación REST que lo distingue de otras arquitecturas.

Con HATEOAS, un cliente interactúa con una aplicación de red cuyos servidores de aplicación proporcionan información dinámicamente a través de hipermedia. Un cliente REST necesita poco o ningún conocimiento previo sobre cómo interactuar con una aplicación o servidor más allá de un conocimiento genérico de los hipermedia.

Por contraposición, clientes y servidores en el standard CORBA interactúan a través de una interfaz fija compartida por medio de documentación o un lenguaje de descripción de interfaz (IDL).

Las restricciones impuestas por HATEOAS desacoplan el cliente del servidor. Esto permite a la funcionalidad del servidor evolucionar independientemente.

Ejemplo

editar

Un cliente REST ingresa a una aplicación REST a través de una URL fija simple. Todas las acciones futuras que el cliente pueda realizar se descubren dentro de las representaciones de recursos devueltas por el servidor. Los tipos de medios utilizados para estas representaciones y las relaciones de enlace que pueden contener están estandarizados. El cliente realiza la transición a través de los estados de la aplicación seleccionando entre los enlaces dentro de una representación o manipulando la representación de otras formas que ofrece su tipo de medio. De esta manera, la interacción RESTful es impulsada por hipermedia, en lugar de información fuera de banda.[1]

Por ejemplo, esta solicitud GET obtiene un recurso de cuenta, solicitando detalles en una representación JSON:[2]

GET /accounts/12345 HTTP/1.1
Host: bank.example.com
Accept: application/vnd.acme.account+json
...

La respuesta es:

HTTP/1.1 200 OK
Content-Type: application/vnd.acme.account+json
Content-Length: ...

{
    "account": {
        "account_number": 12345,
        "balance": {
            "currency": "usd",
            "value": 100.00
        },
        "links": {
            "deposit": "/accounts/12345/deposit",
            "withdraw": "/accounts/12345/withdraw",
            "transfer": "/accounts/12345/transfer",
            "close": "/accounts/12345/close"
        }
    }
}

La respuesta contiene estos posibles enlaces de seguimiento: realizar un depósito, retiro o transferencia, o cerrar la cuenta. Cuando la información de la cuenta se recupera más tarde, la cuenta está sobregirada:

HTTP/1.1 200 OK
Content-Type: application/vnd.acme.account+json
Content-Length: ...

{
    "account": {
        "account_number": 12345,
        "balance": {
            "currency": "usd",
            "value": -25.00
        },
        "links": {
            "deposit": "/accounts/12345/deposit"
        }
    }
}

Ahora solo hay un enlace disponible: depositar más dinero. En su estado actual, los otros enlaces no están disponibles. De ahí el término Motor de estado de aplicación, ya que las acciones que son posibles varían a medida que varía el estado del recurso.

Un cliente no necesita comprender todos los tipos de medios y mecanismos de comunicación que ofrece el servidor. La capacidad de comprender nuevos tipos de medios se puede adquirir en tiempo de ejecución a través del "código bajo demanda" que el servidor proporciona al cliente.[3]

Orígenes

editar

La restricción HATEOAS es una parte esencial de la característica de "interfaz uniforme" de REST, como se define en la tesis doctoral de Roy Fielding.[3]​ Fielding describe con más detalle el concepto en su blog.[1]

El propósito de parte del rigor de esta y otras restricciones REST, explica Fielding, es "el diseño de software en la escala de décadas: cada detalle está destinado a promover la longevidad del software y la evolución independiente". Muchas de las limitaciones se oponen directamente a la eficiencia a corto plazo. Desafortunadamente, las personas son bastante buenos en el diseño corto plazo, y por lo general horrible en el diseño a largo plazo".[1]

Véase también

editar

Referencias

editar
  1. a b c Fielding, Roy T. (20 de octubre de 2008). «REST APIs must be hypertext-driven». Consultado el 20 de mayo de 2010. 
  2. Thijssen, Joshua (29 de octubre de 2016). «What is HATEOAS and why is it important for my REST API?». REST CookBook. Consultado el 5 de febrero de 2020. 
  3. a b «Representational State Transfer (REST)». (PhD). University of California, Irvine. 2000. 
  •   Datos: Q5628978