Skip to content

Files

Latest commit

 

History

History
171 lines (111 loc) · 8.56 KB

README.md

File metadata and controls

171 lines (111 loc) · 8.56 KB

API Umbrella

What Is API Umbrella?

API Umbrella is a platform for exposing web service APIs. The basic goal of API Umbrella is to make life easier for both API creators and API consumers. How?

  • Make life easier for API creators: Allow API creators to focus on building APIs.
    • Standardize the boring stuff: APIs can assume the boring stuff (access control, rate limiting, analytics, etc.) is already taken care if the API is being accessed, so common functionality doesn't need to be implemented in the API code.
    • Easy to add: API Umbrella acts as a layer above your APIs, so your API code doesn't need to be modified to take advantage of the features provided.
    • Scalability: Make it easier to scale your APIs.
  • Make life easier for API consumers: Let API consumers easily explore and use your APIs.
    • Unify disparate APIs: Present separate APIs as a cohesive offering to API consumers. APIs running on different servers or written in different programming languages can be exposed at a single endpoint for the API consumer.
    • Standardize access: All your APIs are can be accessed using the same API key credentials.
    • Standardize documentation: All your APIs are documented in a single place and in a similar fashion.

Components

API Umbrella is broken into several components:

  • API Umbrella Gatekeeper: A custom reverse proxy to control access to your APIs. Performs API key validation, request rate limiting, and gathers analytics.
  • API Umbrella Router: Combines reverse proxies (API Umbrella Gatekeeper and HAProxy) to route requests to the appropriate backend. Ensures all API requests are approved by the gatekeeper and gives the appearance of unified APIs.
  • API Umbrella Web: A web application for providing API documentation and API key signup.

Dependencies

Don't sweat this list, though—installation and configuration of everything can be automated through Chef. See Running API Umbrella below for details.

Running API Umbrella

The easiest way to get started with API Umbrella is to use Vagrant to setup a local development environment.

First install VirtualBox and Vagrant on your computer. Then follow these steps:

Note for Windows Users: As of Vagrant 1.0.5, there's currently a bug with Vagrant that will prevent the vagrant up step from completing properly. See Running API Umbrella in Windows on Vagrant 1.0.5 before proceeding for a workaround.

# Get the code
$ git clone https://github.com/NREL/api-umbrella.git
$ cd api-umbrella
$ git submodule init
$ git submodule update

# Bootstrap a local VM environment (this will take a while)
$ vagrant up

# Login to your local VM
$ vagrant ssh

# Setup the apps on your local VM
$ cd /vagrant/workspace/api-umbrella-router
$ cp config/mongoid.yml.example config/mongoid.yml && cp config/redis.yml.example config/redis.yml
$ bundle install --path=vendor/bundle
$ cap vagrant deploy

$ cd /vagrant/workspace/api-umbrella-web
$ cp config/mongoid.yml.example config/mongoid.yml
$ bundle install --path=vendor/bundle
$ cap vagrant deploy

# Tada?

Assuming all that goes smoothly, you should be able see the homepage at http://localhost:8080/

Problems? Open an issue.

Using API Umbrella

Once you have API Umbrella up and running, there are a variety of things you can do to start using the platform. Here are some of the tasks

Add APIs to the router

Out of the box, API Umbrella doesn't know about any APIs. You must first configure the URL endpoints you want proxied to APIs in the router.

In this example, we'll proxy to Google's Geocoding API (but you'll more likely be proxying to your own web services).

Step 1: Create workspace/api-umbrella-router/config/haproxy/backends/api_google_farm.cfg.erb with the following contents:

backend api_google_farm
  # Strip /api from the beginning of the request URL before the receiving
  # backend application sees the request.
  #
  # Turns a request from "GET /api/something" to "GET /something"
  reqirep ^([^\ ]*)\ /api(/.*) \1\ \2

  # Modify the host header on the request.
  reqirep ^Host: Host:\ maps.googleapis.com

  balance roundrobin
  server api_google1 maps.googleapis.com:80

This backend file defines the server you want to route requests to. The request can be modified to alter URL paths, HTTP headers and more. See HAProxy backend documentation for more info.

Step 2: Create workspace/api-umbrella-router/config/haproxy/api_router_matches/api_google.lst with the following contents:

/api/maps/

This config file lists any URL prefixes you wish to route to the new backend. One line per URL prefx. See HAProxy ACL documentation (specifically the -f option) for more info

Step 3: Update workspace/api-umbrella-router/config/haproxy/frontends/api_router.cfg.erb and add to the bottom:

  # Insert your own...
  acl url_match_api_google path_beg -i -f <%= File.join(latest_release, "config/haproxy/api_router_matches/api_google.lst") %>
  use_backend api_google_farm if url_match_api_google

This frontend file is the glue that instructs the router to route any URL prefixes contained in api_google.lst to the servers defined in the api_google_farm backend. See HAProxy frontend documentation for more info.

Step 4: Deploy your changes

$ vagrant ssh
$ cd /vagrant/workspace/api-umbrella-router
$ cap vagrant deploy

Signup for an API key

On your local environment, visit the signup form:

http://localhost:8080/signup

Signup to receive your own unique API key for your development environment.

Make an API request

Assuming you added the Google Geocoding API example to your router config, you should now be able to make a request to Google's Geocoding API proxied through your local API Umbrella instance:

http://localhost:8080/api/maps/api/geocode/json?address=Golden,+CO&sensor=false&api_key=**YOUR_KEY_HERE**

You can see how API Umbrella layers its authentication on top of existing APIs by making a request using an invalid key:

http://localhost:8080/api/maps/api/geocode/json?address=Golden,+CO&sensor=false&api_key=INVALID_KEY

Login to the web admin

A web admin is available to perform basic tasks:

http://localhost:8080/admin/

While in your local development environment, you may login with any name and e-mail address.

This open admin is obviously not suitable for production, but alternative authentication mechanisms can be added via a variety of OmniAuth strategies.

Write API documentation

Login to the web admin and create documentation for individual web services and organize them into hierarchical collections. As documentation and collections are added, they will show up in the documentation section of the frontend.

Deploying to Production

Migrating to other servers or a production environment can be largely handled by Chef and Capistrano:

  1. Setup your servers using Chef and the available cookbooks and roles.
  2. Deploy api-umbrella-router and api-umbrella-web with Capistrano: cap production deploy

Who's using API Umbrella?