APIs

En la web

¿Qué es una API?

  • Interfaz de programación de aplicaciones
  • Representa la capacidad de comunicación entre componentes de software
  •  Y permiten la expansión de nuestros propios sistemas

En otras palabras

Una API es al programador lo que la GUI al usuario.

 

Es vital, al momento de abstraer partes de un software.

¿Por qué necesito una API?

  • Fomenta el paradigma SOA
  • Añade una capa de seguridad a nuestros datos y sistemas
  • Permite la escalabilidad de nuestros sistemas
  • Añade capas de abstracción, etc.

APIs en la web

Son publicadas por los constructores de software para permitir acceso a características de bajo nivel o propietarias.

Son utilizadas por los programadores para construir sus aplicaciones sin necesidad de volver a programar funciones ya hechas por otros, reutilizando código que se sabe que está probado y que funciona correctamente.

 

¿Qué necesita una API?

  • Un formato de salida
  • Un sistema de autenticación/autorización
  • Un conjunto de recursos
  • Una conexión a una base de datos (NoSQL a veces)

XML

HTML
YAML...y otros lenguajes de marcado

JSON, CSON y otros formatos

  • Menos es mas
  • Es muy fácil definir objetos
  • Ocupa poco espacio
[
    {
       "Nombre":"Estuardo",
       "Apellido":"Díaz",
       "NombreCompleto":"Estuardo Díaz",
       "Username":"t4r0_o",
       "FechaDeAlta":"10-10-2012",
       "Seguidores":5,
       "Siguiendo":8
    },

    {    
       "Nombre":"Juan",
       "Apellido":"Perez",
       "NombreCompleto":"Juan Perez",
       "Username":"Mr.John",
       "FechaDeAlta":"8-11-2012",
       "Seguidores":1,
       "Siguiendo":45
    }
]
<?xml version="1.0"?>
<root>
 <Usuarios>
     <Usuario>
      <Nombre>Estuardo</Nombre>
      <Apellido>Díaz</Apellido>
      <NombreCompleto>Estuardo Díaz</NombreCompleto>
      <Username>t4r0_o</Username>
      <FechaDeAlta>10-10-2012</FechaDeAlta>
      <Seguidores>5</Seguidores>
      <Siguiendo>8</Siguiendo>
     </Usuario>
     <Usuario>
      <Nombre>Juan</Nombre>
      <Apellido>Perez</Apellido>
      <NombreCompleto>Juan Perez</NombreCompleto>
      <Username>Mr.Jhon</Username>
      <FechaDeAlta>8-11-2012</FechaDeAlta>
      <Seguidores>1</Seguidores>
      <Siguiendo>45</Siguiendo>
     </Usuario>
</Usuarios>
</root>

OAuth

Es un protocolo abierto, propuesto por Blaine Cook y Chris Messina, que permite autorización segura de una API de modo estándar y simple para aplicaciones de escritorio, móviles y web.

Un servicio y el RESTo es historia

REST

Es una técnica de arquitectura software para sistemas hipermedia distribuidos como la World Wide Web.

 

Se basa en mensajes http

REpresentational State Transfer

Cualquier interfaz entre sistemas que utilice directamente HTTP para obtener datos

REST... ful?

Los sistemas que siguen los principios REST se llaman con frecuencia RESTful

¿Qué necesita REST?

  • Un conjunto de recursos de salida
  • Un conjunto de URIs
  • Un conjunto de métodos bien definidos

Recursos y URIs

class Persona:
    id=0
    nombre=""
    apellido=""
    username=""
{
  "id":1
  "nombre":"juan",
  "apellido":"perez",
  "username":Mr.Jhon"
}

URL = https://api.misitio.com

URI = /personas

URI individual = /personas/{id}

Metodos HTTP

POST para crear un recurso en el servidor
GET para obtener un recurso
PUT para cambiar el estado de un recurso o actualizarlo
DELETE para eliminar un recurso

Recursos y URIs

Métodos

GET /personas

POST /personas

GET /personas/1

PUT /personas/1

DELETE personas/1

Recursos y URIs

Adicionales

GET /personas/?search=juan

GET /personas/1/followers

GET /personas/1/posts?offset=12&limit=20

¿Qué necesito para hacer una API?

  1. Una base de datos, y preferiblemente un ORM
  2. Un Framework de desarrollo RESTful
  3. Un proveedor de servicios de autenticación
  4. Un servidor http/https

Django + Tastypie

  • Django es un framework de desarrollo web
  • Tastypie es un framework de APIs RESTful, basado en los modelos de django
  • Es muy extensible

Ruby On Rails

  • Rails es un framework de desarrollo web
  • Permite construir APIs RESTful, basado en un poderoso ORM, es usado por empresas como Github, Stripe, Basecamp entre otros
  • Se basa en fundamentos y preconcepciones del mundo de desarrollo web

NodeJS + Expres (Koa)

  • Nodejs es un framework de desarrollo de javascript para backend (entre otras cosas)
  • Permite construir APIs RESTful, y aplicaciones web en tiempo real basado en un funciones simples, conocidas como middlewares
  • Usa las características de Javascript para supercargar las técnicas básicas de desarrollo web

Vamos a la practica

APIs

By Pixela

APIs

Una presentación general sobre la importancia de las APIs en la web

  • 452