Skip to content

Commit

Permalink
feat(pdk): allow certain API to be called in balancer phase
Browse files Browse the repository at this point in the history
  • Loading branch information
fffonion committed Jul 8, 2024
1 parent 1a8601f commit 2b32ca2
Show file tree
Hide file tree
Showing 5 changed files with 21 additions and 15 deletions.
1 change: 1 addition & 0 deletions kong/pdk/private/phases.lua
Original file line number Diff line number Diff line change
Expand Up @@ -122,6 +122,7 @@ end
local public_phases = setmetatable({
request = new_phase(PHASES.rewrite,
PHASES.access,
PHASES.balancer,
PHASES.response,
PHASES.header_filter,
PHASES.body_filter,
Expand Down
1 change: 1 addition & 0 deletions kong/pdk/response.lua
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@ local header_body_log = phase_checker.new(PHASES.response,
local rewrite_access_header = phase_checker.new(PHASES.rewrite,
PHASES.access,
PHASES.response,
PHASES.balancer,
PHASES.header_filter,
PHASES.error,
PHASES.admin_api)
Expand Down
2 changes: 1 addition & 1 deletion kong/pdk/service.lua
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,7 @@ local function new()
-- kong.service.set_target("service.local", 443)
-- kong.service.set_target("192.168.130.1", 80)
function service.set_target(host, port)
check_phase(PHASES.access)
check_phase(access_and_rewrite_and_balancer_preread)

if type(host) ~= "string" then
error("host must be a string", 2)
Expand Down
28 changes: 16 additions & 12 deletions kong/pdk/service/request.lua
Original file line number Diff line number Diff line change
Expand Up @@ -83,12 +83,12 @@ local function new(self)
-- Enables buffered proxying, which allows plugins to access Service body and
-- response headers at the same time.
-- @function kong.service.request.enable_buffering
-- @phases `rewrite`, `access`
-- @phases `rewrite`, `access`, `balancer`
-- @return Nothing.
-- @usage
-- kong.service.request.enable_buffering()
request.enable_buffering = function()
check_phase(access_and_rewrite)
check_phase(access_rewrite_balancer)

if ngx.req.http_version() >= 2 then
error("buffered proxying cannot currently be enabled with http/" ..
Expand All @@ -102,13 +102,13 @@ local function new(self)
---
-- Sets the protocol to use when proxying the request to the Service.
-- @function kong.service.request.set_scheme
-- @phases `access`
-- @phases `access`, `rewrite`, `balancer`
-- @tparam string scheme The scheme to be used. Supported values are `"http"` or `"https"`.
-- @return Nothing; throws an error on invalid inputs.
-- @usage
-- kong.service.request.set_scheme("https")
request.set_scheme = function(scheme)
check_phase(PHASES.access)
check_phase(access_rewrite_balancer)

if type(scheme) ~= "string" then
error("scheme must be a string", 2)
Expand All @@ -131,14 +131,14 @@ local function new(self)
--
-- Input should **not** include the query string.
-- @function kong.service.request.set_path
-- @phases `access`
-- @phases `access`, `rewrite`, `balancer`
-- @tparam string path The path string. Special characters and UTF-8
-- characters are allowed, for example: `"/v2/movies"` or `"/foo/😀"`.
-- @return Nothing; throws an error on invalid inputs.
-- @usage
-- kong.service.request.set_path("/v2/movies")
request.set_path = function(path)
check_phase(PHASES.access)
check_phase(access_rewrite_balancer)

if type(path) ~= "string" then
error("path must be a string", 2)
Expand Down Expand Up @@ -440,13 +440,13 @@ local function new(self)
-- For a higher-level function to set the body based on the request content type,
-- see `kong.service.request.set_body()`.
-- @function kong.service.request.set_raw_body
-- @phases `rewrite`, `access`
-- @phases `rewrite`, `access`, `balancer`
-- @tparam string body The raw body.
-- @return Nothing; throws an error on invalid inputs.
-- @usage
-- kong.service.request.set_raw_body("Hello, world!")
request.set_raw_body = function(body)
check_phase(access_and_rewrite)
check_phase(access_rewrite_balancer)

if type(body) ~= "string" then
error("body must be a string", 2)
Expand All @@ -459,7 +459,9 @@ local function new(self)
-- Ensure client request body has been read.
-- This function is a nop if body has already been read,
-- and necessary to write the request to the service if it has not.
ngx.req.read_body()
if ngx.get_phase() ~= "balancer" then
ngx.req.read_body()
end

ngx.req.set_body_data(body)
end
Expand Down Expand Up @@ -594,7 +596,7 @@ local function new(self)
-- a string with `kong.service.request.set_raw_body()`.
--
-- @function kong.service.request.set_body
-- @phases `rewrite`, `access`
-- @phases `rewrite`, `access`, `balancer`
-- @tparam table args A table with data to be converted to the appropriate format
-- and stored in the body.
-- @tparam[opt] string mimetype can be one of:
Expand Down Expand Up @@ -622,7 +624,7 @@ local function new(self)
-- -- Produces the following body:
-- -- bar=baz&bar=bla&bar&blo=&foo=hello%20world&zzz
request.set_body = function(args, mime)
check_phase(access_and_rewrite)
check_phase(access_rewrite_balancer)

if type(args) ~= "table" then
error("args must be a table", 2)
Expand Down Expand Up @@ -652,7 +654,9 @@ local function new(self)
-- Ensure client request body has been read.
-- This function is a nop if body has already been read,
-- and necessary to write the request to the service if it has not.
ngx.req.read_body()
if ngx.get_phase() ~= "balancer" then
ngx.req.read_body()
end

local body, content_type = handler_fn(args, mime)

Expand Down
4 changes: 2 additions & 2 deletions t/01-pdk/09-service/00-phase_checks.t
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,7 @@ qq{
args = { "example.com", 8000 },
init_worker = false,
certificate = "pending",
rewrite = "forced false",
rewrite = true,
access = true,
response = "forced false",
header_filter = "forced false",
Expand Down Expand Up @@ -243,7 +243,7 @@ qq{
args = { "example.com", 8000 },
init_worker = false,
certificate = "pending",
rewrite = "forced false",
rewrite = true,
access = true,
response = "forced false",
header_filter = "forced false",
Expand Down

0 comments on commit 2b32ca2

Please sign in to comment.