Skip to content

Latest commit

 

History

History
32 lines (20 loc) · 2.83 KB

README.md

File metadata and controls

32 lines (20 loc) · 2.83 KB

3scale APIcast policy development workshop

This repository contains the code and configuration of a 3scale APIcast policy used in the workshop described in this README. It's purposes are to provide a first introduction to the world of 3scale policy development.

In this workshop we are going to dive into the development, testing and deployment of a custom 3scale APIcast policy. In this initial part we are going to setup a development environment so we can actually start the development of our policy.

But before we begin, let’s first take a look what a 3scale APIcast policy is. We are not going into too much detail here, since better and more detailed descriptions about 3scale APIcast policies already exist.

For those unfamiliar, 3scale is a full API Management solution of Red Hat. It exists of an API Manager used for account management, analytics and overall configuration. A developer portal used for outside developers for gaining access to API’s and viewing the documentation. And the API gateway named APIcast. The APIcast gateway is based on Nginx and more specifically Openresty, which is a distribution of Nginx compiled with various modules, most notable the lua-nginx-module.

The lua-nginx-module provides the ability to enhance a Nginx server by executing scripts using the Lua programming language. This is done by providing a Lua hook for each of the Nginx phases. Nginx works using an event loop and a state model where every request (as well as the starting of the server and its worker processes) goes through various phases. Each phase can execute a specific Lua function.

An overview of the various phases and corresponding Lua hooks was kindly in the README of the lua-nginx-module: https://github.com/openresty/lua-nginx-module#directives

Nginx phases

Since the APIcast gateway uses Openresty 3scale provided a way to leverage these Lua hooks in the Nginx server using something called policies. As described in the APIcast README:

“The behaviour of APIcast is customizable via policies. A policy basically tells APIcast what it should do in each of the nginx phases.”

A detailed explanation of policies can be found in the same README: https://github.com/3scale/apicast/blob/master/doc/policies.md

The code in this repo follows the APIcast directory structure. In order to use this code it has to be integrated in the APIcast code. Therefore the code and configuration in this repository act for reference purposes only.

The workshop was 4 distinct sections:

  1. setup the development environment
  2. generate a policy scaffold
  3. create and test the policy
  4. run the policy locally