Document updated on Jun 13, 2021
Transformations using Lua scripting
Scripting with Lua is an additional choice to extend your business logic, and is compatible with the rest of options such as CEL, Martian, or other Go plugins and middlewares.
If you are more familiar with Lua than Go, this module can help you solve exceptional cases that need solution using a little bit of scripting. The introduction of Lua scripts in your Gateway does not require to recompile KrakenD, but unlike Go, Lua scripts are interpreted in real-time.
For performance-first users, a Go plugin delivers much better results than a Lua script.
Configuration
KrakenD looks for the lua scripts in the root folder where KrakenD is running. You need to specify in the configuration which lua scripts are going to be loaded in Krakend, as well as several options. The extra_config can be set at endpoint level or backend level.
"extra_config": {
      "github.com/devopsfaith/krakend-lua/proxy": {
        "sources": ["file1.lua"],
        "md5": {
          "file1.lua": "49ae50f58e35f4821ad4550e1a4d1de0"
        },
        "pre": "lua code to execute for pre",
        "post": "lua code to execute for post",
        "live": false,
        "allow_open_libs": false,
        "skip_next": true
      }
}
- sources: An array with all the files that will be processed
- md5: (optional) The md5sum of each file that must match the one found in the disk. Used to make sure that the file has not been modified by a 3rd party.
- preand- postcontain the code to start the execution in every step.- postis only available in the- backendsection.
- live: Live reload of the script in every execution
- allow_open_libs: The regular lua libraries are not open by default, as an efficiency point. But if you need to use the lua libraries (for file io for example), then set this to true. If not present, default value is false.
- skip_next: only to be set when in a- backendsection, skips the query to the next backend.
headers_to_pass as KrakenD does not forward headers to the backends unless declared in the list.Namespaces (component name)
There are three namespaces that are used for the lua component.
Under the endpoint section use the namespaces (these are described in the next section):
- "github.com/devopsfaith/krakend-lua/proxy"
- "github.com/devopsfaith/krakend-lua/router"
Under the backend use the name space:
- "github.com/devopsfaith/krakend-lua/proxy/backend"
Supported Lua types (cheatsheet)
When running Lua scripts on KrakenD, there are two different types you can use in their coding. Depending on the place of the pipe you want to place the script you can use a proxy type or a router type:
End User <--[router]--> KrakenD <--[proxy]--> Services
These two types are described as follows:
- Router: The router layer is what happens between the end-user and KrakenD
- Proxy: The proxy layer is between KrakenD and your services
proxy type
Use this type when you need to intercept requests and responses between KrakenD and your services.
Request
Scripts that need to modify a request that KrakenD is about to do against the backend services.
- load(Static)
- method(Dynamic)
- path(Dynamic)
- query(Dynamic)
- url(Dynamic)
- params(Dynamic)
- headers(Dynamic)
- body(Dynamic)
Example: Access the request getter with req:url() and the setter with req:url("foo").
Response
Scripts that need to modify a request that KrakenD is about to get from the backend services.
- load(Static)
- isComplete(Dynamic)
- statusCode(Dynamic)
- data(Dynamic)
- headers(Dynamic)
- body(Dynamic)
router type
Use this type when you need to script the router layer, traffic between end-users and KrakenD.
ctx
- load(Static)
- method(Dynamic)
- query(Dynamic)
- url(Dynamic)
- params(Dynamic)
- headers(Dynamic)
- body(Dynamic)
- host(Dynamic)
Additional helpers (cheatsheet)
The following helpers are available in your scripts:
table
- get(Dynamic)
- set(Dynamic)
- len(Dynamic)
- del(Dynamic)
Example of Lua code to delete an element named element from a table:
t:del("element")list
- get(Dynamic)
- set(Dynamic)
- len(Dynamic)
- del(Dynamic)
Example of Lua code to replace a list named collection with deleted content:
local original_collection = responseData:get("collection")
original_collection:del(2)http_response
- new(Static)
- statusCode(Dynamic)
- headers(Dynamic)
- body(Dynamic)
custom_error
A generic helper in pre and post scripts that allows you to set custom http status codes. For instance, when you want to send an immediate response to the client from within a Lua script without further querying the backend, or after evaluating the response of the backend.
It stops the script and the pipe execution.
Example to throw a generic error (500 status code ) with a message:
custom_error("Something weird happened")
Or even changing the http status code (418 I'm a teapot)
custom_error("I refuse to make any coffee, I'm a teapot!", 418)
Sequence of execution
Request sequence:
- Router “source” files
- Router “pre” logic
- Proxy “source” files
- Proxy “pre” logic
- Backend “source” files
- Backend “pre” logic
The returned response then goes through:
- Backend “post” logic
- Proxy “post” logic
Lua examples in different pipes
The following snippets show how to add Lua code in different sections.
Lua in the endpoint
An example setting a header in the response using Lua.
  {
    "endpoint": "/set-a-header",
    "extra_config": {
        "github.com/devopsfaith/krakend-lua/proxy": {
          "pre": "print('Lua proxy!'); local r = request.load(); r:headers('X-from-lua', '1234');"
        }
    }
  }Lua in the backend
An example showing how to print the backend response in the console.
{
    "extra_config": {
          "github.com/devopsfaith/krakend-lua/proxy/backend": {
            "pre": "print('Backend response, pre-logic:'); local r = request.load(); print(r:body());"
          }
    }
}Another example setting a cookie from Lua:
{
    "extra_config": {
        "github.com/devopsfaith/krakend-lua/proxy": {
            "post": "local r = response.load(); r:headers('Set-Cookie', 'key1='.. r:data('response'));",
            "allow_open_libs": true
        }
    }
}
