Модуль ngx_http_js_module

Пример конфигурации
Директивы
     js_content
     js_include
     js_set
Аргумент запроса

Модуль ngx_http_js_module позволяет задавать обработчики location и переменных на njs — подмножестве языка JavaScript.

По умолчанию этот модуль не собирается. Инструкция по сборке и установке доступны здесь.

Пример конфигурации

load_module modules/ngx_http_js_module.so;
...

http {
    js_include http.js;

    js_set $foo     foo;
    js_set $summary summary;

    server {
        listen 8000;

        location / {
            add_header X-Foo $foo;
            js_content baz;
        }

        location /summary {
            return 200 $summary;
        }

        location /hello {
            js_content hello;
        }
    }
}

Файл http.js:

function foo(r) {
    r.log("hello from foo() handler");
    return "foo";
}

function summary(r) {
    var a, s, h;

    s = "JS summary\n\n";

    s += "Method: " + r.method + "\n";
    s += "HTTP version: " + r.httpVersion + "\n";
    s += "Host: " + r.headersIn.host + "\n";
    s += "Remote Address: " + r.remoteAddress + "\n";
    s += "URI: " + r.uri + "\n";

    s += "Headers:\n";
    for (h in r.headersIn) {
        s += "  header '" + h + "' is '" + r.headersIn[h] + "'\n";
    }

    s += "Args:\n";
    for (a in r.args) {
        s += "  arg '" + a + "' is '" + r.args[a] + "'\n";
    }

    return s;
}

function baz(r) {
    r.status = 200;
    r.headersOut.foo = 1234;
    r.headersOut['Content-Type'] = "text/plain; charset=utf-8";
    r.headersOut['Content-Length'] = 15;
    r.sendHeader();
    r.send("nginx");
    r.send("java");
    r.send("script");

    r.finish();
}

function hello(r) {
    r.return(200, "Hello world!");
}

Директивы

Синтаксис: js_content функция;
Умолчание:
Контекст: location, limit_except

Задаёт функцию njs в качестве обработчика содержимого location.

Синтаксис: js_include файл;
Умолчание:
Контекст: http

Задаёт файл, позволяющий задавать обработчики location и переменных на njs.

Синтаксис: js_set $переменная функция;
Умолчание:
Контекст: http

Задаёт функцию njs для указанной переменной.

Аргумент запроса

Каждый HTTP-обработчик njs получает один аргумент, объект запроса.