- 2.8.1.0
- 2.7.1.2
- 2.7.1.0
- 2.6.0.4
- 2.6.0.2
- 2.6.0.1
- 2.6.0.0
- 2.6.0.0 (beta1)
- 2.5.1.2
- 2.5.0.2
- 2.5.0.1
- 2.5.0.0
- 2.5.0.0 (beta1)
- 2.4.1.3
- 2.4.1.1
- 2.4.1.0
- 2.3.3.3
- 2.3.3.1
- 2.3.2.0
- 2.2.1.5
- 2.2.1.2
- 2.2.1.1
- 2.2.0.0 (beta)
- 2.1.4.5
- 2.1.4.3
- 2.1.4.1
- 2.1.4.0
- 2.1.3.1
- 2.1.3.0
- 2.1.0.0 (beta)
- 1.5.0.10
- 1.5.0.8
- 1.5.0.6
- 1.5.0.5
- 1.5.0.4
- 1.5.0.2
- 1.5.0.1
- 1.3.0.2
- 1.3.0.1
- 0.36-6
- 0.36-5
- 0.36-4
- 0.36-3
- 0.36-2
- 0.36-1
- 0.35-3
- 0.35-1
- 0.34-1
- 0.33-2
- 0.32
- 0.31
- 0.30
Kong Gateway Changelog
Plugins
- Request Transformer Advanced ()
- Values stored in
key:value
pairs in this plugin’s configuration are now referenceable, which means they can be stored as in a vault.
- Values stored in
Fixes
Enterprise
- Kong Manager:
- Removed the endpoint
all_routes
from configurable RBAC endpoint permissions. This endpoint was erroneously appearing in the endpoints list, and didn’t configure anything. - Fixed an issue that allowed unauthorized IDP users to log in to Kong Manager. These users had no access to any resources in Kong Manager, but were able to go beyond the login screen.
- Fixed an issue where, in an environment with a valid Enterprise license, admins with no access to the
default
workspace would see a message prompting them to upgrade to Kong Enterprise. - Fixed pagination issues with Kong Manager tables.
- Fixed broken
Learn more
links. - Fixed an issue with group to role mapping, where it didn’t support group names with spaces.
- Fixed the Cross Site Scripting (XSS) security vulnerability in the Kong Manager UI.
- Fixed an RBAC issue where permissions applied to specific endpoints (for example, an individual service or route) were not reflected in the Kong Manager UI.
- Removed New Relic from Kong Manager. Previously,
VUE_APP_NEW_RELIC_LICENSE_KEY
andVUE_APP_SEGMENT_WRITE_KEY
were being exposed in Kong Manager with invalid values. - Removed the action dropdown menu on service and route pages for read-only users.
- Fixed the Edit Configuration button for Dev Portal applications.
- Fixed an RBAC issue where the roles page listed deleted roles.
- Fixed an issue where the orphaned roles would remain after deleting a workspace and cause the Teams > Admins page to break.
- Added the missing Copy JSON button for plugin configuration.
- Fixed an issue where the New Workspace button on the global workspace dashboard wasn’t clickable on the first page load.
- Removed the ability to add multiple documents per service from the UI. Each service only supports one document, so the UI now reflects that.
- The Upstream Timeout plugin now has an icon and is part of the Traffic Control category.
- Fixed an error that would occur when attempting to delete ACL credentials from the consumer credentials list. This happened because the name of the plugin,
acl
, and its endpoint,/acls
, don’t match. - Fixed a caching issue with Dev Portal, where enabling or disabling the Dev Portal for a workspace wouldn’t change the Kong Manager menu.
- Removed the endpoint
- Unpinned the version of
alpine
used in thekong/kong-gateway
Docker image. Previously, the version was pinned to 3.10, which was creating outdatedalpine
builds.
Core
Fixed an issue with how Kong initializes
resty.events
. The code was previously usingngx.config.prefix()
to determine the listening socket path to provide to the resty.events module. This caused breakage when Nginx was started with a relative path prefix. This meant that you couldn’t start 3.0.x with the same default configuration as 2.8.x.Instead of using
ngx.config.prefix()
, Kong will now prefer thekong.configuration.prefix
when available, as it is already normalized to an absolute path. Ifkong.configuration.prefix
is not defined, the result ofngx.config.prefix()
will be used after resolving it to an absolute path.Fixed an issue with secret management references for HashiCorp Vault. By default, Kong passes secrets to the Nginx using environment variables when using
kong start
. Nginx was being started directly without callingkong start
, so the secrets were not available at initialization. #9478Fixed the Amazon Linux RPM installation instructions.
3.0.0.0
Release Date 2022/09/09
Features
Enterprise
Kong Gateway now supports dynamic plugin ordering. You can change a plugin’s static priority by specifing the order in which plugins run. This lets you run plugins such as
rate-limiting
before authentication plugins.Kong Gateway now offers a FIPS package. The package replaces the primary library, OpenSSL, with , which at its core uses the FIPS 140-2 compliant BoringCrypto for cryptographic operations.
To enable FIPS mode, set fips to
on
. FIPS mode is only supported in Ubuntu 20.04.Note: The Kong Gateway FIPS package is not currently compatible with SSL connections to PostgreSQL.
Kong Gateway now includes WebSocket validation functionality. Websockets are a type of persistent connection that works on top of HTTP.
Previously, Kong Gateway 2.x supported limited WebSocket connections, where plugins only ran during the initial connection phase instead of for each frame. Now, Kong Gateway provides more control over WebSocket traffic by implementing plugins that target WebSocket frames.
This release includes:
- and route support for
ws
andwss
protocols - Two new plugins: and WebSocket Validator
- WebSocket plugin development capabilities (Beta feature)
- PDK modules: and kong.websocket.upstream
Learn how to develop WebSocket plugins with our plugin development guide.
- and route support for
In this release, Kong Manager ships a with a refactored design and improved user experience.
Notable changes:
- Reworked workspace dashboards, both for specific workspaces and at the multi-workspace level.
- License metrics now appear at the top of overview pages.
- Restructured the layout and navigation to make workspace selection a secondary concern.
- Grayed out portal buttons when you don’t have permissions.
- Added license level to phone home metrics.
- Added more tooltips.
- is now generally available.
- Added GCP integration support for the secrets manager. GCP is now available as a vault backend.
- The
/vaults-beta
entity has been deprecated and replaced with the/vaults
entity. #8871
Kong Gateway now provides slim and UBI images. Slim images are docker containers built with a minimal set of installed packages to run Kong Gateway. From 3.0 onward, Kong Docker images will only contain software required to run the Gateway. This ensures that false positive vulnerabilities don’t get flagged during security scanning.
If you want to retain or add other dependencies, you can build custom Kong Docker images.
The base OS for our convenience docker tags (for example,
latest
,3.0.0.0
,3.0
) has switched from Alpine to Debian.Added key recovery for keyring encryption. This exposes a new endpoint for the Admin API, , and requires keyring_recovery_public_key to be set in
kong.conf
.You can now encrypt declarative configuration files on data planes in DB-less and hybrid modes using or chacha20-poly1305 encryption algorithms.
Set your desired encryption mode with the configuration parameter.
Core
This release introduces a new router implementation:
atc-router
. This router is written in Rust, a powerful routing language that can handle complex routing requirements. The new router can be used in traditional-compatible mode, or use the new expression-based language.With the new router, we have:
- Reduced router rebuild time when changing Kong’s configuration
- Increased runtime performance when routing requests
- Reduced P99 latency from 1.5s to 0.1s with 10,000 routes
Learn more about the router:
- Implemented delayed response in stream mode. #6878
- Added
cache_key
on target entity for uniqueness detection. Introduced the tracing API, which is compatible with OpenTelemetry API specs, and adds built-in instrumentations.
The tracing API is intended to be used with a external exporter plugin. Built-in instrumentation types and sampling rate are configurable through the opentelemetry_tracing and options. #8724
Added
path
,uri_capture
, andquery_arg
options to upstreamhash_on
for load balancing.- Introduced Unix domain socket-based
lua-resty-events
to replace shared memory-basedlua-resty-worker-events
. #8890 - Introduced the
table_name
field for entities. This field lets you specify a table name. Previously, the name was deduced by the entityname
attribute. - Added
headers
on active health checks for upstreams. #8255 - Target entities using hostnames were resolved when they were not needed. Now when a target is removed or updated, the DNS record associated with it is removed from the list of hostnames to be resolved. 9265
- Improved error handling and debugging info in the DNS code.
- Kong Gateway will now attempt to recover from an unclean shutdown by detecting and removing dangling Unix sockets in the prefix directory. #9254
- A new CLI command,
kong migrations status
, generates the migration status in a JSON file. - Removed the warning for
AAAA
being experimental withdns_order
.
Performance
- Kong Gateway does not register unnecessary event handlers on hybrid mode control plane nodes anymore. #8452.
- Use the new timer library to improve performance, except for the plugin server.
- Increased the use of caching for DNS queries by activating
additional_section
by default. #8895 pdk.request.get_header
has been changed to a faster implementation. It doesn’t fetch all headers every time it’s called.- Conditional rebuilding of the router, plugins iterator, and balancer on data planes. #8519,
- Made configuration loading code more cooperative by yielding. #8888
- Use the LuaJIT encoder instead of JSON to serialize values faster in LMDB.
- Made inflating and JSON decoding non-concurrent, which avoids blocking and makes data plane reloads faster. #8959
- Stopped duplication of some events.
- Improved performance of configuration hash calculation by using
string.buffer
andtablepool
. #9073 - Reduced cache usage in DB-less mode by not using the Kong cache for routes and services in LMDB.
Admin API
- Added a new
/timers
Admin API endpoint to get timer statistics and worker info. #8999 - The
/
endpoint now includes plugin priority.
Hybrid Mode
- Added wRPC protocol support. Configuration synchronization now happens over wRPC. wRPC is an RPC protocol that encodes with ProtoBuf and transports with WebSocket.
- To keep compatibility with earlier versions, added support for the control plane to fall back to the previous protocol to support older data planes. #8834
- Added support to negotiate services supported with wRPC protocol. We will support more services in the future.
- Declarative configuration exports now happen inside a transaction in PostgreSQL. #8586
Plugins
Starting with version 3.0, all bundled plugin versions are the same as the Kong Gateway version. #8772
now refers to the Kong Gateway version instead of the individual plugin version.
New plugins:
OpenTelemetry (
opentelemetry
)Export tracing instrumentations to any OTLP/HTTP compatible backend.
opentelemetry_tracing
configuration must be enabled to collect the core tracing spans of Kong Gateway.TLS Handshake Modifier (
tls-handshake-modifier
)Make certificates available to other plugins acting on the same request.
(
tls-metadata-headers
)Proxy TLS client certificate metadata to upstream services via HTTP headers.
WebSocket Size Limit (
websocket-size-limit
)Allows operators to specify a maximum size for incoming WebSocket messages.
(
websocket-validator
)Validate individual WebSocket messages against a user-specified schema before proxying them.
ACME (
acme
)- Added the
allow_any_domain
field. It defaults to false and if set to true, the gateway will ignore thedomains
field.
- Added the
- AWS Lambda (
aws-lambda
)- Added support for cross-account invocation through the
aws_assume_role_arn
andaws_role_session_name
configuration parameters. - The plugin now accepts string type
statusCode
as a valid return when working in proxy integration mode. #8765 - The plugin now separates AWS credential cache by the IAM role ARN.
- Added support for cross-account invocation through the
- Collector (
collector
)- The deprecated Collector plugin has been removed.
- DeGraphQL (
degraphql
)- The GraphQL server path is now configurable with the
graphql_server_path
configuration parameter.
- The GraphQL server path is now configurable with the
- (
kafka-upstream
) and Kafka Log (kafka-log
)- Added support for the
SCRAM-SHA-512
authentication mechanism.
- Added support for the
- (
ldap-auth-advanced
)- This plugin now allows authorization based on group membership. The new configuration parameter,
groups_required
, is an array of string elements that indicates the groups that users must belong to for the request to be authorized. - The character
.
is now allowed in group attributes. - The character
:
is now allowed in the password field.
- This plugin now allows authorization based on group membership. The new configuration parameter,
- mTLS Authentication (
mtls-auth
)- Introduced certificate revocation list (CRL) and OCSP server support with the following parameters:
http_proxy_host
,http_proxy_port
,https_proxy_host
, andhttps_proxy_port
.
- Introduced certificate revocation list (CRL) and OCSP server support with the following parameters:
(
opa
)New configuration parameter
include_body_in_opa_input
: When enabled, include the raw body as a string in the OPA input atinput.request.http.body
and the body size atinput.request.http.body_size
.New configuration parameter
include_parsed_json_body_in_opa_input
: When enabled and content-type isapplication/json
, the parsed JSON will be added to the OPA input atinput.request.http.parsed_body
.
Prometheus (
prometheus
)- High cardinality metrics are now disabled by default.
- Decreased performance penalty to proxy traffic when collecting metrics.
The following metric names were adjusted to add units to standardize where possible:
http_status
tohttp_requests_total
.latency
tokong_request_latency_ms
(HTTP),kong_upstream_latency_ms
,kong_kong_latency_ms
, andsession_duration_ms
(stream).Kong latency and upstream latency can operate at orders of different magnitudes. Separate these buckets to reduce memory overhead.
kong_bandwidth
tokong_bandwidth_bytes
.nginx_http_current_connections
andnginx_stream_current_connections
were merged into tonginx_hconnections_total
(ornginx_current_connections
?)request_count
andconsumer_status
were merged into http_requests_total.If the
per_consumer
config is set tofalse
, theconsumer
label will be empty. If theper_consumer
config istrue
, theconsumer
label will be filled.
Removed the following metric:
http_consumer_status
- New metrics:
session_duration_ms
: monitoring stream connections.node_info
: Single gauge set to 1 that outputs the node’s ID and Kong Gateway version.
http_requests_total
has a new label,source
. It can be set toexit
,error
, orservice
.- All memory metrics have a new label:
node_id
. - Updated the Grafana dashboard that comes packaged with Kong
- (
statsd
)- Newly open-sourced plugin capabilities: All capabilities of the StatsD Advanced plugin are now bundled in the plugin. #9046
- (
zipkin
)- Added support for including the HTTP path in the span name with the
http_span_name
configuration parameter. #8150 - Added support for socket connect and send/read timeouts through the
connect_timeout
,send_timeout
, andread_timeout
configuration parameters. This can help mitigatengx.timer
saturation when upstream collectors are unavailable or slow.
- Added support for including the HTTP path in the span name with the
Configuration
- You can now configure
openresty_path
to allow developers and operators to specify the OpenResty installation to use when running Kong Gateway, instead of using the system-installed OpenResty. - Added
ipv6only
to listen optionsadmin_listen
,proxy_listen
, andstream_listen
. #9225 - Added
so_keepalive
to listen optionsadmin_listen
,proxy_listen
, andstream_listen
. - Add LMDB DB-less configuration persistence and removed the JSON-based configuration cache for faster startup time. #8670
nginx_events_worker_connections=auto
now has a lower bound of 1024.nginx_main_worker_rlimit_nofile=auto
now has a lower bound of 1024. #9276
PDK
- Added new PDK function:
kong.request.get_start_time()
. This function returns the request start time, in Unix epoch milliseconds. #8688 - The function
kong.db.*.cache_key()
now falls back to.id
if nothing fromcache_key
is found.
Known limitations
- Kong Manager does not currently support the following features:
- Secrets management
- Plugin ordering
- Expression-based routing
- Blue-green migration from 2.8.x (and below) to 3.0.x is not supported.
- This is a known issue planned to be fixed in the next 2.8 release. If this is a requirement for upgrading, Kong operators should upgrade to that version before beginning a upgrade to 3.0.0.0.
- See for more details.
OpenTracing: There is an issue with
nginx-opentracing
in this release, so it is not recommended to upgrade yet if you are an OpenTracing user. This will be rectified in an upcoming patch/minor release.The Kong Gateway FIPS package is not currently compatible with SSL connections to PostgreSQL.
Breaking changes and deprecations
Deployment
- Deprecated and stopped producing Amazon Linux 1 containers and packages. Amazon Linux 1 reached end-of-life on December 31, 2020.
- Deprecated and stopped producing Debian 8 (Jessie) containers and packages. Debian 8 reached end-of-life in June 30, 2020. Kong/kong-distributions #766
Core
As of 3.0, Kong Gateway’s schema library’s
process_auto_fields
function will not make deep copies of data that is passed to it when the given context isselect
. This was done to avoid excessive deep copying of tables where we believe the data most of the time comes from a driver likepgmoon
orlmdb
.If a custom plugin relied on
process_auto_fields
not overriding the given table, it must make its own copy before passing it to the function now. #8796The deprecated
shorthands
field in Kong plugin or DAO schemas was removed in favor of the typedshorthand_fields
. If your custom schemas still useshorthands
, you need to update them to useshorthand_fields
.- The support for
legacy = true/false
attribute was removed from Kong schemas and Kong field schemas. #8958 - The deprecated alias of
Kong.serve_admin_api
was removed. If your custom Nginx templates still use it, change it toKong.admin_content
. - The Kong singletons module
kong.singletons
was removed in favor of the PDKkong.*
. #8874 - The data plane configuration cache was removed. Configuration persistence is now done automatically with LMDB.
ngx.ctx.balancer_address
was removed in favor ofngx.ctx.balancer_data
. #9043- The normalization rules for
route.path
have changed. Kong Gateway now stores the unnormalized path, but the regex path always pattern-matches with the normalized URI. Previously, Kong Gateway replaced percent-encoding in the regex path pattern to ensure different forms of URI matches. That is no longer supported. Except for the reserved characters defined in , write all other characters without percent-encoding. #9024 - Kong Gateway no longer uses a heuristic to guess whether a
route.path
is a regex pattern. From 3.0 onward, all regex paths must start with the"~"
prefix, and all paths that don’t start with"~"
will be considered plain text. The migration process should automatically convert the regex paths when upgrading from 2.x to 3.0. Bumped the version number (
_format_version
) of declarative configuration to3.0
for changes onroute.path
. Declarative configurations using older versions are upgraded to3.0
during migrations.Do not sync (
deck sync
) declarative configuration files from 2.8 or earlier to 3.0. Old configuration files will overwrite the configuration and create compatibility issues. To grab the updated configuration,deck dump
the 3.0 file after migrations are completed.Tags may now contain space characters.
- Support for the
nginx-opentracing
module is deprecated as of3.0
and will be removed from Kong in4.0
(see the Known Limitations section for additional information). - We removed regex and backreferences support in the the atc-router. These are rarely used features and removing support for them improves the speed of our regex matching. If your current regexes use look-around or backreferences you will receive an error when attempting to start Kong, showing exactly what regex is incompatible. Users can either switch to the
traditional
router flavor or change the regex to remove look-around / backreferences.
Admin API
- The Admin API endpoint
/vitals/reports
has been removed. POST
requests on/targets
endpoints are no longer able to update existing entities. They are only able to create new ones. #8596, . If you have scripts that usePOST
requests to modify/targets
, change them toPUT
requests to the appropriate endpoints before updating to Kong Gateway 3.0.- Insert and update operations on duplicated targets return a
409
error. #8179, - The list of reported plugins available on the server now returns a table of metadata per plugin instead of a boolean
true
. #8810
PDK
- The
kong.request.get_path()
PDK function now performs path normalization on the string that is returned to the caller. The raw, non-normalized version of the request path can be fetched viakong.request.get_raw_path()
. #8823 pdk.response.set_header()
,pdk.response.set_headers()
,pdk.response.exit()
now ignore and emit warnings for manually setTransfer-Encoding
headers.- The PDK is no longer versioned. #8585
- The JavaScript PDK now returns
Uint8Array
forkong.request.getRawBody
,kong.response.getRawBody
, andkong.service.response.getRawBody
. The Python PDK returnsbytes
forkong.request.get_raw_body
,kong.response.get_raw_body
, andkong.service.response.get_raw_body
. Previously, these functions returned strings. - The
go_pluginserver_exe
andgo_plugins_dir
directives are no longer supported. #8552. If you are using , migrate your plugins to use the Go PDK before upgrading.
Plugins
- DAOs in plugins must be listed in an array, so that their loading order is explicit. Loading them in a hash-like table is no longer supported. #8988
- Plugins MUST now have a valid
PRIORITY
(integer) andVERSION
(“x.y.z” format) field in theirhandler.lua
file, otherwise the plugin will fail to load. - The old
kong.plugins.log-serializers.basic
library was removed in favor of the PDK functionkong.log.serialize
. Upgrade your plugins to use the PDK. #8815 - The support for deprecated legacy plugin schemas was removed. If your custom plugins still use the old (
0.x era
) schemas, you are now forced to upgrade them. Updated the priority for some plugins.
This is important for those who run custom plugins as it may affect the sequence in which your plugins are executed. This does not change the order of execution for plugins in a standard Kong Gateway installation.
Old and new plugin priority values:
acme
changed from1007
to1705
basic-auth
changed from1001
to1100
hmac-auth
changed from1000
to1030
jwt
changed from1005
to1450
jwt-signer
changed from999
to1020
.key-auth
changed from1003
to1250
ldap-auth
changed from1002
to1200
oauth2
changed from1004
to1400
rate-limiting
changed from901
to910
pre-function
changed from+inf
to1000000
.
Kong plugins no longer support
CREDENTIAL_USERNAME
(X-Credential-Username
). Use the constantCREDENTIAL_IDENTIFIER
(X-Credential-Identifier
) when setting the upstream headers for a credential. #8815(
acl
), Bot Detection (bot-detection
), and (ip-restriction
)- Removed the deprecated
blacklist
andwhitelist
configuration parameters. #8560
- Removed the deprecated
- (
acme
)- The default value of the
auth_method
configuration parameter is nowtoken
.
- The default value of the
- AWS Lambda (
aws-lambda
)- The AWS region is now required. You can set it through the plugin configuration with the
aws_region
field parameter, or with environment variables. - The plugin now allows
host
andaws_region
fields to be set at the same time, and always applies the SigV4 signature.
- The AWS region is now required. You can set it through the plugin configuration with the
- HTTP Log (
http-log
)- The
headers
field now only takes a single string per header name, where it previously took an array of values.
- The
- JWT (
jwt
)- The authenticated JWT is no longer put into the nginx context (
ngx.ctx.authenticated_jwt_token
). Custom plugins which depend on that value being set under that name must be updated to use Kong’s shared context instead (kong.ctx.shared.authenticated_jwt_token
) before upgrading to 3.0.
- The authenticated JWT is no longer put into the nginx context (
(
prometheus
)- High cardinality metrics are now disabled by default.
- Decreased performance penalty to proxy traffic when collecting metrics.
The following metric names were adjusted to add units to standardize where possible:
http_status
tohttp_requests_total
.latency
tokong_request_latency_ms
(HTTP),kong_upstream_latency_ms
,kong_kong_latency_ms
, andsession_duration_ms
(stream).Kong latency and upstream latency can operate at orders of different magnitudes. Separate these buckets to reduce memory overhead.
kong_bandwidth
tokong_bandwidth_bytes
.nginx_http_current_connections
andnginx_stream_current_connections
were merged into tonginx_connections_total
.request_count
andconsumer_status
were merged intohttp_requests_total
.If the
per_consumer
config is set tofalse
, theconsumer
label will be empty. If theper_consumer
config istrue
, theconsumer
label will be filled.
Removed the following metric:
http_consumer_status
- New metrics:
session_duration_ms
: monitoring stream connections.node_info
: Single gauge set to 1 that outputs the node’s ID and Kong Gateway version.
http_requests_total
has a new label,source
. It can be set toexit
,error
, orservice
.- All memory metrics have a new label:
node_id
. - Updated the Grafana dashboard that comes packaged with Kong #8712
- The plugin doesn’t export status codes, latencies, bandwidth and upstream health check metrics by default. They can still be turned on manually by setting
status_code_metrics
,lantency_metrics
,bandwidth_metrics
andupstream_health_metrics
respectively.
- Serverless Functions (
post-function
orpre-function
)- Removed the deprecated
config.functions
configuration parameter from the Serverless Functions plugins’ schemas. Use theconfig.access
phase instead.
- Removed the deprecated
StatsD (
statsd
):- Any metric name that is related to a service now has a
service.
prefix:kong.service.<service_identifier>.request.count
.- The metric
kong.<service_identifier>.request.status.<status>
has been renamed tokong.service.<service_identifier>.status.<status>
. - The metric
kong.<service_identifier>.user.<consumer_identifier>.request.status.<status>
has been renamed tokong.service.<service_identifier>.user.<consumer_identifier>.status.<status>
.
- The metric
- The metric
*.status.<status>.total
from metricsstatus_count
andstatus_count_per_user
has been removed.
- Any metric name that is related to a service now has a
Rate Limiting (
rate-limiting
), (rate-limiting-advanced
), and Response Rate Limiting (response-ratelimiting
):- The default policy is now local for all deployment modes.
- Deprecated: StatsD Advanced (
statsd-advanced
):- The StatsD Advanced plugin has been deprecated and will be removed in 4.0. All capabilities are now available in the plugin.
- Proxy Cache (
proxy-cache
), (proxy-cache-advanced
), and GraphQL Proxy Cache Advanced (graphql-proxy-cache-advanced
)- These plugins don’t store response data in
ngx.ctx.proxy_cache_hit
anymore. Logging plugins that need the response data must now read it fromkong.ctx.shared.proxy_cache_hit
.
- These plugins don’t store response data in
Configuration
- The Kong constant
CREDENTIAL_USERNAME
with the value ofX-Credential-Username
has been removed. - The default value of
lua_ssl_trusted_certificate
has changed tosystem
#8602 to automatically load the trusted CA list from the system CA store. - It is no longer possible to use a
.lua
format to import a declarative configuration file from thekong
CLI tool. Only JSON and YAML formats are supported. If your update procedure with Kong Gateway involves executingkong config db_import config.lua
, convert theconfig.lua
file into aconfig.json
orconfig.yml
file before upgrading. - The data plane config cache mechanism and its related configuration options (
data_plane_config_cache_mode
anddata_plane_config_cache_path
) have been removed in favor of LMDB.
Migrations
- The migration helper library (mostly used for Cassandra migrations) is no longer supplied with Kong Gateway.
- PostgreSQL migrations can now have an
up_f
part like Cassandra migrations, designating a function to call. Theup_f
part is invoked after theup
part has been executed against the database for both PostgreSQL and Cassandra.
Fixes
Enterprise
Fixed an issue with keyring encryption, where the control plane would crash if any errors occurred during the initialization of the keyring module.
Fixed an issue where the keyring module was not decrypting keys after a soft reload.
Fixed pagination issues:
- Fixed a consumer pagination issue.
- Fixed an issue that appeared when loading the second page while iterating over a foreign key field using the DAO.
Fixed service route update failures that occurred after restarting a control plane.
Vitals:
- Disabled
phone_home
foranonymous_reports
on the data plane. - The Kong Gateway version information is now sent in the telemetry request query parameter.
- Disabled
- Kong Manager:
- Fixed the workspace dashboard’s loading state. Previously, a dashboard with no request data and an existing service would still prompt users to add a service.
- Fixed an issue where Kong Manager allowed selection of metrics not supported by the Datadog plugin.
- Fixed the values accepted for upstream configuration in Kong Manager. Previously, fields that were supposed to accept decimals would only accept whole numbers.
- Fixed an issue where you couldn’t save or update
pre-function
plugin configuration when the updated value contained a comma (,
). - The service name field on the Service Contracts page now correctly shows the service display name. Previously, it showed the service ID.
- Fixed an issue where, after updating the CA certificate, the page wouldn’t return to the certificate view.
- Fixed an issue where the port was missing from the service URL on the service overview page.
- Fixed an issue where switching between workspace dashboard pages would not update the Dev Portal URL.
- Fixed issues with plugins:
- The Exit Transformer plugin can now load Lua functions added through Kong Manager.
- The CORS plugin now treats regexes properly for the
config.origins
field. - The Datadog plugin now accepts an array for the
tags
field. Previously, it was incorrectly expecting a string.
- Fixed an
HTTP 500
error that occurred when sorting routes by the Hosts column, then clicking Next on a paginated listing. - Fixed an issue that prevented developer role assignments from displaying in Kong Manager. When viewing a role under the Permissions tab in the Dev Portal section, the list of developers wouldn’t update when a new developer was added. Kong Manager was constructing the wrong URL when retrieving Dev Portal assignees.
- Fixed an issue where admins couldn’t switch workspaces if they didn’t have an roles in the default workspace.
- Fixed a display issue with Dev Portal settings in Kong Manager.
- Improved the error that appeared when trying to view admin roles without permissions for the resource. Instead of displaying
404 workspace not found
, the error now informs the user that they don’t have access to view roles.
- Fixed an issue where the data plane would reload and lose its license after an Nginx reload.
Fixed issues in dependencies:
kong-gql
: Fixed variable definitions to handle non-nullable/list-type variables correctly.lua-resty-openssl-aux-module
: Fixed an issue with gettingSSL_CTX
from a request.
Core
- The schema validator now correctly converts
null
from declarative configurations tonil
. - Kong now reschedules router and plugin iterator timers only after finishing the previous execution, avoiding unnecessary concurrent executions. #8567
- External plugins now handle returned JSON with null member correctly.
- Fixed an issue where the address of an environment variable could change but the code didn’t check that it was fixed after init. #8581
- Fixed an issue where the Go plugin server instance would not be updated after a restart.
- Fixed an issue on trying to reschedule the DNS resolving timer when Kong was being reloaded. #8702
- The private stream API has been rewritten to allow for larger message payloads.
- Fixed an issue that the client certificate sent to the upstream was not updated when using the
PATCH
method. #8934 - Fixed an issue where the control plane and wRPC module interaction would cause Kong to crash when calling
export_deflated_reconfigure_payload
without apcall
. - Moved all
.proto
files to/usr/local/kong/include
and ordered by priority. #8914 - Fixed an issue that caused unexpected 404 errors when creating or updating configs with invalid options.
- Fixed an issue that caused crashes when calling some PDK APIs. #8604
- Fixed an issue that caused crashes when go PDK calls returned arrays.
- Plugin servers now shutdown gracefully when Kong exits. #8923
- CLI now prompts with
[y/n]
instead of[Y/n]
, as it does not takey
as default. - Improved the error message that appears when Kong can’t connect to Cassandra on init. #8847
- Fixed an issue where the Vault subschema wasn’t loaded in the
off
strategy. - The schema now runs select transformations before
process_auto_fields
. #9049 - Fixed an issue where Kong Gateway would use too many timers to keep track of upstreams when
worker_consistency = eventual
. , #8858 - Fixed an issue where it wasn’t possible to set target status using only a hostname for targets set only by their hostname.
- Fixed an issue where cache entries of some entities were not being properly invalidated after a cascade delete. #9261
- Running
kong start
when Kong Gateway is already running no longer overwrites the existing.kong_env
file
Admin API
- The Admin API now supports
HTTP/2
when requesting/status
. - Fixed an issue where the Admin API didn’t display
Allow
andAccess-Control-Allow-Methods
headers withOPTIONS
requests.
Plugins
Plugins with colliding priorities have now deterministic sorting based on their name.
External plugins: Kong Gateway now handles logging better when a plugin instance loses the
instances_id
in an event handler. #8652(
acme
)- The default value of the
auth_method
configuration parameter is now set totoken
. #8565 - Added a cache for
domains_matcher
.
- The default value of the
- HTTP Log (
http-log
)- Log output is now restricted to the workspace the plugin is running in. Previously, the plugin could log requests from outside of its workspace.
- (
aws-lambda
) - (
forward-proxy
)- Fixed a proxy authentication error caused by incorrect base64 encoding.
- Use lowercase when overwriting the Nginx request host header.
- The plugin now allows multi-value response headers.
- gRPC Gateway (
grpc-gateway
)- Fixed the handling of boolean fields from URI arguments.
- HMAC Authentication (
hmac-auth
)- Removed deprecated signature format using
ngx.var.uri
.
- Removed deprecated signature format using
- LDAP Authentication (
ldap-auth
)- Refactored ASN.1 parser using OpenSSL API through FFI.
- LDAP Authentication Advanced (
ldap-auth-advanced
)- Fixed an issue where Kong Manager LDAP authentication failed when
base_dn
was the domain root.
- Fixed an issue where Kong Manager LDAP authentication failed when
- (
mocking
)- Fixed an issue where
204
responses were not handled correctly and you would see the following error:"No examples exist in API specification for this resource"
. 204
response specs now support empty content elements.
- Fixed an issue where
- OpenID Connect (
openid-connect
) openid-connect- Fixed an issue with
kong_oauth2
consumer mapping.
- Fixed an issue with
- (
rate-limiting
) and Response Rate Limiting (response-ratelimiting
)- Fixed a PostgreSQL deadlock issue that occurred when the
cluster
policy was used with two or more metrics (for example,second
andday
.)
- Fixed a PostgreSQL deadlock issue that occurred when the
- Rate Limiting Advanced (
rate-limiting-advanced
)- Fixed error handling when calling
get_window
and added more buffer on the window reserve. - Fixed error handling for plugin strategy configuration when in hybrid or DB-less mode and strategy is set to
cluster
.
- Fixed error handling when calling
- (
serverless-functions
)- Fixed a problem that could cause a crash. #9269
- (
syslog
)- The
conf.facility
default value is now set touser
. #8564
- The
- (
zipkin
)- Fixed the balancer spans’ duration to include the connection time from Nginx to the upstream. #8848
- Corrected the calculation of the header filter start time.
- Made the plugin compatible with the latest Jaeger header spec, which makes
parent_id
optional.
Clustering
- The cluster listener now uses the value of
admin_error_log
for its log file instead ofproxy_error_log
. - Fixed a typo in some business logic that checks the Kong role before setting a value in cache at startup. #9060
- Fixed an issue in hybrid mode where, if a service was set to
enabled: false
and that service had a route with an enabled plugin, any new data planes would receive empty configuration. - Localized
config_version
to avoid a race condition from the new yielding config loading code. #8188
PDK
kong.response.get_source()
now returns an error instead of an exit when plugin throws a runtime exception in the access phase. #8599kong.tools.uri.normalize()
now escapes reserved and unreserved characters more accurately.RFC3987 validation on route paths was removed, allowing operators to create a route with an invalid path URI like
/something|
which can not match any incoming request. This validation will be added back in a future release.
Dependencies
- Bumped
openresty
from 1.19.9.1 to 1.21.4.1 - Bumped
pgmoon
from 1.13.0 to 1.15.0 #8908 - Bumped
openssl
from 1.1.1n to 1.1.1q #9074 #8752 - Bumped
resty.openssl
from 0.8.8 to 0.8.10 #8592 #9023 - Bumped
inspect
from 3.1.2 to 3.1.3 - Bumped
resty.acme
from 0.7.2 to 0.8.1 #8680 - Bumped
luarocks
from 3.8.0 to 3.9.1 #8700 - Bumped
luasec
from 1.0.2 to 1.2.0 #8754 - Bumped
resty.healthcheck
from 1.5.0 to 1.6.1 #8755 #9150 - Bumped
resty.cassandra
from 1.5.1 to 1.5.2 - Bumped
penlight
from 1.12.0 to 1.13.1 #9206 - Bumped
lua-resty-mlcach
e from 2.5.0 to 2.6.0 - Bumped
lodash
for Dev Portal from 4.17.11 to 4.17.21 - Bumped
lodash
for Kong Manager from 4.17.15 to 4.17.21
2.8.2.2
Release Date 2022/12/01
Fixes
Core
Timer issue fixes:
Added batch queues for the Datadog and StatsD plugins to reduce timer usage, fixing a
lua_max_running_timers are not enough
timer error.Whenever a request was processed, a new running timer was instantly created during the log phase. This was causing a shortage of timers under heavy traffic and led to unpredictable consequences, where internal timers were killed randomly and couldn’t recover automatically. This would then trigger a
lua_max_running_timers are not enough
timer error and cause data planes to crash.Fixed a timer leak that occurred whenever the generic messaging protocol connection would break in hybrid mode.
2.8.2.1
Release Date 2022/11/21
Fixes
Enterprise
- Kong Manager:
- Fixed an issue where admins needed the specific
rbac/role
permission to edit RBAC roles. Now, admins can edit RBAC roles with the/admins
permission. - Fixed an issue where the client certificate ID didn’t display properly in the upstream update form.
- Fixed an issue in the service documents UI which allowed users to upload multiple documents. Since each service only supports one document, the documents would not display correctly. Uploading a new document now overrides the previous document.
- Fixed an issue where the New Workspace button on the global workspace dashboard wasn’t clickable on the first page load.
- Fixed an RBAC issue where the roles page listed deleted roles.
- Removed New Relic from Kong Manager. Previously,
VUE_APP_NEW_RELIC_LICENSE_KEY
andVUE_APP_SEGMENT_WRITE_KEY
were being exposed in Kong Manager with invalid values. - Fixed an RBAC issue where permissions applied to specific endpoints (for example, an individual service or route) were not reflected in the Kong Manager UI.
- Fixed an issue with group to role mapping, where it didn’t support group names with spaces.
- Fixed an issue with individual workspace dashboards, where right-clicking on View All and choosing “Open Link in New Tab” or “Copy Link” for services, routes, and plugins redirected to the default workspace and caused an
HTTP 404
error.
- Fixed an issue where admins needed the specific
- Dev Portal: Fixed an issue where Dev Portal response examples weren’t rendered when media type was vendor-specific.
Core
Targets with a weight of
0
are no longer included in health checks, and checking their status via theupstreams/<upstream>/health
endpoint results in the statusHEALTHCHECK_OFF
. Previously, theupstreams/<upstream>/health
endpoint was incorrectly reporting targets withweight=0
asHEALTHY
, and the health check was reporting the same targets asUNDEFINED
.Fixed the default
logrotate
configuration, which lacked permissions to access logs.
Plugins
- (
kafka-upstream
)- Fixed the
Bad Gateway
error that would occur when using the Kafka Upstream plugin with the configurationproducer_async=false
.
- Fixed the
- Response Transformer (
response-transformer
)- Fixed an issue where the plugin couldn’t process string responses.
- (
mtls-auth
)- Fixed an issue where the plugin was causing requests to silently fail on Kong Gateway data planes.
- Request Transformer (
request-transformer
)- Fixed an issue where empty arrays were being converted to empty objects. Empty arrays are now preserved.
- (
azure-functions
)- Fixed an issue where calls made by this plugin would fail in the following situations:
- The plugin was associated with a route that had no service.
- The route’s associated service had a
path
value.
- Fixed an issue where calls made by this plugin would fail in the following situations:
- LDAP Auth Advanced (
ldap-auth-advanced
)- Fixed an issue where operational attributes referenced by
group_member_attribute
weren’t returned in search query results.
- Fixed an issue where operational attributes referenced by
2.8.2.0
Release Date 2022/10/12
Fixes
Enterprise
- Kong Manager:
- Fixed an issue where workspaces with zero roles were not correctly sorted by the number of roles.
- Fixed the Cross Site Scripting (XSS) security vulnerability in the Kong Manager UI.
- Fixed an issue where registering an admin without
admin_gui_auth
set resulted in a500
error. - Fixed an issue that allowed unauthorized IDP users to log in to Kong Manager. These users had no access to any resources in Kong Manager, but were able to go beyond the login screen.
- Fixed OpenSSL vulnerabilities CVE-2022-2097 and .
- Hybrid mode: Fixed an issue with consumer groups, where the control plane wasn’t sending the correct number of consumer entries to data planes.
- Hybrid mode: Fixed an issue where sending a
PATCH
request to update a route after restarting a control plane caused a 500 error response.
Plugins
- (
aws-lambda
)- Fixed an issue where the plugin couldn’t read environment variables in the ECS environment, causing permission errors.
- Forward Proxy (
forward-proxy
)- If the
https_proxy
configuration parameter is not set, it now defaults tohttp_proxy
to avoid DNS errors.
- If the
- (
graphql-proxy-cache-advanced
) and Proxy Cache Advanced (proxy-cache-advanced
)- Fixed the error
function cannot be called in access phase (only in: log)
, which was preventing the plugin from working consistently.
- Fixed the error
- (
graphql-rate-limiting-advanced
)- The plugin now returns a
500
error when using thecluster
strategy in hybrid or DB-less modes instead of crashing.
- The plugin now returns a
- LDAP Authentication Advanced (
ldap-auth-advanced
)- The characters
.
and:
are now allowed in group attributes.
- The characters
- (
openid-connect
)- Fixed issues with OIDC role mapping where admins couldn’t be added to more than one workspace, and permissions were not being updated.
- Request Transformer Advanced (
request-transformer-advanced
)- Fixed an issue where empty arrays were being converted to empty objects. Empty arrays are now preserved.
- (
route-transformer-advanced
)- Fixed an issue where URIs that included
%20
or a whitespace would return a400 Bad Request
.
- Fixed an issue where URIs that included
2.8.1.4
Release Date 2022/08/23
Fixed vulnerabilities and CVE-2022-24975.
When using secrets management in free mode, only the backend is available. AWS, GCP, and HashiCorp vault backends require an Enterprise license.
Fixed an issue in Kong Manager where entity detail pages were empty and didn’t list existing entities. The following entities were affected:
- Route lists on service pages
- Upstreams
- Certificates
- SNIs
- RBAC roles
- Fixed an issue where the browser hung when creating an upstream with the existing host and port.
Plugins
- (
openid-connect
)- Fixed a caching issue in hybrid mode, where the data plane node would try to retrieve a new JWK from the IdP every time. The data plane node now looks for a cached JWK first.
- Proxy Caching Advanced (
proxy-cache-advanced
)- Fixed an issue that prevented users from removing the cluster addresses on an existing configuration.
Dependencies
- Bump
lua-resty-aws
version to 0.5.4 to reduce memory usage when AWS vault is enabled. #23 - Bump
lua-resty-gcp
version to 0.0.5 to reduce memory usage when GCP vault is enabled.
2.8.1.3
Release Date 2022/08/05
Features
Enterprise
- Added GCP integration support for the secrets manager. GCP is now available as a vault backend.
Plugins
- AWS Lambda (
aws-lambda
)- Added support for cross-account lambda function invocation based on AWS roles.
Fixes
Enterprise
- Fixed an issue with excessive log file disk utilization on control planes.
- Fixed an issue with keyring encryption, where keyring was not decrypting keys after a soft reload.
- The router now detects static route collisions inside the current workspace, as well as with other workspaces.
- When using a custom plugin in a hybrid mode deployment, the control plane now detects compatibility issues and stops sending the plugin configuration to data planes that can’t use it. The control plane continues sending the custom plugin configuration to compatible data planes.
- Optimized the Kong PDK function
kong.response.get_source()
.
Kong Manager
- Fixed an issue with admin creation. Previously, when an admin was created with no roles, the admin would have access to the first workspace listed alphabetically.
- Fixed several issues with SNI listing. Previously, the SNI list was empty after sorting by the SSL certificate ID field. In 2.8.1.1, the SSL certificate ID field in the SNI list was empty.
Plugins
- (
mocking
)- Fixed an issue where the plugin didn’t accept empty values in examples.
- ACME (
acme
)- The
domains
plugin parameter can now be left empty. Whendomains
is empty, all TLDs are allowed. Previously, the parameter was labelled as optional, but leaving it empty meant that the plugin retrieved no certificates at all.
- The
- (
response-transformer-advanced
)- Fixed an issue with nested array parsing.
- Rate Limiting Advanced (
rate-limiting-advanced
)- Fixed an issue with
cluster
strategy timestamp precision in Cassandra.
- Fixed an issue with
2.8.1.2
Release Date 2022/07/15
Fixes
Enterprise
- Fixed an issue in hybrid mode where, if a service was set to
enabled: false
and that service had a route with an enabled plugin, any new data planes would receive empty configuration. - Fixed a timer leak that occurred when
worker_consistency
was set toeventual
inkong.conf
. This issue caused timers to be exhausted and failed to start any other timers used by Kong Gateway, resulting in atoo many pending timers
error. - Fixed memory leaks coming from
lua-resty-lock
. - Fixed global plugins can operate out of the workspace scope
Kong Manager and Dev Portal
- Fixed an issue where Kong Manager did not display all Dev Portal developers in the organization.
- Fixed an issue that prevented developer role assignments from displaying in Kong Manager. When viewing a role under the Permissions tab in the Dev Portal section, the list of developers wouldn’t update when a new developer was added. Kong Manager was constructing the wrong URL when retrieving Dev Portal assignees.
- Fixed empty string handling in Kong Manager. Previously, Kong Manager was handling empty strings as
""
instead of a null value. - Improved Kong Manager styling by fixing an issue where content didn’t fit on object detail pages.
- Fixed an issue that sometimes prevented clicking Kong Manager links and buttons in Safari.
- Fixed an issue where users were being navigated to the object detail page after clicking on the “Copy ID” button from the object list.
- Fixed an issue where the number of requests and error rate were not correctly displaying when Vitals was disabled.
Plugins
- Rate Limiting (
rate-limiting
) and (response-ratelimiting
)- Fixed a PostgreSQL deadlock issue that occurred when the
cluster
policy was used with two or more metrics (for example,second
andday
.)
- Fixed a PostgreSQL deadlock issue that occurred when the
- HTTP Log (
http-log
)- Log output is now restricted to the workspace the plugin is running in. Previously, the plugin could log requests from outside of its workspace.
- (
mocking
)- Fixed an issue where
204
responses were not handled correctly and you would see the following error:"No examples exist in API specification for this resource"
. 204
response specs now support empty content elements.
- Fixed an issue where
Deprecated
Amazon Linux 1: Support for running Kong Gateway on Amazon Linux 1 is now deprecated, as the . Starting with Kong Gateway 3.0.0.0, Kong is not building new Amazon Linux 1 images or packages, and Kong will not test package installation on Amazon Linux 1.
If you need to install Kong Gateway on Amazon Linux 1, see the documentation for previous versions.
Debian 8: Support for running Kong Gateway on Debian 8 (“Jessie”) is now deprecated, as . Starting with Kong Gateway 3.0.0.0, Kong is not building new Debian 8 (“Jessie”) images or packages, and Kong will not test package installation on Debian 8 (“Jessie”).
If you need to install Kong Gateway on Debian 8 (“Jessie”), see the documentation for previous versions.
Ubuntu 16.04: Support for running Kong Gateway on Ubuntu 16.04 (“Xenial”) is now deprecated, as . Starting with Kong Gateway 3.0.0.0, Kong is not building new Ubuntu 16.04 images or packages, and Kong will not test package installation on Ubuntu 16.04.
If you need to install Kong Gateway on Ubuntu 16.04, see the documentation for previous versions.
2.8.1.1
Release Date 2022/05/27
Features
Enterprise
- You can now enable application status and application request emails for the Developer Portal using the following configuration parameters:
- portal_application_status_email: Enable to send application request status update emails to developers.
- : Enable to send service access request emails to users specified in
smtp_admin_emails
. - portal_smtp_admin_emails: Specify the email addresses to send portal admin emails to, overriding values set in
smtp_admin_emails
.
- Added the ability to use
email.developer_meta
fields in portal email templates. For example,{{email.developer_meta.preferred_name}}
.
Plugins
- AWS Lambda (
aws-lambda
)- When working in proxy integration mode, the
statusCode
field now accepts string datatypes.
- When working in proxy integration mode, the
- (
mtls-auth
)- Introduced certificate revocation list (CRL) and OCSP server support with the following parameters:
http_proxy_host
,http_proxy_port
,https_proxy_host
, andhttps_proxy_port
.
- Introduced certificate revocation list (CRL) and OCSP server support with the following parameters:
- Kafka Upstream (
kafka-upstream
) and (kafka-log
)- Added support for the
SCRAM-SHA-512
authentication mechanism.
- Added support for the
Fixes
Enterprise
Improved Kong Admin API and Kong Manager performance for organizations with many entities.
Fixed an issue with keyring encryption, where the control plane would crash if any errors occurred during the initialization of the keyring module.
Fixed an issue where Kong Manager did not display all RBAC users and Consumers in the organization.
Fixed an issue where some areas in a row of a list were not clickable.
Plugins
- Rate Limiting Advanced (
rate-limiting-advanced
)- Fixed rate limiting advanced errors that appeared when the Rate Limiting Advanced plugin was not in use.
- Fixed an error where rate limiting counters were not updating response headers due to incorrect key expiration tracking. Redis key expiration is now tracked properly in
lua_shared_dict kong_rate_limiting_counters
.
- (
forward-proxy
)- Fixed an
invalid header value
error for HTTPS requests. The plugin now accepts multi-value response headers. - Fixed an error where basic authentication headers containing the
=
character weren’t forwarded. - Fixed request errors that occurred when a scheme had no proxy set. The
https
proxy now falls back to thehttp
proxy if not specified, and thehttp
proxy falls back tohttps
.
- Fixed an
- GraphQL Rate Limiting Advanced (
graphql-rate-limiting-advanced
)- Fixed
deserialize_parse_tree
logic when building GraphQL AST with non-nullable or list types.
- Fixed
2.8.1.0
Release Date 2022/04/07
Fixes
Enterprise
- Fixed an issue with RBAC where
endpoint=/kong workspace=*
would not let the/kong
endpoint be accessed from all workspaces - Fixed an issue with RBAC where admins without a top level
endpoint=*
permission could not add any RBAC rules, even if they hadendpoint=/rbac
permissions. These admins can now add RBAC rules for their current workspace only. - Kong Manager
- Serverless functions can now be saved when there is a comma in the provided value
- Custom plugins now show an Edit button when viewing the plugin configuration
- Editing Dev Portal permissions no longer returns a 404 error
- Fix an issue where admins with access to only non-default workspaces could not see any workspaces
- Show the workspace name when an admin only has access to non-default workspaces
- Add support for table filtering and sorting when using Cassandra
- Support the # character in RBAC tokens on the RBAC edit page
- Performing an action on an upstream target no longer leads to a 404 error
- Developer Portal
- Information about the current session is now bound to an nginx worker thread. This prevents data leaks when a worker is handling multiple requests at the same time
- Keys are no longer rotated unexpectedly when a node restarts
- Add cache when performing RBAC token verification
- The log message “plugins iterator was changed while rebuilding it” was incorrectly logged as an
error
. This release converts it to theinfo
log level. - Fixed a 500 error when rate limiting counters are full with the Rate Limiting Advanced plugin
- Improved the performance of the router, plugins iterator and balancer by adding conditional rebuilding
Plugins
- (
http-log
)- Include provided query string parameters when sending logs to the
http_endpoint
- Include provided query string parameters when sending logs to the
- Forward Proxy (
forward-proxy
)- Use lowercase when overwriting the
host
header
- Use lowercase when overwriting the
- (
statsd-advanced
)- Added support for setting
workspace_identifier
toworkspace_name
- Added support for setting
- Rate Limiting Advanced (
rate-limiting-advanced
)- Skip namespace creation if the plugin is not enabled. This prevents the error “[rate-limiting-advanced] no shared dictionary was specified” being logged.
- (
ldap-auth-advanced
)- Support passwords that contain a
:
character
- Support passwords that contain a
- OpenID Connect (
openid-connect
)- Provide valid upstream headers e.g.
X-Consumer-Id
,X-Consumer-Username
- Provide valid upstream headers e.g.
- (
jwt-signer
)- Implement the
enable_hs_signatures
option to enable JWTs signed with HMAC algorithms
- Implement the
Dependencies
- Bumped
openssl
from 1.1.1k to 1.1.1n to resolve CVE-2022-0778 - Bumped
openresty
from 1.19.3.2 to 1.19.9.1 #7727
2.8.0.0
Release Date 2022/03/02
Features
Enterprise
- Improved tables in Kong Manager: (for PostgreSQL-backed instances only)
- Click on a table row to access the entry instead of using the old View icon.
- Search and filter tables through the Filters dropdown, which is located above the table.
- Sort any table by clicking on a column title.
- Tables now have pagination.
- Kong Manager with OIDC:
- Added the configuration option admin_auto_create_rbac_token_disabled to enable or disable RBAC tokens when automatically creating admins with OpenID Connect.
- If a license is present,
license_key
is now included in theapi
signal for .
Dev Portal
- The new
/developers/export
endpoint lets you export the list of developers and their statuses into CSV format.
Core
Beta feature: Kong Gateway 2.8.0.0 introduces secrets management and vault support. You can now store confidential values such as usernames and passwords as secrets in secure vaults. Kong Gateway can then reference these secrets, making your environment more secure.
The beta includes
get
support for the following vault implementations:As part of this support, some plugins have certain fields marked as referenceable. See the plugin section of the Kong Gateway 2.8 changelog for details.
Test out secrets management using the getting started guide, and check out the documentation for the Kong Admin API .
You can customize the transparent dynamic TLS SNI name.
Thanks, @zhangshuaiNB!
Routes now support matching headers with regular expressions.
Thanks, @vanhtuan0409!
You can now configure cluster_max_payload for hybrid mode deployments. This configuration option sets the maximum payload size allowed to be sent across from the control plane to the data plane. If your environment has large configurations that generate
payload too big
errors and don’t get applied to the data planes, use this setting to adjust the limit.Thanks, ! #8337
Performance
Improved the calculation of declarative configuration hash for big configurations. The new method is faster and uses less memory. #8204
Multiple improvements in the Router, including:
- The router builds twice as fast
- Failures are cached and discarded faster (negative caching)
- Routes with header matching are cached
These changes should be particularly noticeable when rebuilding in DB-less environments. #8010
Admin API
- The current declarative configuration hash is now returned by the
status
endpoint when Kong node is running in DB-less or data plane mode. #8214
Plugins
- (
canary
)- Added the ability to configure
canary_by_header_name
. This parameter accepts a header name that, when present on a request, overrides the configured canary functionality.- If the configured header is present with the value
always
, the request will always go to the canary upstream. - If the header is present with the value
never
, the request will never go to the canary upstream.
- If the configured header is present with the value
- Added the ability to configure
- Prometheus (
prometheus
)- Added three new metrics:
kong_db_entities_total
(gauge): total number of entities in the database.kong_db_entity_count_errors
(counter): measures the number of errors encountered during the measurement ofkong_db_entities_total
.kong_nginx_timers
(gauge): total number of Nginx timers, in Running or Pending state. Tracksngx.timer.running_count()
andngx.timer.pending_count()
.
- Added three new metrics:
OpenID Connect (
openid-connect
)Added Redis ACL support (Redis v6.0.0+) for storing and retrieving a session. Use the
session_redis_username
andsession_redis_password
configuration parameters to configure it.These parameters replace the
session_redis_auth
field, which is now deprecated and planned to be removed in 3.x.x.Added support for distributed claims. Set the
resolve_distributed_claims
configuration parameter totrue
to tell OIDC to explicitly resolve distributed claims.Distributed claims are represented by the
_claim_names
and_claim_sources
members of the JSON object containing the claims.Beta feature: The
client_id
,client_secret
,session_secret
,session_redis_username
, andsession_redis_password
configuration fields are now marked as referenceable, which means they can be securely stored as in a vault. References must follow a specific format.
(
forward-proxy
)Added
http_proxy_host
,http_proxy_port
,https_proxy_host
, andhttps_proxy_port
configuration parameters for mTLS support.These parameters replace the
proxy_port
andproxy_host
fields, which are now deprecated and planned to be removed in 3.x.x.The
auth_password
andauth_username
configuration fields are now marked as referenceable, which means they can be securely stored as secrets in a vault. References must follow a .
Kafka Upstream (
kafka-upstream
) and (kafka-log
)Added the ability to identify a Kafka cluster using the
cluster_name
configuration parameter. By default, this field generates a random string. You can also set your own custom cluster identifier.Beta feature: The
authentication.user
andauthentication.password
configuration fields are now marked as referenceable, which means they can be securely stored as secrets in a vault. References must follow a .
LDAP Authentication Advanced (
ldap-auth-advanced
)- Beta feature: The
ldap_password
andbind_dn
configuration fields are now marked as referenceable, which means they can be securely stored as in a vault. References must follow a specific format.
- Beta feature: The
(
vault-auth
)- Beta feature: The
vaults.vault_token
form field is now marked as referenceable, which means it can be securely stored as a secret in a vault. References must follow a .
- Beta feature: The
GraphQL Rate Limiting Advanced (
graphql-rate-limiting-advanced
)Added Redis ACL support (Redis v6.0.0+ and Redis Sentinel v6.2.0+).
Added the
redis.username
andredis.sentinel_username
configuration parameters.Beta feature: The
redis.username
,redis.password
,redis.sentinel_username
, andredis.sentinel_password
configuration fields are now marked as referenceable, which means they can be securely stored as in a vault. References must follow a specific format.
(
rate-limiting
)Rate Limiting Advanced (
rate-limiting-advanced
)Added Redis ACL support (Redis v6.0.0+ and Redis Sentinel v6.2.0+).
Added the
redis.username
andredis.sentinel_username
configuration parameters.Beta feature: The
redis.username
,redis.password
,redis.sentinel_username
, andredis.sentinel_password
configuration fields are now marked as referenceable, which means they can be securely stored as in a vault. References must follow a specific format.
(
response-ratelimiting
)- Added Redis ACL support (Redis v6.0.0+ and Redis Sentinel v6.2.0+).
Added the
redis_username
configuration parameter.Thanks, @27ascii for the original contribution!
Response Transformer Advanced (
response-transformer-advanced
)- Use response buffering from the PDK.
(
proxy-cache-advanced
)Added Redis ACL support (Redis v6.0.0+ and Redis Sentinel v6.2.0+).
Added the
redis.sentinel_username
andredis.sentinel_password
configuration parameters.Beta feature: The
redis.password
,redis.sentinel_username
, andredis.sentinel_password
configuration fields are now marked as referenceable, which means they can be securely stored as secrets in a vault. References must follow a .
jq (
jq
)- Use response buffering from the PDK.
(
acme
)Added the
rsa_key_size
configuration parameter.Thanks, lodrantl!
Fixes
Enterprise
Fixed an issue where, if
data_plane_config_cache_mode
was set tooff
, the data plane received no updates from the control plane.Fixed
attempt to index local 'workspace'
error, which occurred when accessing Routes or Services using TLS.Fixed an issue where cluster_telemetry_server_name was not automatically generated and registered if it was not explicitly set.
Fixed the setting. When using PKI for certificate verification in hybrid mode, you can now configure a list of Common Names allowed to connect to a control plane with the option. If not set, only data planes with the same parent domain as the control plane cert are allowed.
Kong Manager
Fixed an issue where OIDC authentication into Kong Manager failed when used with Azure AD.
Fixed a performance issue with the Teams page in Kong Manager.
Fixed an issue with checkboxes in Kong Manager, where the checkbox for the OAuth2 plugin’s
hash_secret
value was labelled as Required and users were not able to uncheck it.Fixed an issue where Kong Manager was not updating plugin configuration when attempting to clear the
service.id
from a plugin.Fixes an issue with Route creation in Kong Manager, where a new route would default to
http
as the supported protocol. Now, creating a Route picks up the correct default value, which ishttp,https
.Kong Manager now accurately lists
udp
as a protocol option for Route and Service objects on their configuration pages.Fixed an issue with Kong Manager OIDC authentication, which caused the error
“attempt to call method 'select_by_username_ignore_case' (a nil value)”
and prevented login with OIDC.Fixed a latency issue with OAuth2 token creation. These tokens are no longer tracked by the workspace entity counter, as the count is not needed by the Kong Manager UI.
Fixed an issue where the plugin list table couldn’t be sorted by the Applied To column.
Dev Portal
When the SMTP configuration was broken or unresponsive, the API would respond with an error message that was a JavaScript Object (
[Object object]
) instead of a string. This happened when a user was registering on any given portal with broken SMTP. Now, if there is an error, the API responds with the stringError sending email
.The
/document_objects
and/services/:id/document_objects
endpoints no longer accept multiple documents per service. This was an issue, as each service can only have one document. Instead, posting a document to one of these endpoints now overrides the previous document.
Core
When the Router encounters an SNI FQDN with a trailing dot (
.
), the dot will be ignored, since according to the dot is not part of the hostname. #8269Fixed a bug in the Router that would not prioritize the routes with both a wildcard and a port (
route.*:80
) over wildcard-only routes (route.*
), which have less specificity.The internal DNS client isn’t confused by the single-dot (
.
) domain, which can appear in/etc/resolv.conf
in special cases likesearch .
#8307The Cassandra connector now records migration consistency level.
Thanks, ! #8226
Balancer
Targets now keep their health status when upstreams are updated. #8394
One debug message which was erroneously using the
error
log level has been downgraded to the appropriatedebug
log level.
Clustering
- Replaced a cryptic error message with a more useful one when there is a failure on SSL when connecting with the control plane.
Admin API
- Fixed an incorrect
next
field that appeared when paginating Upstreams.
PDK
- Phase names are now correctly selected when performing phase checks.
- Fixed a bug in the go-PDK where, if
kong.request.getrawbody
was big enough to be buffered into a temporary file, it would return an an empty string. #8390
Plugins
External Plugins:
CORS (
cors
)The CORS plugin does not send the
Vary: Origin
header anymore when the headerAccess-Control-Allow-Origin
is set to*
.Thanks, ! #8401
(
aws-lambda
)- Fixed incorrect behavior when configured to use an HTTP proxy and deprecated the
proxy_scheme
config attribute for removal in 3.0. #8406
- Fixed incorrect behavior when configured to use an HTTP proxy and deprecated the
- (
oauth2
)- The plugin clears the
X-Authenticated-UserId
andX-Authenticated-Scope
headers when it is configured in logical OR and is used in conjunction with another authentication plugin. #8422
- The plugin clears the
- (
datadog
)- The plugin schema now lists the default values for configuration options in a single place instead of in two separate places. #8315
- (
rate-limiting
)- Fixed a 500 error associated with performing arithmetic functions on a nil value by adding a nil value check after performing
ngx.shared.dict
operations.
- Fixed a 500 error associated with performing arithmetic functions on a nil value by adding a nil value check after performing
Rate Limiting Advanced (
rate-limiting-advanced
)Fixed a 500 error that occurred when consumer groups were enforced but no proper configurations were provided. Now, if no specific consumer group configuration exists, the consumer group defaults to the original plugin configuration.
Fixed a timer leak that caused the timers to be exhausted and failed to start any other timers used by Kong, showing the error
too many pending timers
.Before, the plugin used one timer for each namespace maintenance process, increasing timer usage on instances with a large number of rate limiting namespaces. Now, it uses a single timer for all namespace maintenance.
Fixed an issue where the
local
strategy was not working with DB-less and hybrid deployments. We now allowsync_rate = null
andsync_rate = -1
when alocal
strategy is defined.
(
exit-transformer
)- Fixed an issue where the Exit Transformer plugin would break the plugin iterator, causing later plugins not to run.
mTLS Authentication (
mtls-auth
)- Fixed
attempt to index local 'workspace'
error, which occurred when accessing Routes or Services using TLS.
- Fixed
(
oauth2-introspection
)- Fixed issues with TLS connections when the IDP is behind a reverse proxy.
Proxy Cache Advanced (
proxy-cache-advanced
)- Fixed a
X-Cache-Status:Miss
error that occurred when caching large files.
- Fixed a
(
proxy-cache-advanced
)- Fixed a
X-Cache-Status:Miss
error that occurred when caching large files.
- Fixed a
Response Transformer Advanced (
response-transformer-advanced
)- In the
body_filter
phase, the plugin now sets the body to an empty string instead ofnil
.
- In the
(
jq
)- If plugin has no output, it will now return the raw body instead of attempting to restore the original response body.
OpenID Connect (
openid-connect
)- Fixed negative caching, which was loading wrong a configuration value.
(
jwt-signer
)- Fixed an issue where the
enable_hs_signatures
configuration parameter did not work. The plugin now defines expiry earlier to avoid arithmetic on a nil value.
- Fixed an issue where the
Dependencies
- Bumped OpenSSL from 1.1.1l to 1.1.1m
- Bumped
resty.session
from 3.8 to 3.10 #8294 - Bumped
lua-resty-openssl
to 0.8.5 - Bumped
lodash
for Dev Portal from 4.17.11 to 4.17.21 - Bumped
lodash
for Kong Manager from 4.17.15 to 4.17.21
Deprecated
The external
go-pluginserver
project is considered deprecated in favor of the .Starting with Kong Gateway 2.8.0.0, Kong is not building new open-source CentOS images. Support for running open-source Kong Gateway on CentOS on is now deprecated, as CentOS has reached End of Life (OEL).
Running Kong Gateway Enterprise on CentOS is currently supported, but CentOS is planned to be fully deprecated in Kong Gateway 3.x.x.
OpenID Connect plugin: The
session_redis_auth
field is now deprecated and planned to be removed in 3.x.x. Usesession_redis_username
andsession_redis_password
instead.Forward Proxy Advanced plugin: The
proxy_port
andproxy_host
fields are now deprecated and planned to be removed in 3.x.x. Usehttp_proxy_host
andhttp_proxy_port
, orhttps_proxy_host
andhttps_proxy_port
instead.AWS Lambda plugin: The
proxy_scheme
field is now deprecated and planned to be removed in 3.x.x.
2.7.2.0
Release Date 2022/04/07
Fixes
Enterprise
- Fixed an issue with RBAC where
endpoint=/kong workspace=*
would not let the/kong
endpoint be accessed from all workspaces - Fixed an issue with RBAC where admins without a top level
endpoint=*
permission could not add any RBAC rules, even if they hadendpoint=/rbac
permissions. These admins can now add RBAC rules for their current workspace only. - Kong Manager
- Enable the
search_user_info
option when using OpenID Connect (OIDC) - Fix broken docs links on the Upstream page
- Serverless functions can now be saved when there is a comma in the provided value
- Custom plugins now show an Edit button when viewing the plugin configuration
- Enable the
- Add cache when performing RBAC token verification
- The log message “plugins iterator was changed while rebuilding it” was incorrectly logged as an
error
. This release converts it to theinfo
log level. - Fixed a 500 error when rate limiting counters are full with the Rate Limiting Advanced plugin
Plugins
- (
http-log
)- Include provided query string parameters when sending logs to the
http_endpoint
- Include provided query string parameters when sending logs to the
- Forward Proxy (
forward-proxy
)- Fix timeout issues with HTTPs requests by setting
https_proxy_host
to the same value ashttp_proxy_host
- Use lowercase when overwriting the
host
header - Add support for basic authentication when using a secured proxy with HTTPS requests
- Fix timeout issues with HTTPs requests by setting
- (
statsd-advanced
)- Added support for setting
workspace_identifier
toworkspace_name
- Added support for setting
- Rate Limiting Advanced (
rate-limiting-advanced
)- Skip namespace creation if the plugin is not enabled. This prevents the error “[rate-limiting-advanced] no shared dictionary was specified” being logged.
- (
proxy-cache-advanced
)- Large files would not be cached due to memory usage, leading to a
X-Cache-Status:Miss
response. This has now been resolved
- Large files would not be cached due to memory usage, leading to a
- GraphQL Proxy Cache Advanced (
graphql-proxy-cache-advanced
)- Large files would not be cached due to memory usage, leading to a
X-Cache-Status:Miss
response. This has now been resolved
- Large files would not be cached due to memory usage, leading to a
- (
ldap-auth-advanced
)- Support passwords that contain a
:
character
- Support passwords that contain a
Dependencies
- Bumped
openssl
from 1.1.1k to 1.1.1n to resolve CVE-2022-0778 - Bumped
openresty
from 1.19.3.2 to 1.19.9.1 #7727
2.7.1.2
Release Date 2022/02/17
Fixes
Enterprise
- Fixed an issue with Kong Manager OIDC authentication, which caused the error
“attempt to call method 'select_by_username_ignore_case' (a nil value)”
and prevented login with OIDC. - Fixed an issue where common names added to
cluster_allowed_common_names
did not work.
2.7.1.1
Release Date 2022/02/04
Fixes
Enterprise
- Fixed a performance issue with Kong Manager, which occurred when admins had access to multiple workspaces.
- Fixed the
attempt to index local 'workspace'
error, which occurred when accessing Routes or Services using TLS.
2.7.1.0
Release Date: 2022/01/27
Features
Enterprise
- You can now configure cluster_max_payload for hybrid mode deployments. This configuration option sets the maximum payload size allowed to be sent across from the control plane to the data plane. If your environment has large configurations that generate
payload too big
errors and don’t get applied to the data planes, use this setting to adjust the limit. - When using PKI for certificate verification in hybrid mode, you can now configure a list of Common Names allowed to connect to a control plane with the option. If not set, only data planes with the same parent domain as the control plane cert are allowed.
Fixes
Enterprise
- Fixed an issue where OIDC authentication into Kong Manager failed when used with Azure AD.
- Fixed a timer leak that caused the timers to be exhausted and failed to start any other timers used by Kong, showing the error
too many pending timers
. - Fix an issue where, if
data_plane_config_cache_mode
was set tooff
, the data plane received no updates from the control plane.
Core
- Reschedule resolve timer only when the previous one has finished.
- Plugins, and any entities implemented with subchemas, now can use the
transformations
andshorthand_fields
properties, which were previously only available for non-subschema entities. #8146
Plugins
Rate Limiting (
rate-limiting
)- Fixed a 500 error associated with performing arithmetic functions on a nil value by adding a nil value check after performing
ngx.shared.dict
operations. Fixed a timer leak that caused the timers to be exhausted and failed to start any other timers used by Kong, showing the error
too many pending timers
.Before, the plugin used one timer for each namespace maintenance process, increasing timer usage on instances with a large number of rate limiting namespaces. Now, it uses a single timer for all namespace maintenance.
- Fixed a 500 error associated with performing arithmetic functions on a nil value by adding a nil value check after performing
(
rate-limiting-advanced
)- Fixed a 500 error that occurred when consumer groups were enforced but no proper configurations were provided. Now, if no specific consumer group configuration exists, the consumer group defaults to the original plugin configuration.
- Exit Transformer (
exit-transformer
)- Fix an issue where the Exit Transformer plugin would break the plugin iterator, causing later plugins not to run.
2.7.0.0
Release Date: 2021/12/16
Features
Enterprise
- Kong Gateway now supports installations on Debian 10 and 11.
This release introduces consumer groups, a new entity that lets you manage custom rate limiting configuration for any defined subsets of consumers. To use consumer groups for rate limiting, configure the plugin with the
enforce_consumer_groups
andconsumer_groups
parameters, and use the/consumer_groups
endpoint to manage the groups.This is useful for managing consumers with same rate limiting settings, as you can create a consumer group and one Rate Limiting Advanced plugin instance for the group to reduce proxy delay.
- Consumer groups reference
-
This feature is currently not supported with declarative configuration.
The data plane configuration cache can now be encrypted or turned off entirely. Two new configuration options have been added:
- data_plane_config_cache_mode: The cache can be
unencrypted
,encrypted
, oroff
. - : Use this setting to specify a custom path for the cache.
- data_plane_config_cache_mode: The cache can be
- The
/license/report
API endpoint now provides monthly throughput usage reports.
Dev Portal
- The Dev Portal API now supports
sort_by={attribute}
andsort_desc
query parameters for sorted list results. Improvements to Dev Portal authentication with OpenID Connect (OIDC): If OIDC auth is enabled, the first time a user attempts to access the Dev Portal using their IDP credentials, they are directed to a pre-filled registration form. Submit the form to create a Dev Portal account, linking the account to your IDP.
After linking, you can use your IDP credentials to directly access this Dev Portal account.
Added TLSv1.3 support for the Dev Portal API and GUI.
Kong Manager
When using OpenID Connect to secure Kong Manager, you no longer need to create admins manually in Kong Manager and map their roles to your identity provider. Instead, admins are created on first login and their roles are assigned based on their group membership in your IdP. This feature also partly resolves a problem with creating admins for both Kong Manager and Dev Portal.
Kong Manager now provides a simplified, organized form for configuring the OpenID Connect plugin. Users can now easily identify a common set of required parameters to configure the plugin, and add custom configurations as needed.
Core
Service entities now have a required enabled field which defaults to
true
. When set tofalse
, routes attached to the service are not added to the proxy router.In hybrid mode:
- If
enabled
is set tofalse
for a service, the service and its attached routes and plugins are not exported to data planes. - If
enabled
is set tofalse
for a plugin, plugins are now also not exported to data planes, regardless of the service setting.
- If
- DAOs in plugins must be listed in an array, so that their loading order is explicit. Loading them in a hash-like table is now deprecated. #7942
- Added the ability to without terminating the connection. #6757
Performance
In this release, we continued our work on better performance:
- Improved the plugin iterator performance and JITability #7912
- Simplified the Kong core context read and writes for better performance #7919
- Reduced proxy long tail latency while reloading DB-less config
PDK
- Added two new functions for the
body_filter
phase: and kong.response.set_raw_body.
Plugins
- (
openid-connect
)- Added support for JWT algorithm RS384.
- The plugin now allows Redis Cluster nodes to be specified by hostname through the
session_redis_cluster_nodes
field, which is helpful if the cluster IPs are not static.
- (
rate-limiting-advanced
)- Added the
enforce_consumer_groups
andconsumer_groups
parameters, which introduce support for consumer groups. With consumer groups, you can manage custom rate limiting configuration for any defined subsets of consumers.
- Added the
- Forward Proxy (
forward-proxy
)- Added two proxy authentication parameters,
auth_username
andauth_password
.
- Added two proxy authentication parameters,
- (
mocking
)- Added the
random_examples
parameter. Use this setting to randomly select one example from a set of mocked responses.
- Added the
IP-Restriction (
ip-restriction
)Response status and message can now be customized through configurations
status
andmessage
.Thanks timmkelley for the patch!
(
datadog
)gRPC Gateway (
grpc-gateway
) and (grpc-web
)- Both plugins now share the Timestamp transcoding and included
.proto
files features. [#7950(https://github.com/Kong/kong/pull/7950)
- Both plugins now share the Timestamp transcoding and included
- (
grpc-gateway
)- This plugin now processes services and methods defined in imported
.proto
files. #8107
- This plugin now processes services and methods defined in imported
(
rate-limiting
) Added support for Redis SSL through configuration propertiesredis_ssl
(can be set totrue
orfalse
),redis_ssl_verify
, andredis_server_name
. #6737Thanks for the patch!
Plugin encryption
Several fields have been marked as encrypted on plugins. If is enabled, these fields will be encrypted:
- ACME:
account_email
,eab_kid
, andeab_hmac_kid
- AWS Lambda:
aws_key
andaws_secret
- Azure Functions:
apikey
andclientid
- Basic Auth:
basicauth_credentials.password
- HTTP Log:
http_endpoint
- LDAP Auth Advanced:
ldap_password
- Loggly:
key
- OAuth2:
config.provision_key
parameter value and theoauth2_credentials.provision_key
field - OpenID Connect:
client_id
,client_secret
,session_auth
, andsession_redis_auth
- Session:
secret
- Vault:
vaults.vault_token
andvault_credentials.secret_token
Note: There is a known issue with encrypting deeply nested fields in certain plugins. For plugins with fields that are marked as encrypted but currently not working, see the Known Issues section.
- ACME:
Fixes
Enterprise
Fixed an issue with Vitals report generation. If running Vitals with InfluxDB and attempting to generate a report containing any status codes outside of 2XX, 4XX, or 5XX, report generation would fail. With this fix, proxied traffic outside of the expected codes will not cause errors, and instead appear as count totals in Vitals reports.
Fixed a latency issue in hybrid mode. Previously, applying a large number of configuration changes to a data plane simultaneously caused high latency in all upstream requests.
Users can now successfully delete admins with the
super-admin
role from any workspace, as long as they have the correct permissions, and the associated Consumer entity will be deleted as well. This frees up the username for a new user. Previously, deleting an admin with asuper-admin
role from a different workspace than where it was originally created did not delete the associated Consumer entity, and the username would remain locked. For example, if the admin was created in workspacedev
and deleted from workspaceQA
, this issue would occur.Phone home metrics are now sent over TLS, meaning that any analytics data on Kong Gateway usage now travels through an encrypted connection.
Dev Portal
Dev Portal OpenID Connect authentication now properly redirects users based on the values of
login_redirect_uri
andforbidden_redirect_uri
set inportal_auth
. If these values are not set inportal_auth
, redirect values are taken from the Portal templates file,portal.conf.yaml
.When using OpenID Connect as the Dev Portal authentication method, updates to Developers now correctly propagate to their associated Consumers.
Fixed links in Dev Portal footer.
Improved accessibility of the Dev Portal, fixing various issues related to labels, names, headings, and color contrast:
- Keyboard-accessible response examples and “Try it out” sections
- Form inputs now have labels
- Selectable elements now all have accessible names
- Unique IDs for active elements
- Heading levels only increase by one, and are in the correct order
- Improved contrast of buttons
Fixed info tooltip crash and rendering issue when viewing the Dev Portal app registration service list.
Fixed the Dev Portal Application Services list to allow pagination.
Fixed a table border styling issue in Dev Portal.
Kong Manager
- Fixed an issue with icon alignment in Kong Manager, where the Delete (garbage can) icon overlapped with the View link and caused users to accidentally click Delete.
Core
- Fixed an issue where the
pluginsocket.proto
file was missing for Go plugins. - Balancer caches are now reset on configuration reload. #7924
- Configuration reload no longer causes a new DNS-resolving timer to be started.
- Fixed problem when bootstrapping multi-node Cassandra clusters, where migrations could attempt insertions before a schema agreement occurred. #7667
- Fixed an intermittent botting error which happened when a custom plugin had interdependent entity schemas on its custom DAO and they were loaded in an incorrect order.
- Fixed an issue where
encrypted=true
would apply to the main plugin object, instead of each plugin subschema.
PDK
kong.log.inspect
log level is nowdebug
instead ofwarn
. It also renders textboxes more cleanly now.
Plugins
(
ldap-auth
)Fixed issue where the basic authentication header was not parsed correctly when the password contained a colon (
:
). #7977Thanks for reporting the issue!
Prometheus (
prometheus
)- Hid Upstream Target health metrics on the control plane, as the control plane doesn’t initialize the balancer and doesn’t have any real metrics to show.
- Request Validator (
request-validator
)- Reverted the change in parsing multiple values, as arrays in version 1.1.3 headers and query-args as
primitive
are now validated individually when duplicates are provided, instead of merging them as an array. - Whitespace around CSV values is now dropped since it is not significant according to the RFC (whitespace is optional).
- Bumped
openapi3-deserialiser
to 2.0.0 to enable the changes.
- Reverted the change in parsing multiple values, as arrays in version 1.1.3 headers and query-args as
- (
forward-proxy
)- This plugin no longer uses deprecated features of the
lua-resty-http
dependency, which previously added deprecation warnings to the DEBUG log. - This plugin no longer sets a Host header if the
upstream_host
is an empty string.
- This plugin no longer uses deprecated features of the
- OAuth2 Introspection (
oauth2-introspection
)- This plugin no longer uses deprecated features of the
lua-resty-http
dependency, which previously added deprecation warnings to the DEBUG log.
- This plugin no longer uses deprecated features of the
- (
graphql-rate-limiting-advanced
)- Fixed plugin initialization code causing HTTP 500 status codes after enabling the plugin.
- mTLS Auth (
mtls-auth
)- Fixed an issue where CRL cache was not properly invalidated, causing all certificates to appear invalid.
- (
proxy-cache-advanced
)- Fixed the
function cannot be called in access phase
error, which occurred when the plugin was called in the log phase.
- Fixed the
- Rate Limiting Advanced (
rate-limiting-advanced
)- Fixed the schema entity check for
config.limit
andconfig.window_size
count when the number of configured window sizes and limits parameters are not equal.
- Fixed the schema entity check for
Dependencies
- Bumped
go-pdk
used in tests from v0.6.0 to v0.7.1 #7964 - Bumped
grpcurl
from 1.8.2 to 1.8.5 - Bumped
lua-pack
from 1.0.5 to 2.0.0 #8004 - Dependency on
luaossl
is removed. lua-resty-openapi3-deserializer
(library dependency)- Reverted the header fix in
1.1.0
. For primitive types, the values are returned as plain strings, not as an array. Duplicate values must now be offered individually for deserialization. - Stripped whitespace from headers since it is not significant according to the RFC.
- Reverted the header fix in
Deprecated
- Kong Immunity is deprecated, removed, and not available in Kong Gateway. To access old Kong Immunity documentation, see the doc archive.
Cassandra as a backend database for Kong Gateway is deprecated with this release and will be removed in a future version.
The target for Cassandra removal is the Kong Gateway 4.0 release. Starting with the Kong Gateway 3.0 release, some new features might not be supported with Cassandra. Our intent is to provide our users with ample time and alternatives for satisfying the use cases that they have been able to address with Cassandra.
The old
BasePlugin
module is deprecated and will be removed in a future version of Kong. See porting tips in the .- Hash syntax for plugin DAOs is deprecated. Plugin DAOs should be arrays instead of hashes.
Known issues
- There’s a bug in Kong Gateway which prevents keyring encryption from working on deeply nested fields in plugins, so the
encrypted=true
setting does not have any effect on the following plugins and fields:- JWT Signer: the fields
d
,p
,q
,dp
,dq
,qi
, andk
insidejwt_signer_jwks.previous[...].
andjwt_signer_jwks.keys[...]
- Kafka Log:
config.authentication.user
and - Kafka Upstream:
config.authentication.user
andconfig.authentication.password
- OpenID Connect: the fields
d
,p
,q
,dp
,dq
,qi
,oth
,r
,t
, andk
insideopenid_connect_jwks.previous[...].
andopenid_connect_jwks.keys[...]
- JWT Signer: the fields
Consumer groups are not supported in declarative configuration with decK. If you have consumer groups in your configuration, decK will ignore them.
If you are using SSL certificates with custom plugins, you may need to set certificate phase in
ngc.ctx
.
2.6.1.0
Release Date 2022/04/07
Fixes
Enterprise
- Fixed an issue with RBAC where
endpoint=/kong workspace=*
would not let the/kong
endpoint be accessed from all workspaces - Fixed an issue with RBAC where admins without a top level
endpoint=*
permission could not add any RBAC rules, even if they hadendpoint=/rbac
permissions. These admins can now add RBAC rules for their current workspace only.
Plugins
- (
http-log
)- Include provided query string parameters when sending logs to the
http_endpoint
- Include provided query string parameters when sending logs to the
Dependencies
- Bumped
openssl
from 1.1.1k to 1.1.1n to resolve CVE-2022-0778 - Bumped
luarocks
from 3.7.1 to 3.8.0 #8630 - Bumped
openresty
from 1.19.3.2 to 1.19.9.1
2.6.0.4
Release Date 2022/02/10
Fixes
Enterprise
- Fixed an issue with Kong Manager OIDC authentication, which caused the error
“attempt to call method 'select_by_username_ignore_case' (a nil value)”
and prevented login with OIDC.
2.6.0.3
Release Date: 2022/01/27
Features
Enterprise
- You can now configure cluster_max_payload for hybrid mode deployments. This configuration option sets the maximum payload size allowed to be sent across from the control plane to the data plane. If your environment has large configurations that generate
payload too big
errors and don’t get applied to the data planes, use this setting to adjust the limit.
Fixes
Enterprise
- Phone home metrics are now sent over TLS, meaning that any analytics data on Kong Gateway usage now travels through an encrypted connection.
- Fixed an issue where OIDC authentication into Kong Manager failed when used with Azure AD.
- Fixed a timer leak that caused the timers to be exhausted and failed to start any other timers used by Kong, showing the error
too many pending timers
. - Fixed an issue with icon alignment in Kong Manager, where the Delete (garbage can) icon overlapped with the View link and caused users to accidentally click Delete.
Dev Portal
- Fixed the Dev Portal Application Services list to allow pagination.
- Fixed a table border styling issue.
- Fixed issues with modal accessibility.
Plugins
(
rate-limiting
) and Rate Limiting Advanced (rate-limiting-advanced
)Fixed a timer leak that caused the timers to be exhausted and failed to start any other timers used by Kong, showing the error
too many pending timers
.Before, the plugin used one timer for each namespace maintenance process, increasing timer usage on instances with a large number of rate limiting namespaces. Now, it uses a single timer for all namespace maintenance.
2.6.0.2
Release Date: 2021/12/03
Fixes
Dev Portal
Fixed links in Dev Portal footer.
Improved accessibility of the Dev Portal, fixing various issues related to labels, names, headings, and color contrast:
- Keyboard-accessible response examples and “Try it out” sections
- Form inputs now have labels
- Selectable elements now all have accessible names
- Unique IDs for active elements
- Heading levels only increase by one, and are in the correct order
- Improved contrast of buttons
Fixed the Dev Portal API
/applications
endpoint to only accept allowed fields in a PATCH request.Fixed info tooltip crash and rendering issue when viewing the Dev Portal app registration service list.
Plugins
- (
openid-connect
)- The plugin now allows Redis Cluster nodes to be specified by hostname through the
session_redis_cluster_nodes
field, which is helpful if the cluster IPs are not static.
- The plugin now allows Redis Cluster nodes to be specified by hostname through the
2.6.0.1
Release Date: 2021/11/18
Fixes
Enterprise
Fixed an issue with Vitals report generation. If running Vitals with InfluxDB and attempting to generate a report containing any status codes outside of 2XX, 4XX, or 5XX, report generation would fail. With this fix, proxied traffic outside of the expected codes will not cause errors, and instead appear as count totals in Vitals reports.
Fixed a latency issue in hybrid mode. Previously, applying a large number of configuration changes to a Data Plane simultaneously caused high latency in all upstream requests.
Fixed accessibility issues related to non-unique IDs in the Dev Portal.
When using OpenID Connect as the Dev Portal authentication method, updates to Developers now correctly propagate to their associated Consumers.
Users can now successfully delete admins with the
super-admin
role from any workspace, as long as they have the correct permissions, and the associated Consumer entity will be deleted as well. This frees up the username for a new user. Previously, deleting an admin with asuper-admin
role from a different workspace than where it was originally created did not delete the associated Consumer entity, and the username would remain locked. For example, if the admin was created in workspacedev
and deleted from workspaceQA
, this issue would occur.
Dependencies
- Bumped kong-redis-cluster from
1.1-0
to1.2.0
.- With this update, if the entire cluster is restarted and starts up using new IP addresses, the cluster client can recover automatically.
2.6.0.0
Release date: 2021/10/14
Features
Enterprise
Core
This release includes the addition of a new schema entity validator: mutually_exclusive
. Before, the only_one_of
validator required at least one of the fields included be configured. This new entity validator allows only one or neither of the fields be configured. #7765
Configuration
- Enable IPV6 on
dns_order
as unsupported experimental feature. #7819. - The template renderer can now use
os.getenv
. .
Hybrid Mode
- Data plane is able to eliminate some unknown fields when Control Plane is using a more modern version. .
Admin API
- Added support for the HTTP HEAD method for all Admin API endpoints.
- Added better support for OPTIONS requests. Previously, the Admin API replied the same on all OPTIONS requests, where as now OPTIONS request will only reply to routes that our Admin API has. Non-existing routes will have a 404 returned. Additionally, the Allow header was added to responses. Both Allow and Access-Control-Allow-Methods now contain only the methods that the specific API supports. #7830
Plugins
- New plugin: jq (
jq
) The jq plugin enables arbitrary jq transformations on JSON objects included in API requests or responses. - (
kafka-log
) The Kafka Log plugin now supports TLS, mTLS, and SASL auth. SASL auth includes support for PLAIN, SCRAM-SHA-256, and delegation tokens. - Kafka Upstream (
kafka-upstream
) The Kafka Upstream plugin now supports TLS, mTLS, and SASL auth. SASL auth includes support for PLAIN, SCRAM-SHA-256, and delegation tokens. - (
rate-limiting-advanced
)- The Rate Limiting Advanced plugin now has a new identifier type,
path
, which allows rate limiting by matching request paths. - The plugin now has a
local
strategy in the schema. The local strategy automatically setsconfig.sync_rate
to -1. - The highest sync-rate configurable was a 1 second interval. This sync-rate has been increased by reducing the minimum allowed interval from 1 to 0.020 second (20ms).
- The Rate Limiting Advanced plugin now has a new identifier type,
- OPA (
opa
) The OPA plugin now has a request path parameter, which makes setting policies on a path easier for administrators. - (
canary
) The Canary plugin now has the option to hash on the header (falls back on IP, and then random). - OpenID Connect (
openid-connect
) Upgrade to v2.1.0 to maintain version compatibility with older data planes.- Features from v2.0.x include the following:
- The OpenID Connect plugin can now handle JWT responses from a
userinfo
endpoint. - The plugin now supports JWE Introspection.
- The OpenID Connect plugin can now handle JWT responses from a
- Feature from to v2.1.x includes the following:
- The plugin now has a new param,
by_username_ignore_case
, which allowsconsumer_by
username values to be matched case-insensitive with Identity Provider claims.
- The plugin now has a new param,
- Features from v2.0.x include the following:
- (
request-transformer-advanced
)- This release includes a fix for the URL encode transformed path. The plugin now uses PDK functions to set upstream URI by replacing
ngx.var.upstream_uri
so the urlencode is taken care of.
- This release includes a fix for the URL encode transformed path. The plugin now uses PDK functions to set upstream URI by replacing
- AWS-Lambda (
aws-lambda
) The plugin will now try to detect the AWS region by usingAWS_REGION
andAWS_DEFAULT_REGION
environment variables (when not specified with the plugin configuration). This allows users to specify a ‘region’ on a per Kong node basis, adding the ability to invoke the Lambda function in the same region where Kong is located. - Datadog (
datadog
) The Datadog plugin now allowshost
andport
config options be configured from environment variables,KONG_DATADOG_AGENT_HOST
andKONG_DATADOG_AGENT_PORT
. This update enables users to set different destinations on a per Kong node basis, which makes multi-DC setups easier and in Kubernetes helps with the ability to run the Datadog agents as a daemon-set. - Prometheus (
prometheus
) The Prometheus plugin now includes a new metric,data_plane_cluster_cert_expiry_timestamp
, to expose the Data Plane’scluster_cert
expiry timestamp for improved monitoring in Hybrid Mode. . - GRPC-Gateway (grpc-gateway)
- Fields of type
.google.protobuf.Timestamp
on the gRPC side are now transcoded to and from ISO8601 strings in the REST side. - URI arguments like
..?foo.bar=x&foo.baz=y
are interpreted as structured fields, equivalent to{"foo": {"bar": "x", "baz": "y"}}
. #7564
- Fields of type
- (
request-termination
)- The Request Termination plugin now includes a new
trigger
config option, which makes the plugin only activate for any requests with a header or query parameter named like the trigger. This config option can be a great debugging aid, without impacting actual traffic being processed. #6744. - The
request-echo
config option was added. If set, the plugin responds with a copy of the incoming request. This config option eases troubleshooting when Kong Gateway is behind one or more other proxies or LB’s, especially when combined with the newtrigger
option. .
- The Request Termination plugin now includes a new
Dependencies
- Bumped
openresty
from 1.19.3.2 to #7430 - Bumped
openssl
from1.1.1k
to1.1.1l
- Bumped
lua-resty-http
from 0.15 to 0.16.1 #7797 - Bumped
Penlight
to 1.11.0 - Bumped
lua-resty-http
from 0.15 to 0.16.1 #7797 - Bumped
lua-protobuf
from 0.3.2 to 0.3.3 - Bumped
lua-resty-openssl
from 0.7.3 to 0.7.4 #7657 - Bumped
lua-resty-acme
from 0.6 to 0.7.1 - Bumped
grpcurl
from 1.8.1 to 1.8.2 #7659 - Bumped
luasec
from 1.0.1 to 1.0.2 - Bumped
lua-resty-ipmatcher
to 0.6.1 #7703
Fixes
Enterprise
- This release includes a fix for an issue with the Vitals InfluxDB timestamp generation when inserting metrics.
- Kong Gateway (Enterprise) no longer exports
consumer_reset_secrets
. - Fixes an issue where keyring data was not being properly generated and activated on a Kong process start (for example, kong start).
- Kong Gateway now returns keyring-encrypted fields early when a decrypt attempt is made, giving you time to import the keys so Kong Gateway can recognize the decrypted fields. Before if there were data fields keyring-encrypted in the database, Kong Gateway attempted to decrypt them on the
init*
phases (init
orinit_worker
phases - when the Kong process is started), and you would get errors like “no request found”. Keys must still be imported after the Kong process is started. - The feature is no longer in an alpha quality state.
- This release includes a fix to the CentOS Docker image builds, ensuring CentOS 7 images are properly generated.
Core
- Balancer retries now correctly set the
:authority
pseudo-header on balancer retries. . - Healthchecks are now stopped while the Balancer is being recreated. #7549.
- Fixed an issue in which a malformed
Accept
header could cause unexpected HTTP 500. . - Kong no longer removes
Proxy-Authentication
request header andProxy-Authenticate
response header. #7724. - Fixed an issue where Kong would not sort correctly Routes with both regex and prefix paths.
Hybrid Mode
- Ensure data plane config thread is terminated gracefully, preventing a semi-deadlocked state.
CLI
kong config parse
no longer crashes when there’s a Go plugin server enabled. .
Configuration
- Declarative Configuration parser now prints more correct errors when printing unknown foreign references. .
- YAML anchors in Declarative Configuration are properly processed. #7748.
Admin API
GET /upstreams/:upstreams/targets/:target
no longer returns 404 when target weight is 0. #7758.
PDK
kong.response.exit
now uses customized “Content-Length” header when found. #7828.
Plugins
- ACME (
acme
) Dots in wildcard domains are escaped. . - Prometheus (
prometheus
) Upstream’s health info now includes previously missingsubsystem
field. . - Proxy-Cache (
proxy-cache
) Fixed an issue where the plugin would sometimes fetch data from the cache but not return it.
2.6.0.0 (beta1)
Release date: 2021/10/04
Features
Enterprise
Core
This release includes the addition of a new schema entity validator: mutually_exclusive
. Before, the only_one_of
validator required at least one of the fields included be configured. This new entity validator allows only one or neither of the fields be configured. #7765
Configuration
- Enable IPV6 on
dns_order
as unsupported experimental feature. #7819. - The template renderer can now use
os.getenv
. .
Hybrid Mode
- Data plane is able to eliminate some unknown fields when Control Plane is using a more modern version. .
Admin API
- Added support for the HTTP HEAD method for all Admin API endpoints.
- Added better support for OPTIONS requests. Previously, the Admin API replied the same on all OPTIONS requests, where as now OPTIONS request will only reply to routes that our Admin API has. Non-existing routes will have a 404 returned. Additionally, the Allow header was added to responses. Both Allow and Access-Control-Allow-Methods now contain only the methods that the specific API supports. #7830
Plugins
- New plugin: jq (
jq
) The jq plugin enables arbitrary jq transformations on JSON objects included in API requests or responses. - (
kafka-log
) The Kafka Log plugin now supports TLS, mTLS, and SASL auth. SASL auth includes support for PLAIN, SCRAM-SHA-256, and delegation tokens. - Kafka Upstream (
kafka-upstream
) The Kafka Upstream plugin now supports TLS, mTLS, and SASL auth. SASL auth includes support for PLAIN, SCRAM-SHA-256, and delegation tokens. - (
rate-limiting-advanced
)- The Rate Limiting Advanced plugin now has a new identifier type,
path
, which allows rate limiting by matching request paths. - The plugin now has a
local
strategy in the schema. The local strategy automatically setsconfig.sync_rate
to -1. - The highest sync-rate configurable was a 1 second interval. This sync-rate has been increased by reducing the minimum allowed interval from 1 to 0.020 second (20ms).
- The Rate Limiting Advanced plugin now has a new identifier type,
- OPA (
opa
) The OPA plugin now has a request path parameter, which makes setting policies on a path easier for administrators. - (
canary
) The Canary plugin now has the option to hash on the header (falls back on IP, and then random). - OpenID Connect (
openid-connect
) Upgrade to v2.1.0 to maintain version compatibility with older data planes.- Features from v2.0.x include the following:
- The OpenID Connect plugin can now handle JWT responses from a
userinfo
endpoint. - The plugin now supports JWE Introspection.
- The OpenID Connect plugin can now handle JWT responses from a
- Feature from to v2.1.x includes the following:
- The plugin now has a new param,
by_username_ignore_case
, which allowsconsumer_by
username values to be matched case-insensitive with Identity Provider claims.
- The plugin now has a new param,
- Features from v2.0.x include the following:
- (
aws-lambda
) The plugin will now try to detect the AWS region by usingAWS_REGION
andAWS_DEFAULT_REGION
environment variables (when not specified with the plugin configuration). This allows users to specify a ‘region’ on a per Kong node basis, adding the ability to invoke the Lambda function in the same region where Kong is located. #7765 - (
datadog
) The Datadog plugin now allowshost
andport
config options be configured from environment variables,KONG_DATADOG_AGENT_HOST
andKONG_DATADOG_AGENT_PORT
. This update enables users to set different destinations on a per Kong node basis, which makes multi-DC setups easier and in Kubernetes helps with the ability to run the Datadog agents as a daemon-set. #7463 - (
prometheus
) The Prometheus plugin now includes a new metric,data_plane_cluster_cert_expiry_timestamp
, to expose the Data Plane’scluster_cert
expiry timestamp for improved monitoring in Hybrid Mode. #7800. - (grpc-gateway)
- Fields of type
.google.protobuf.Timestamp
on the gRPC side are now transcoded to and from ISO8601 strings in the REST side. #7538 - URI arguments like
..?foo.bar=x&foo.baz=y
are interpreted as structured fields, equivalent to{"foo": {"bar": "x", "baz": "y"}}
.
- Fields of type
- Request Termination (
request-termination
)- The Request Termination plugin now includes a new
trigger
config option, which makes the plugin only activate for any requests with a header or query parameter named like the trigger. This config option can be a great debugging aid, without impacting actual traffic being processed. . - The
request-echo
config option was added. If set, the plugin responds with a copy of the incoming request. This config option eases troubleshooting when Kong Gateway is behind one or more other proxies or LB’s, especially when combined with the newtrigger
option. #6744.
- The Request Termination plugin now includes a new
Dependencies
- Bumped
openresty
from 1.19.3.2 to 1.19.9.1 - Bumped
openssl
from1.1.1k
to1.1.1l
7767 - Bumped
lua-resty-http
from 0.15 to 0.16.1 - Bumped
Penlight
to 1.11.0 #7736 - Bumped
lua-resty-http
from 0.15 to 0.16.1 - Bumped
lua-protobuf
from 0.3.2 to 0.3.3 #7656 - Bumped
lua-resty-openssl
from 0.7.3 to 0.7.4 - Bumped
lua-resty-acme
from 0.6 to 0.7.1 #7658 - Bumped
grpcurl
from 1.8.1 to 1.8.2 - Bumped
luasec
from 1.0.1 to 1.0.2 #7750 - Bumped
lua-resty-ipmatcher
to 0.6.1
Fixes
Enterprise
- This release includes a fix for an issue with the Vitals InfluxDB timestamp generation when inserting metrics.
- Kong Gateway (Enterprise) no longer exports
consumer_reset_secrets
. - Fixes an issue where keyring data was not being properly generated and activated on a Kong process start (for example, kong start).
- Kong Gateway now returns keyring-encrypted fields early when a decrypt attempt is made, giving you time to import the keys so Kong Gateway can recognize the decrypted fields. Before if there were data fields keyring-encrypted in the database, Kong Gateway attempted to decrypt them on the
init*
phases (init
orinit_worker
phases - when the Kong process is started), and you would get errors like “no request found”. Keys must still be imported after the Kong process is started. - The Keyring Encryption feature is no longer in an alpha quality state.
Core
- Balancer retries now correctly set the
:authority
pseudo-header on balancer retries. #7725. - Healthchecks are now stopped while the Balancer is being recreated. .
- Fixed an issue in which a malformed
Accept
header could cause unexpected HTTP 500. #7757. - Kong no longer removes
Proxy-Authentication
request header andProxy-Authenticate
response header. . - Fixed an issue where Kong would not sort correctly Routes with both regex and prefix paths. #7695
Hybrid Mode
- Ensure data plane config thread is terminated gracefully, preventing a semi-deadlocked state. #7568
CLI
kong config parse
no longer crashes when there’s a Go plugin server enabled. #7589.
Configuration
- Declarative Configuration parser now prints more correct errors when printing unknown foreign references. #7756.
- YAML anchors in Declarative Configuration are properly processed. .
Admin API
GET /upstreams/:upstreams/targets/:target
no longer returns 404 when target weight is 0. .
PDK
kong.response.exit
now uses customized “Content-Length” header when found. .
Plugins
- (
acme
) Dots in wildcard domains are escaped. #7839. - (
prometheus
) Upstream’s health info now includes previously missingsubsystem
field. #7802. - (
proxy-cache
) Fixed an issue where the plugin would sometimes fetch data from the cache but not return it. #7775
2.5.1.2
Release Date: 2021/11/18
Fixes
Enterprise
Fixed an issue with Vitals report generation. If running Vitals with InfluxDB and attempting to generate a report containing any status codes outside of 2XX, 4XX, or 5XX, report generation would fail. With this fix, proxied traffic outside of the expected codes will not cause errors, and instead appear as count totals in Vitals reports.
Fixed a latency issue in hybrid mode. Previously, applying a large number of configuration changes to a Data Plane simultaneously caused high latency in all upstream requests.
Fixed accessibility issues related to non-unique IDs in the Dev Portal.
When using OpenID Connect as the Dev Portal authentication method, updates to Developers now correctly propagate to their associated Consumers.
2.5.1.1
Release Date: 2021/10/22
Fixes
Enterprise
- This release includes a fix for an issue with the Vitals InfluxDB timestamp generation when inserting metrics.
- Kong Gateway now displays a DEBUG log message alerting users Kong Vitals is not enabled when running Kong Gateway (Enterprise) in “free” mode.
- Fixes an issue where keyring data was not being properly generated and activated on a Kong Gateway process start (for example,
kong start
). - Kong Gateway now returns keyring-encrypted fields early when a decrypt attempt is made, giving you time to import the keys so Kong Gateway can recognize the decrypted fields. Before if there were data fields keyring-encrypted in the database, Kong Gateway attempted to decrypt them on the
init*
phases (init
orinit_worker
phases - when the Kong process is started), and you would get errors like “no request found”. Keys must still be imported after the Kong process is started. - The feature is no longer in an alpha quality state.
- When using Redis Cluster with a Kong Gateway plugin and the cluster nodes are configured by hostname, if the entire cluster is rebooted and appears on new IP addresses, now the connection will eventually self heal once DNS is updated.
Plugins
- (
openid-connect
) The plugin now allows Redis Cluster nodes to be specified by hostname, which is helpful if the cluster IPs are not static.
2.5.1.0
Release Date 2021/09/08
Dependencies
- Bumped
grpcurl
from 1.8.1 to 1.8.2 #7659 - Bumped
lua-resty-openssl
from 0.7.3 to 0.7.4 - Bumped
penlight
from 1.10.0 to 1.11.0 #7736 - Bumped
luasec
from 1.0.1 to 1.0.2 - Bumped
OpenSSL
from 1.1.1k to 1.1.1l #7767
Fixes
Core
- You can now successfully delete workspaces after deleting all entities associated with that workspace. Previously, Kong Gateway was not correctly cleaning up parent-child relationships. For example, creating an Admin also creates a Consumer and RBAC user. When deleting the Admin, the Consumer and RBAC user are also deleted, but accessing the
/workspaces/workspace_name/meta
endpoint would show counts for Consumers and RBAC users, which prevented the workspace from being deleted. Now deleting entities correctly updates the counts, allowing an empty workspace to be deleted. - When an upstream event is received from the DAO,
handler.lua
now gets the workspace ID from the request and adds it to the upstream entity that will be used in the worker and cluster events. Before this change, when posting balancer CRUD events, the workspace ID was lost and the balancer used the default workspace ID as a fallback. #7778
CLI
- Fixes regression that included an issue where Go plugins prevented CLI commands like
kong config parse
orkong config db_import
from working as expected. #7589
Admin API
- Kong Gateway now validates workspace names, preventing the use of reserved names on workspaces. #7380
Plugins
- Azure Functions (
azure-functions
) This release updates thelua-resty-http
dependency to v0.16.1, which means the plugin no longer uses the deprecated functions.
2.5.0.2
Release Date 2021/09/02
Fixes
Enterprise
- This release fixes a regression in the Kong Dev Portal templates that removed dynamic menu navigation and other improvements from portals created in Kong Gateway v2.5.0.1.
Plugins
- (
mocking
) This release fixes special character handling in path matching for the plugin. Before, if a path contained a hyphen the plugin failed to match the path.
2.5.0.1
Release Date 2021/08/18
Fixes
Enterprise
- Updates Kong Dev Portal templates’ JQuery dependency to v3.6.0, improving security.
- Now, bootstrap migrations for multi-node Apache Cassandra clusters work as expected. With this fix, inserts are performed after schema agreement.
- Updates Nettle dependency version from
3.7.2
to3.7.3
, fixing bugs that could cause RSA decryption functions to crash with invalid inputs.
Plugins
- OpenID Connect (
openid-connect
) With this fix, when the OpenID Connect plugin is configured with aconfig.anonymous
consumer andconfig.scopes_required
is set, a token missing the required scopes will have the anonymous consumer headers set when sent to the upstream.
2.5.0.0
Release Date 2021/08/03
Features
Enterprise
- This release includes event hooks, a new entity that represents the relationship between an event (source and event) and an action (handler). Depending on the handler, an event hook will execute an action with the event’s associated data when it is triggered. There are four supported handlers:
- webhook
- custom-webhook
- log
- lambda
See the event hooks reference and documentation for more information.
- For users running in free mode, Kong has updated the top banner to include information on the benefits of and a link for updating to Konnect.
Core
- Control planes can now send updates to new data planes even if the control planes lose connection to the database.
- Kong now automatically adds
cluster_cert
(cluster_mtls=shared
) orcluster_ca_cert
(cluster_mtls=pki
) intolua_ssl_trusted_certificate
when operating in hybrid mode. Before, hybrid mode users needed to configurelua_ssl_trusted_certificate
manually as a requirement for Lua to verify the control plane’s certificate. See Starting Data Plane Nodes in the Hybrid Mode guide for more information. - New
declarative_config_string
option allows loading declarative configurations directly from a string. See the Loading The Declarative Configuration File section of the DB-less and Declarative Configuration guide for more information.
PDK
- The Kong Gateway PDK now accepts tables in the response body for Stream subsystems, just as it does for the HTTP subsystem. Before, developers had to check the subsystem if they wrote code that used the
exit()
function before calling it, because passing the wrong argument type would break the request response.
Plugins
- (
hmac-auth
) The HMAC Authentication plugin now includes support for the@request-target
field in the signature string. Before, the plugin used therequest-line
parameter, which contains the HTTP request method, request URI, and the HTTP version number. The inclusion of the HTTP version number in the signature caused requests to the same target with different request methods(such as HTTP/2) to have different signatures. The newly addedrequest-target
field only includes the lowercase request method and request URI when calculating the hash, avoiding those issues. See the HMAC Authentication documentation for more information. - Syslog (
syslog
) The Syslog plugin now includes facility configuration options, which are a way for the plugin to group error messages from different sources. See the description for the facility parameter in the Parameters section of the for more information. #6081. - (
prometheus
) The Prometheus plugin now exposes connected data planes’ status on the control plane. New metrics include the following:data_plane_last_seen
,data_plane_config_hash
anddata_plane_version_compatible
. These metrics can be useful for troubleshooting when data planes have inconsistent configurations across the cluster. See the Available metrics section of the Prometheus plugin documentation for more information. - Zipkin (
zipkin
) The Zipkin plugin now includes the following tags:kong.route
,kong.service_name
, andkong.route_name
. See the section of the Zipkin plugin documentation for more information. #115 - (
rate-limiting-advanced
) and Proxy Cache Advanced (proxy-cached-advanced
)- This release deprecates the
timeout
field and replaces it with three precise options:connect_timeout
,read_timeout
, andsend_timeout
. Currently, if these options are not set, the value oftimeout
will be used for all (or its default value of 2000ms). Theconnect_timeout
,read_timeout
, andsend_timeout
fields are mutually required fields. Thetimeout
field will be removed from the product in version 3.0.x.x. - This release also includes new configuration options
keepalive_pool
,keepalive_pool_size
, andkeepalive_backlog
. These options relate totcp:connect
options.
- This release deprecates the
- ACME (
acme
) The ACME plugin now waits before signaling a challenge in hybrid mode to ensure the control plane propagates any updated configuration data. The client certificate will now be stored in external storage in hybrid mode with a warning being emitted if the ACME plugin is configured to useshm
storage. Additional checks have also been added during the sanity test which can be run on a Kong Gateway setup before creating any certificates.
Hybrid Mode
- Kong Gateway now exposes an upstream health checks endpoint (using the status API) on the data plane for better observability. See in the Hybrid Mode guide for more information. #7429
- Control planes are now more lenient when checking data planes’ compatibility in hybrid mode. See the section of the Hybrid Mode guide for more information. #7488
Dependencies
- Bumped
openresty
from 1.19.3.1 to 1.19.3.2 #7430 - Bumped
luasec
from 1.0 to 1.0.1 - Bumped
luarocks
from 3.5.0 to 3.7.0 #7043 - Bumped
grpcurl
from 1.8.0 to 1.8.1 - Bumped
penlight
from 1.9.2 to 1.10.0 #7127 - Bumped
lua-resty-dns-client
from 6.0.0 to 6.0.2 - Bumped
kong-plugin-acme
from 0.2.14 to 0.2.15 #74 - Bumped
kong-plugin-prometheus
from 1.2 to 1.3 - Bumped
kong-plugin-zipkin
from 1.3 to 1.4 #7455 - Bumped
lua-resty-openssl
from 0.7.2 to 0.7.3 - Bumped
lua-resty-healthcheck
from 1.4.1 to 1.4.2 #7511 - Bumped
hmac-auth
from 2.3.0 to 2.4.0 - Pinned
lua-protobuf
to 0.3.2 (previously unpinned) #7079
Fixes
Enterprise
- Renamed the property identifying control planes in hybrid mode when using Kong Vitals with anonymous reports enabled. Before, users received an error on their control planes about a function that could not be used.
- Kong Gateway now starts even when
SSL_CIPHER_SUITE
is set tomodern
when the Kong Dev Portal is enabled. Before, Kong Gateway would fail to start with an NGINX configuration error, “invalid number of arguments in ‘ssl_ciphers’ directive”. - Updated
lua-resty-openssl
to v0.7.3, fixing an error users were encountering when trying to synchronize configurations from control planes to data planes. Users were seeing the following errors in the ingress controller logs, indicating their configurations were not successfully being pushed to the Kong Gateway proxy node: “failed to update kong configuration”, “declarative config is invalid,” and “failed to sync”. - Users can now set
enforce_rbac
toboth
and still be able to log into Kong Gateway’s UI, Kong Manager. - Updated
lua-resty-healthcheck
to v1.4.2 which fixes an error where Kong would spam ‘nothing to do’ in the logs multiple times per second, slowing down performance. - Updated
lua-resty-dns-client
to v6.0.1 which fixes an issue users were encountering when adding more than 1000 endpoints, resulting in the errorlua_max_running_timers are not enough
throughout the logs. - Kong Gateway now ensures proper keyspace, table, and table names are used when performing migrations on Apache Cassandra v2.2.
- This release includes an update that circumvents a potential security issue with a buffer overflow when validating the Kong Gateway license.
- Users can now successfully delete workspaces after deleting all entities associated with that workspace. Previously, Kong Gateway was not correctly cleaning up parent-child relationships. For example, creating an Admin also creates a Consumer and RBAC user. When deleting the Admin, the Consumer and RBAC user are also deleted, but accessing the
/workspaces/workspace_name/meta
endpoint would show counts for Consumers and RBAC users, which prevented the workspace from being deleted. Now deleting entities correctly updates the counts, allowing an empty workspace to be deleted.
Core
- When using DB-less mode,
select_by_cache_key
now finds entities by using the providedfield
directly in ` select_by_key` and does not complete unnecessary cache reads. #7146 - Kong can now finish initialization even if a plugin’s
init_worker
handler fails, improving stability. - TLS keepalive requests no longer share their context. Before when two calls were made to the same “server+hostname” but different routes and using a keepalive connection, plugins that were active in the first call were also sometimes (incorrectly) active in the second call. The wrong plugin was active because Kong was passing context in the SSL phase to the plugin iterator, creating connection-wide structures in that context, which was then shared between different keepalive requests. With this fix, Kong does not pass context to plugin iterators with the
certificate
phase, avoiding plugin mixups.#7102 - The HTTP status 405 is now handled by Kong’s error handler. Before accessing Kong Gateway using the TRACE method returned a standard NGINX error page because the 405 wasn’t included in the error page settings of the NGINX configuration. .
- Custom
ngx.sleep
implementation ininit_worker
phase now invokesupdate_time
in order to prevent time-based deadlocks #7532 Proxy-Authorization
header is removed when it is part of the original request or when a plugin sets it to the same value as the original requestHEAD
requests don’t provoke an error when a Plugin implements theresponse
phase #7535
Hybrid Mode
- Control planes no longer perform health checks on CRUD upstreams’ and targets’ events. #7085
- To prevent unnecessary cache flips on data planes, Kong now checks
dao:crud
events more strictly and has a new cluster event,clustering:push_config
for configuration pushes. These updates allow Kong to filter invalidation events that do not actually require a database change. Furthermore, the clustering module does not subscribe to the genericinvalidations
event, which has a more broad scope than database entity invalidations. - Data planes ignore null fields coming from control planes when doing schema validation. #7458
- Kong Gateway now includes the source in error logs produced by control planes.
- With this release, data plane config hash calculation and checking is more consistent. It is impervious to changes in table iterations. Hashes are calculated in both the control plane and the data plane, and data planes send pings more immediately and with the new hash. #7483
Balancer
- All targets are returned by the Admin API now, including targets with a
weight=0
, or disabled targets. Before disabled targets were not included in the output when users attempted to list all targets. Then when users attempted to add the targets again, they received an error message telling them the targets already existed. #7094 - Upserting existing targets no longer fails. Before, because of updates made to target configurations since Kong Gateway v2.2.0, upserting older configurations would fail. This fix allows older configurations to be imported.
- The last balancer attempt is now correctly logged. Before balancer tries were saved when retrying, which meant the last retry state was not saved since there were no more retries. This update saves the failure state so it can be correctly logged. #6972
- Kong Gateway now ensures that the correct upstream event is removed from the queue when updating the balancer state.
CLI
- The
prefix
argument in thekong stop
command now takes precedence over environment variables, as it does in thekong start
command.
Configuration
- Declarative configurations now correctly parse custom plugin entities schemas with attributes called “plugins”. Before when using declarative configurations, users with custom plugins that included a “plugins” field would encounter startup exceptions. With this fix, the declarative configuration can now distinguish between plugins schema and custom plugins fields.
- The stream access log configuration options are now properly separated from the HTTP access log. Before when users used Kong Gateway with TCP, they couldn’t use a custom log format. With this fix,
proxy_stream_access_log
andproxy_stream_error_log
have been added to differentiate the Stream access log from the HTTP subsystem. See proxy_stream_access_log and in the Configuration Property Reference for more information. #7046
Migrations
- Kong Gateway no longer assumes that
/?/init.lua
is in the Lua path when doing migrations. Before, when users created a custom plugin in a non-standard location and setlua_package_path = /usr/local/custom/?.lua
, migrations failed. Migrations failed because the Kong core file isinit.lua
and it is required as part ofkong.plugins.<name>.migrations
. With this fix, migrations no longer expectinit.lua
to be a part of the path. #6993 Kong Gateway no longer emits errors when doing
ALTER COLUMN
operations in Apache Cassandra 4.0.Important: Even with this fix, Cassandra 4.0 is not yet fully supported.
PDK
- With this update,
kong.response.get_XXX()
functions now work in the log phase on external plugins. Beforekong.response.get_XXX()
functions required data from the response object, which was not accessible in the post-log timer used to call log handlers in external plugins. Now these functions work by accessing the required data from the set saved at the start of the log phase. See in the Plugin Development Kit for more information. #7048 - External plugins handle certain error conditions better while the Kong Gateway balancer is being refreshed. Before when an
instance_id
of an external plugin changed, and the plugin instance attempted to reset and retry, it was failing because of a typo in the comparison. . - With this release,
kong.log
’s phase checker now accounts for the existence of the newresponse
pseudo-phase. Before users may have erroneously received a safe runtime error for using a function out-of-place in the PDK. #7109 - Kong Gateway no longer sandboxes the
string.rep
function. Beforestring.rep
was sandboxed to disallow a single operation from allocating too much memory. However, a single operation allocating too much memory is no longer an issue because in LuaJIT there are no debug hooks and it is trivial to implement a loop to allocate memory on every single iteration. Additionally, since thestring
table is global and obtainable by any sandboxed string, its sandboxing provoked issues on global state. - The
kong.pdk.node
function can now correctly iterates over all the shared dict metrics. Before this fix, users using thekong.pdk.node
function could not see all shared dict metrics under the Stream subsystem. #7078
Plugins
- LDAP Authentication (
ldap-auth
) The LDAP Authentication schema now includes a default value for theconfig.ldap_port
parameter that matches the documentation. Before the plugin documentation section included a reference to a default value for the LDAP port; however, the default value was not included in the plugin schema. #7438 - (
prometheus
) The Prometheus plugin exporter now attaches subsystem labels to memory stats. Before, the HTTP and Stream subsystems were not distinguished, so their metrics were interpreted as duplicate entries by Prometheus. #118 - (
zipkin
)- The plugin now works even when
balancer_latency
isnil
. - The plugin no longer shares context between several Zipkin plugins. Before the plugin was using
ngx.ctx
exclusively, even in a global context, which meant more than one instance of the Zipkin plugin would override each other. Now the plugin useskong.ctx.plugin
to hold thezipkin
table, instead ofngx.ctx
.
- The plugin now works even when
- External plugins This release includes better error messages when external plugins fail to start. With this fix, Kong Gateway detects the return code 127 (command not found), allowing it to display an appropriate error message, “external plugin server start command exited with command not found”.
- Rate Limiting Advanced (
rate-limiting-advanced
) and (proxy-cached-advanced
) Kong now offersssl_verify
andserver_name
options for Redis Sentinel-based connections. Before these options were only offered for Cluster or plain Redis connections, causing SSL to fail in Redis Sentinel configurations. - Rate Limiting Advanced (
rate-limiting-advanced
) This release fixes an error in the plugin where counters would not sync after aPATCH
request.
2.5.0.0 (beta1)
Release Date 2021/07/13
Features
Enterprise
- For users running in free mode, Kong has updated the top banner to include information on the benefits of and a link for updating to Konnect.
- This release includes several updates to Kong Manager, the Kong Gateway UI, including the following:
- Support for the Mocking and Response Rate Limiting plugins.
- Updates to the Konnect Plugin page, allowing users to:
- Create new plugin associated with
consumer
orglobal
. - View plugin details by clicking the row.
- Edit and delete plugins that are not associated with a
service
orroute
. - Click the
applied to
entity type (service
,route
, orconsumer
) link to view the details of that entity. - Sort the columns.
- Search by ID.
- Create new plugin associated with
Core
- Control Planes can now send updates to new data planes even if the control planes lose connection to the database.
- Kong now automatically adds
cluster_cert
(cluster_mtls=shared
) orcluster_ca_cert
(cluster_mtls=pki
) intolua_ssl_trusted_certificate
when operating in Hybrid mode. Before, Hybrid mode users needed to configurelua_ssl_trusted_certificate
manually as a requirement for Lua to verify the Control Plane’s certificate. See Starting Data Plane Nodes in the Hybrid Mode guide for more information. - New
declarative_config_string
option allows loading a declarative config directly from a string. See the Loading The Declarative Configuration File section of the DB-less and Declarative Configuration guide for more information.
PDK
- The Kong PDK now accepts tables in the response body for Stream subsystems, just as it does for the HTTP subsystem. Before developers had to check the subsystem if they wrote code that used the
exit()
function before calling it, because passing the wrong argument type would break the request response.
Plugins
- (
hmac-auth
) The HMAC Authentication plugin now includes support for the@request-target
field in the signature string. Before, the plugin used therequest-line
parameter, which contains the HTTP request method, request URI, and the HTTP version number. The inclusion of the HTTP version number in the signature caused requests to the same target but using different request methods(such as HTTP/2) to have different signatures. The newly added request-target field only includes the lowercase request method and request URI when calculating the hash, avoiding those issues. See the HMAC Authentication documentation for more information. - Syslog (
syslog
) The Syslog plugin now includes facility configuration options, which are a way for the plugin to group error messages from different sources. See the description for the facility parameter in the Parameters section of the for more information. #6081. - (
prometheus
) The Prometheus plugin now exposes connected data planes’ status on the control plane. New metrics include the following:data_plane_last_seen
,data_plane_config_hash
anddata_plane_version_compatible
. These metrics can be useful for troubleshooting when data planes have inconsistent configurations across the cluster. See the Available metrics section of the Prometheus plugin documentation for more information. - Zipkin (
zipkin
) The Zipkin plugin now includes the following tags:kong.route
,kong.service_name
andkong.route_name
. See the section of the Zipkin plugin documentation for more information. #115
Hybrid Mode
- Kong now exposes an upstream health checks endpoint (using the status API) on the data plane for better observability. See Readonly Status API endpoints on Data Plane in the Hybrid Mode guide for more information.
- Control Planes are now more lenient when checking Data Planes’ compatibility in Hybrid mode. See the Version compatibility section of the Hybrid Mode guide for more information.
Dependencies
- Bumped
openresty
from 1.19.3.1 to 1.19.3.2 - Bumped
luasec
from 1.0 to 1.0.1 #7126 - Bumped
luarocks
from 3.5.0 to 3.7.0 - Bumped
grpcurl
from 1.8.0 to 1.8.1 #7128 - Bumped
penlight
from 1.9.2 to 1.10.0 - Bumped
lua-resty-dns-client
from 6.0.0 to 6.0.2 #7539 - Bumped
kong-plugin-prometheus
from 1.2 to 1.3 - Bumped
kong-plugin-zipkin
from 1.3 to 1.4 #7455 - Bumped
lua-resty-openssl
from 0.7.2 to 0.7.3 - Bumped
lua-resty-healthcheck
from 1.4.1 to 1.4.2 #7511 - Bumped
hmac-auth
from 2.3.0 to 2.4.0 - Pinned
lua-protobuf
to 0.3.2 (previously unpinned) #7079
Fixes
Enterprise
- Renamed the property identifying control planes in hybrid mode when using Vitals with anonymous reports enabled. Before, users received an error on their control planes about a function that could not be used.
- Kong now starts even when
SSL_CIPHER_SUITE
is set tomodern
when the Kong Dev Portal is enabled. Before, Kong would fail to start with an NGINX configuration error, “invalid number of arguments in ‘ssl_ciphers’ directive”. - Updated
lua-resty-openssl
to v0.7.3, fixing an error users were encountering when trying to synchronize configurations from control planes to data planes. Users were seeing the following errors in the ingress controller logs, indicating their configurations were not successfully being pushed to the Kong proxy node: “failed to update kong configuration”,”declarative config is invalid,” and “failed to sync”. - Users can now set
enforce_rbac
toboth
and still be able to log into Kong Gateway’s UI, Kong Manager. - Updated
lua-resty-healthcheck
to v1.4.2 which fixes an error where Kong would spam ‘nothing to do’ in the logs multiple times per second, slowing down performance. - Updated
lua-resty-dns-client
to v6.0.1 which fixes an issue users were encountering when adding more than 1000 endpoints, resulting in the errorlua_max_running_timers are not enough
throughout the logs.
Core
- When using DB-less mode,
select_by_cache_key
now finds entities by using the providedfield
directly in ` select_by_key` and does not complete unnecessary cache reads. #7146 - Kong can now finish initialization even if a plugin’s
init_worker
handler fails, improving stability. - TLS keepalive requests no longer share their context. Before when two calls were made to the same “server+hostname” but different routes and using a keepalive connection, plugins that were active in the first call were also sometimes (incorrectly) active in the second call. The wrong plugin was active because Kong was passing context in the SSL phase to the plugin iterator, creating connection-wide structures in that context, which was then shared between different keepalive requests. With this fix, Kong does not pass context to plugin iterators with the
certificate
phase, avoiding plugin mixups.#7102 - The HTTP status 405 is now handled by Kong’s error handler. Before accessing Kong using the TRACE method returned a standard NGINX error page because the 405 wasn’t included in the error page settings of the NGINX configuration. .
- Custom
ngx.sleep
implementation ininit_worker
phase now invokesupdate_time
in order to prevent time-based deadlocks #7532 Proxy-Authorization
header is removed when it is part of the original request or when a plugin sets it to the same value as the original requestHEAD
requests don’t provoke an error when a Plugin implements theresponse
phase #7535
Hybrid Mode
- Control planes no longer perform health checks on CRUD upstreams’ and targets’ events. #7085
- To prevent unnecessary cache flips on data planes, Kong now checks
dao:crud
events more strictly and has a new cluster event,clustering:push_config
for configuration pushes. These updates allow Kong to filter invalidation events that do not actually require a database change. Furthermore, the clustering module does not subscribe to the genericinvalidations
event, which has a more broad scope than database entity invalidations. - Data Planes ignore null fields coming from control planes when doing schema validation. #7458
- Kong now includes the source in error logs produced by control planes.
- With this release, data plane config hash calculation and checking is more consistent. It is impervious to changes in table iterations. Hashes are calculated in both the control plane and the data plane, and data planes send pings more immediately and with the new hash. #7483
Balancer
- All targets are returned by the Admin API now, including targets with a
weight=0
, or disabled targets. Before disabled targets were not included in the output when users attempted to list all targets. Then when users attempted to add the targets again, they received an error message telling them the targets already existed. #7094 - Upserting existing targets no longer fails. Before, because of updates made to target configurations since Kong v2.2.0, upserting older configurations would fail. This fix allows older configurations to be imported.
- The last balancer attempt is now correctly logged. Before balancer tries were saved when retrying, which meant the last retry state was not saved since there were no more retries. This update saves the failure state so it can be correctly logged. #6972
- Kong now ensures that the correct upstream event is removed from the queue when updating the balancer state.
CLI
- The
prefix
argument in thekong stop
command now takes precedence over environment variables, as it does in thekong start
command.
Configuration
- Declarative configurations now correctly parse custom plugin entities schemas with attributes called “plugins”. Before when using declarative configurations, users with custom plugins that included a “plugins” field would encounter startup exceptions. With this fix, the declarative configuration can now distinguish between plugins schema and custom plugins fields.
- The stream access log configuration options are now properly separated from the HTTP access log. Before when users used Kong with TCP, they couldn’t use a custom log format. With this fix,
proxy_stream_access_log
andproxy_stream_error_log
have been added to differentiate the Stream access log from the HTTP subsystem. See proxy_stream_access_log and in the Configuration Property Reference for more information. #7046
Migrations
- Kong no longer assumes that
/?/init.lua
is in the Lua path when doing migrations. Before, when users created a custom plugin in a non-standard location and setlua_package_path = /usr/local/custom/?.lua
, migrations failed. Migrations failed because the Kong core file isinit.lua
and it is required as part ofkong.plugins.<name>.migrations
. With this fix, migrations no longer expectinit.lua
to be a part of the path. #6993 Kong no longer emits errors when doing
ALTER COLUMN
operations in Apache Cassandra 4.0.
PDK
- With this update,
kong.response.get_XXX()
functions now work in the log phase on external plugins. Beforekong.response.get_XXX()
functions required data from the response object, which was not accessible in the post-log timer used to call log handlers in external plugins. Now these functions work by accessing the required data from the set saved at the start of the log phase. See in the Plugin Development Kit for more information. #7048 - External plugins handle certain error conditions better while the Kong balancer is being refreshed. Before when an
instance_id
of an external plugin changed, and the plugin instance attempted to reset and retry, it was failing because of a typo in the comparison. . - With this release,
kong.log
’s phase checker now accounts for the existence of the newresponse
pseudo-phase. Before users may have erroneously received a safe runtime error for using a function out-of-place in the PDK. #7109 - Kong no longer sandboxes the
string.rep
function. Beforestring.rep
was sandboxed to disallow a single operation from allocating too much memory. However, a single operation allocating too much memory is no longer an issue because in LuaJIT there are no debug hooks and it is trivial to implement a loop to allocate memory on every single iteration. Additionally, since thestring
table is global and obtainable by any sandboxed string, its sandboxing provoked issues on global state. - The
kong.pdk.node
function can now correctly iterates over all the shared dict metrics. Before this fix, users using thekong.pdk.node
function could not see all shared dict metrics under the Stream subsystem. #7078
Plugins
- LDAP Authentication (
ldap-auth
) The LDAP Authentication schema now includes a default value for theconfig.ldap_port
parameter that matches the documentation. Before the plugin documentation section included a reference to a default value for the LDAP port; however, the default value was not included in the plugin schema. #7438 - (
prometheus
) The Prometheus plugin exporter now attaches subsystem labels to memory stats. Before, the HTTP and Stream subsystems were not distinguished, so their metrics were interpreted as duplicate entries by Prometheus. #118 - (
zipkin
)- The plugin now works even when
balancer_latency
isnil
. - The plugin no longer shares context between several Zipkin plugins. Before the plugin was using
ngx.ctx
exclusively, even in a global context, which meant more than one instance of the Zipkin plugin would override each other. Now the plugin useskong.ctx.plugin
to hold thezipkin
table, instead ofngx.ctx
.
- The plugin now works even when
- External plugins This release includes better error messages when external plugins fail to start. With this fix, Kong detects the return code 127 (command not found), allowing it to display an appropriate error message, “external plugin server start command exited with command not found”.
2.4.1.3
Release Date 2021/09/02
Fixes
Enterprise
- This release fixes a regression in the Kong Dev Portal templates that removed dynamic menu navigation and other improvements from portals created in Kong Gateway v2.4.1.2.
2.4.1.2
Release Date 2021/08/18
Fixes
Enterprise
- Users can now successfully delete workspaces after deleting all entities associated with that workspace. Previously, Kong Gateway was not correctly cleaning up parent-child relationships. For example, creating an Admin also creates a Consumer and RBAC user. When deleting the Admin, the Consumer and RBAC user are also deleted, but accessing the
/workspaces/workspace_name/meta
endpoint would show counts for Consumers and RBAC users, which prevented the workspace from being deleted. Now deleting entities correctly updates the counts, allowing an empty workspace to be deleted. - Updates Kong Dev Portal templates’ JQuery dependency to v3.6.0, improving security.
- Users with the
kong_admin
role can now log in to Kong Manager whenenforce_rbac=both
is set. - Renames the property identifying control planes in hybrid mode when using Kong Vitals with anonymous reports enabled. Before, users received the error,
Cannot use this function in data plane
, on their control planes. - Updates Nettle dependency version from
3.7.2
to3.7.3
, fixing bugs that could cause RSA decryption functions to crash with invalid inputs.
Plugins
- (
openid-connect
) With this fix, when the OpenID Connect plugin is configured with aconfig.anonymous
consumer andconfig.scopes_required
is set, a token missing the required scopes will have the anonymous consumer headers set when sent to the upstream. - Fixes a regression in the Kong Collector plugin that caused HARs to be kept in its queue indefinitely.
Hybrid Mode
- Control planes are now more lenient when checking data planes’ compatibility in hybrid mode. See the section of the Hybrid Mode guide for more information. #7488
2.4.1.1
Release Date 2021/05/27
Fixes
Enterprise
- Kong Gateway now automatically removes trailing and leading whitespaces from RBAC
user_token
entries. Before, both Kong Manager and the Admin API (/rbac/users) allowed creating RBAC tokens with trailing whitespace. However, HTTP does not allow whitespace in theKong-Admin-Token
header value. Subsequently, a successfully created RBAC token was not usable. This was especially an issue when using Kong Manager to create tokens as it’s hard to see any accidental whitespace in the text field. - Kong Immunity used to send query parameters in plain text. With this fix, query parameters are now sent obfuscated.
Plugins
- When making a call using the plugin, instead of a successful connection, users received an error and the call was cancelled. With this fix, Kong Gateway now ensures the certificate phase is set in
ngx.ctx
, and the mTLS Authentication plugin works as expected.
Release Date 2021/05/18
Features
Core
This Kong Gateway version introduces relaxed version checks in hybrid mode between control planes and data planes, allowing data planes that are missing minor updates (up to two) to still connect to the control plane. Also, data planes are allowed to have a superset of plugins in addition to the control plane plugins. See for more information. 6932
Data planes are not allowed to connect to control planes if they are a different major version, a version newer than the control plane’s version, or missing plugins from the control plane.
UTF-8 characters can now be used in tags. This update expands the range of accepted characters in tags from a limited set of ASCII characters to almost all UTF-8 sequences. Exceptions:
,
and/
are reserved for filtering tags with “and” and “or”, and are not allowed in tags.- Non-printable ASCII (for example, the space character) is not allowed. See in the Admin API documentation for more information.
- Kong Gateway now supports using an Online Certificate Status Protocol (OCSP) responder in the cluster for hybrid mode control planes. This new feature can be configured in the
kong.conf
file. See cluster_oscp in the Configuration Reference for more information. - PostgreSQL
ssl_version
configuration now defaults toany
. Ifssl_version
is not explicitly set, theany
option ensures thatluasec
will negotiate the most secure protocol available.
Enterprise
When using Kong Gateway in Hybrid mode, if you’re not using features (for example, new plugin offerings) that the data planes don’t know about (because they aren’t using a version that contains that feature), the data planes can still read from a control plane of a more recent version. Prior to v2.4.1.0, we did our version compatibility checks at connection initiation, which meant that incompatibilities in the data plane were enforced even if those incompatibilities weren’t being used by the configuration at all. We’ve now switched the check to happen at configuration read time. See the section of the Hybrid Mode Overview for more information.
PDK
- This release includes a new JavaScript Plugin Development Kit (PDK). This addition allows users to write Kong plugins in JavaScript and TypeScript. See for more information.
- This release includes support for the Protobuf plugin communication protocol, which can be used in place of MessagePack to communicate with non-Lua plugins. 6941
- Plugin writers can now use the
ssl_certificate
phase on plugins in the . Previously plugin writers could not use thessl_certificate
phase on plugins in thestream
module, as it was only supported with the HTTP module. 6873
Plugins
- New plugin: OPA (
opa
)- The OPA plugin forwards requests to an Open Policy Agent and processes the request only if the authorization policy allows for it.
- New plugin: (
mocking
)- The Kong Mocking plugin leverages standards-based Open API Specifications (OAS) for sending out mock responses to APIs.
- Zipkin (
zipkin
)- The plugin now supports OT and Jaeger style
uber-trace-id
headers. Seeconfig.header_type
in the section of the Zipkin plugin documentation for more information. 101 - The plugin now allows insertion of custom tags on the Zipkin request trace. See
config.tags_header
in the section of the Zipkin plugin documentation for more information. 102 - The plugin now allows the creation of baggage items on child spans.
- The plugin now supports OT and Jaeger style
- JWT (
jwt
)- The plugin now supports ES384 JWTs signature validation.
- Logging plugins: File Log, , Syslog, , UDP Log, and
- Kong administrators now have a powerful new capability to transform logs to any format that’s needed for capturing, indexing, and correlating logs. When formatting, developers also have the ability to execute custom Lua code, opening up a new range of possibilities for generating logs to whichever specification administrators need the most. This feature uses the new PDK method
kong.log.set_serialize_value
, as well as the new sandbox capability, both introduced in Kong v2.3. 6944
- Kong administrators now have a powerful new capability to transform logs to any format that’s needed for capturing, indexing, and correlating logs. When formatting, developers also have the ability to execute custom Lua code, opening up a new range of possibilities for generating logs to whichever specification administrators need the most. This feature uses the new PDK method
Dependencies
- Bumped
opentracing-cpp
from v1.5.1 to v1.6.0 - Bumped
datadog
from v1.1.2 to v1.3.0 - Bumped
nginx-opentracing
from v0.9.0 to v0.14.0 - Bumped
jaeger
from v0.5.0 to v0.7.0 - Bumped
lua-resty-nettle
from v1.8.3 to v2.0.0 - Bumped
openresty
from v1.17.8.2 to v1.19.3.1 - Bumped
luasec
from v1.0.0 to v1.0.1 - Bumped
prometheus
from v1.2.0 to v1.2.1
Fixes
Core
- Kong 2.4 ensures that all the Core entities are loaded before loading any plugins. This fixes an error in which plugins could not link to or modify Core entities because they were not loaded yet. 6880
- Schema validations now log more descriptive error messages when types are invalid.
- Kong now ignores tags in Cassandra when filtering by multiple entities, which is the expected behavior and the one already existent when using PostgreSQL databases. See Tags in the Admin API documentation for more information.
- Users can proxy websockets through Kong when using Chrome or Firefox.
HTTP Connection
headers usually carry a list of headers meant for receivers (in this case a proxy) that are not meant to be proxied further (hop-by-hop headers). The Kong Gateway correctly cleans these headers, but it was a bit too aggressive and theUpgrade
header was cleared from responseConnection
headers, causing the connections to fail when using Firefox or Chrome. 6929 - Kong now accepts fully-qualified domain names ending in dots to be compliant with RFC internet standard. 6864
- Kong has removed unnecessary load from DNS servers by resolving an issue occurring when using upstreams for load balancing. When caching services, Kong does not warmup upstream names used as service hosts entries when warming up DNS entries, as they are not real DNS entries.
- Migrations order is now guaranteed to be always the same. Before, the order in which the subsystems were loaded changed randomly. Now, subsystems are sorted alphabetically, so the order in which migrations are executed is constant. 6901
- Buffered responses are disabled on connection upgrades. Kong cannot do buffered responses with, for example, websocket connection upgrades.
- The host header is updated between balancer retries. Before, Kong Gateway set the
Host
header during the access phase only and would send the wrong header if a target failed to serve and needed to be retried. 6796 - Fixed an issue that occurred when using upstreams for load balancing, where Kong was attempting to resolve the upstream name instead of the hostname and failing with the errors
name resolution failed
anddns server error: 3 name error
. The following updates correct the issue:- Kong does not cache empty upstream name dictionaries.
- Kong does not assume upstreams don’t exist after init phases. 7010
- Balancer retries now send the upstream the correct target hostname. This fix was originally include in but was reverted because of an issue in the Lua INGINX module. The Lua INGINX module issue has been fixed, and the original balancer retry fix re-applied. 1770
- The Developer Portal is now disabled when running without a license.
- Kong now ensures healthchecks and balancers are not created on control plane nodes.
- This release includes the following optimizations of Kong’s URL normalization code:
- only runs regex when necessary
- normalizes
/..
,/.
, and//
if necessary - moves anonymous callback functions to module local functions 7100
- Fixed an issue where control plane nodes would needlessly invalidate and send new configurations to data plane nodes.
- Kong now ensures HTTP code
405
is handled by Kong’s error page. 6933 - Kong now ensures errors in plugins
init_worker
do not break Kong’s worker initialization. - Fixed an issue where two subsequent TLS keep-alive requests would lead to incorrect plugin execution. 7102
- Kong now ensures Targets upsert operation behaves similarly to other entities’ upsert method.
- Kong now ensures failed balancer retries are saved and accounted for in log data. 6972
Enterprise
- Workspaces now allow special characters in their names. Kong Manager and the Dev Portal now correctly display these characters. This update also fixes an issue where workspaces with special characters were not correctly detecting collisions in route validation.
CLI
Kong now ensures kong start
and kong stop
prioritize the CLI flag --prefix
over environmental variable KONG_PREFIX
.
Configuration
Kong now ensures the subsystem allows for configuration of access logs format. 7046
Admin API
Kong now ensures targets with a weight of 0 are displayed in the Admin API. 7094
PDK
- Kong Gateway no longer leaves plugin servers alive after exiting and does not try to start them in the unsupported stream subsystem. 6849
- Golang does not cache
kong.log
methods. Thekong
table has some special-case logic for the.log
subtable, and avoiding caching preserves this logic. - Config file style and options case are now consistent. 6981
- Added correct Protobuf MacOS path to enable external plugins in Homebrew installations.
- Kong Gateway now auto-escapes upstream paths (
kong.service.request.set_path()
) to avoid proxying errors. 6978 - In the Golang PDK, ports are now declared as
Int
. Before they were incorrectly declaredStrings
. - Kong now ensures the new
response
phase is accounted for in the phase checkers. 7109
Plugins
- The Rate Limiting and plugins included default options that did not work well with DB-less or hybrid deployments because the database is not available on data plane nodes. With this fix, the default values and validation rules are now compatible with DB-less or hybrid modes. 6885
- (
oauth2
)- To improve user experience and limit confusion, the plugin now handles cases of client invalid token generation in a more predictable way. Before, the resulting error codes were confusing and unhelpful, often leading users to the wrong conclusions. 6594
- (
zipkin
)- The W3C parsing function was returning a non-used extra value that has been removed, and the plugin now early-exits if there is a problem with the W3C Trace Context header. 100
- Fixed a bug which randomly caused requests to fail with a 400 error code during span timestamping if the access phase was skipped.
- Kong JWT Signer (
jwt-signer
)- Cache now uses upsert instead of insert/update with databases.
- Key rotation is now more resilient on errors. For example, previously if there were errors like an error connecting to an external JSON Web Key Set(JWKS) url endpoint to fetch the JWKS, the error would halt progress. Now, the plugin attempts to respond more resiliently, for instance by using older JWKS already downloaded.
- Adds DB-less improvements. Before the plugin included some code paths that attempted to write data to a database. These code paths would cause errors with DB-less mode. Now instead of attempting to write data to a database, these code paths use alternative solutions such as storing data in local memory.
- (
exit-transformer
)- The plugin was not allowing access to any Kong modules within the sandbox except
kong.request
, which prevented access to other necessary modules such askong.log
.
- The plugin was not allowing access to any Kong modules within the sandbox except
- HMAC Authentication (
hmac-auth
)- The plugin now enables Just-in-time(JIT) compilation of authorization header regex.
- MTLS Authentication (
mtls-auth
)- Fixed an issue where the plugin did not work in DB-less mode.
- Kong now ensures plugins written in languages other than Lua can use
kong.reponse.get_*
methods, for examplekong.reponse.get_status
.
Deprecated
- The BasePlugin class was deprecated in Kong v2.4.x and will be removed in v3.0.x. Plugins that extend
base_plugin.lua
will continue to work until v3.0.x but should be updated to the newer, simpler .
Known issues
The plugin is incompatible with Kong Gateway v2.4.1.0. When making a call using the mTLS Authentication plugin, instead of a successful connection, users receive an error and the call is aborted. This error is caused by an update to the way Kong handles keep-alive connections. 7102
2.4.0.0 (beta)
Release Date 2021/04/13
Core
This Kong Gateway version introduces relaxed version checks in hybrid mode between control planes and data planes, allowing data planes that are missing minor updates (up to two) to still connect to the control plane. Also, data planes are allowed to have a superset of plugins in addition to the control plane plugins. See Managing the cluster using Control Plane nodes for more information.
Data planes are not allowed to connect to control planes if they are a different major version, a version newer than the control plane’s version, or missing plugins from the control plane.
UTF-8 characters can now be used in tags. This update expands the range of accepted characters in tags from a limited set of ASCII characters to almost all UTF-8 sequences. Exceptions:
,
and/
are reserved for filtering tags with “and” and “or”, and are not allowed in tags.- Non-printable ASCII (for example, the space character) is not allowed. See Tags in the Admin API documentation for more information.
- Kong Gateway now supports using an Online Certificate Status Protocol (OCSP) responder in the cluster for hybrid mode control planes. This new feature can be configured in the
kong.conf
file. See in the Configuration Reference for more information. 6887 - PostgreSQL
ssl_version
configuration now defaults toany
. Ifssl_version
is not explicitly set, theany
option ensures thatluasec
will negotiate the most secure protocol available.
PDK
- This release includes a new JavaScript Plugin Development Kit (PDK). This addition allows users to write Kong plugins in JavaScript and TypeScript. See Developing JavaScript plugins for more information.
- This release includes support for the Protobuf plugin communication protocol, which can be used in place of MessagePack to communicate with non-Lua plugins.
- This release enables the
ssl_certificate
phase on plugins in thestream
module. 6873
Plugins
- New plugin: OPA (
opa
)- The OPA plugin forwards requests to an Open Policy Agent and processes the request only if the authorization policy allows for it. Released as BETA and should not be deployed in production environment.
- New plugin: Mocking (
mocking
)- The Kong Mocking plugin leverages standards-based Open API Specifications (OAS) for sending out mock responses to APIs. Released as BETA and should not be deployed in production environment.
- (
zipkin
)- The plugin now supports OT and Jaeger style
uber-trace-id
headers. Seeconfig.header_type
in the Parameters section of the Zipkin plugin documentation for more information. - The plugin now allows insertion of custom tags on the Zipkin request trace. See
config.tags_header
in the Parameters section of the Zipkin plugin documentation for more information. - The plugin now allows the creation of baggage items on child spans. 98
- The plugin now supports OT and Jaeger style
- (
jwt
)- The plugin now supports ES384 JWTs signature validation. 6854
- Logging plugins: , Loggly, , TCP Log, , and HTTP Log
- Kong administrators now have a powerful new capability to transform logs to any format that’s needed for capturing, indexing, and correlating logs. When formatting, developers also have the ability to execute custom Lua code, opening up a new range of possibilities for generating logs to whichever specification administrators need the most. This feature uses the new PDK method
kong.log.set_serialize_value
, as well as the new sandbox capability, both introduced in Kong v2.3.
- Kong administrators now have a powerful new capability to transform logs to any format that’s needed for capturing, indexing, and correlating logs. When formatting, developers also have the ability to execute custom Lua code, opening up a new range of possibilities for generating logs to whichever specification administrators need the most. This feature uses the new PDK method
- OpenID Connect (
openid-connect
)kong-openid-connect
library updated to v2.1.0- Treats JWE tokens as opaque, so that they can be introspected.
- Adds support for Ed448 curve in EdDSA signing and verification and JWKS key generation.
Dependencies
- Bumped
opentracing-cpp
from v1.5.1 to v1.6.0 - Bumped
datadog
from v1.1.2 to v1.3.0 - Bumped
nginx-opentracing
from v0.9.0 to v0.14.0 - Bumped
jaeger
from v0.5.0 to v0.7.0 - Bumped
lua-resty-nettle
from v1.8.3 to v2.0.0 - Bumped
openresty
from v1.17.8.2 to v1.19.3.1
Fixes
Core
- Topological sort now prioritizes core, avoiding problems when plugin entities use core entities but don’t explicitly depend on them. 6880
- Schema validations now log more descriptive error messages when types are invalid.
- Kong now ignores tags in Cassandra when filtering by multiple entities, which is the expected behavior and the one already existent when using PostgreSQL databases. See Tags in the Admin API documentation for more information.
- Users can proxy websockets through Kong when using Chrome or Firefox.
HTTP Connection
headers usually carry a list of headers meant for receivers (in this case a proxy) that are not meant to be proxied further (hop-by-hop headers). The Kong Gateway correctly cleans these headers, but it was a bit too aggressive and theUpgrade
header was cleared from responseConnection
headers, causing the connections to fail when using Firefox or Chrome. 6929 - Kong now accepts fully-qualified domain names ending in dots to be compliant with RFC internet standards.
- Kong has removed unnecessary load from DNS servers by resolving an issue occurring when using upstreams for load balancing. When caching services, Kong does not warmup upstream names used as service hosts entries when warming up DNS entries, as they are not real DNS entries. 6891
- Migrations order is now guaranteed to be always the same. Before, the order in which the subsystems were loaded changed randomly. Now, subsystems are sorted alphabetically, so the order in which migrations are executed is constant.
- Buffered responses are disabled on connection upgrades. Kong cannot do buffered responses with, for example, websocket connection upgrades. 6902
- Entity relationships are now traverse-order-independent. This fix keeps track of all copied records and injects the new field on each copy.
- The host header is updated between balancer retries. Before, Kong Gateway set the
Host
header during the access phase only and would send the wrong header if a target failed to serve and needed to be retried. 6796 - The router prioritizes the route with most matching headers when matching headers.
- Fixed an issue involving multipart/form-data boundary checks. 6638
- Fixed an issue that occurred when using upstreams for load balancing, where Kong was attempting to resolve the upstream name instead of the hostname and failing with the errors
name resolution failed
anddns server error: 3 name error
. The following updates correct the issue:- Kong does not cache empty upstream name dictionaries.
- Kong does not assume upstreams don’t exist after init phases. 7010
- The Developer Portal is now disabled when running without a license.
PDK
- Kong Gateway no longer leaves plugin servers alive after exiting and does not try to start them in the unsupported stream subsystem. 6849
- Golang does not cache
kong.log
methods. Thekong
table has some special-case logic for the.log
subtable, and avoiding caching preserves this logic. - The
response
phase is now included on the list of public phases. 6638 - Config file style and options case are now consistent.
- Added correct Protobuf MacOS path to enable external plugins in Homebrew installations. 6980
- Kong Gateway now auto-escapes upstream paths (
kong.service.request.set_path()
) to avoid proxying errors. - In the Golang PDK, ports are now declared as
Int
. Before they were incorrectly declaredStrings
. 6994
Plugins
- The Rate Limiting and plugins included default options that did not work well with DB-less or hybrid deployments because the database is not available on data plane nodes. With this fix, the default values and validation rules are now compatible with DB-less or hybrid modes. 6885
- (
oauth2
)- To improve user experience and limit confusion, the plugin now handles cases of client invalid token generation in a more predictable way. Before, the resulting error codes were confusing and unhelpful, often leading users to the wrong conclusions. 6594
- (
zipkin
)- The W3C parsing function was returning a non-used extra value that has been removed, and the plugin now early-exits if there is a problem with the W3C Trace Context header. 100
- Fixed a bug which randomly caused requests to fail with a 400 error code during span timestamping if the access phase was skipped.
- Kong JWT Signer (
jwt-signer
)- Cache now uses upsert instead of insert/update with databases.
- Key rotation is now more resilient on errors.
- Adds DB-less improvements.
- (
exit-transformer
)- The plugin was not allowing access to any Kong modules within the sandbox except
kong.request
, which prevented access to other necessary modules such askong.log
.
- The plugin was not allowing access to any Kong modules within the sandbox except
2.3.3.4
Release Date 2021/09/02
Fixes
Enterprise
- This release fixes a regression in the Kong Dev Portal templates that removed dynamic menu navigation and other improvements from portals created in Kong Gateway v2.3.3.3.
2.3.3.3
Release Date 2021/08/18
Fixes
Enterprise
- Users can now successfully delete workspaces after deleting all entities associated with that workspace. Previously, Kong Gateway was not correctly cleaning up parent-child relationships. For example, creating an Admin also creates a Consumer and RBAC user. When deleting the Admin, the Consumer and RBAC user are also deleted, but accessing the
/workspaces/workspace_name/meta
endpoint would show counts for Consumers and RBAC users, which prevented the workspace from being deleted. Now deleting entities correctly updates the counts, allowing an empty workspace to be deleted. - Updates Kong Dev Portal templates’ JQuery dependency to v3.6.0, improving security.
- Users can now include special characters “.”, “-“, “_”, “~” in workspace names. Before when users created workspaces using the UI, the workspace name was validated; however, when using the Admin API to add users, the workspace name was not validated. Because the name was not validated in the Admin Api, users could create workspace names with special characters that would then break the environment.
- Kong Gateway now escapes “-“ and “.” special characters in workspace names when building the compiled pattern for collision detection.
Plugins
- (
openid-connect
) With this fix, when the OpenID Connect plugin is configured with aconfig.anonymous
consumer andconfig.scopes_required
is set, a token missing the required scopes will have the anonymous consumer headers set when sent to the upstream.
Hybrid Mode
- Control planes are now more lenient when checking data planes’ compatibility in hybrid mode. See the section of the Hybrid Mode guide for more information. #7488
2.3.3.2
Release Date 2021/04/21
Fixes
Enterprise
When using Kong Gateway in hybrid mode, schema, minor, and major version changes lead to a broken connection between the control planes and data planes. With this fix, the OAuth 2.0 Authentication plugin is upgraded to v2.2.0 and the plugin is downgraded from v1.9.0 to v1.8.4.
When using the Mutual TLS Authentication plugin with a service that was configured for mutual TLS, the Kong Gateway was not sending the client certificate to the upstream. With this fix, Kong Gateway now avoids patching a plugin’s handler if it is not defined and supports client certificates in
buffered_proxying
mode.
2.3.3.1
Release Date 2021/04/14
Features
Enterprise
Users can now set a custom login message and classification banner (top and bottom) on the Kong Manager login page. This classification banner persists beyond the login page and can be configured in the
kong.conf
file.The following new configuration options are now available:
admin_gui_header_txt
admin_gui_header_bg_color
admin_gui_header_txt_color
admin_gui_footer_txt
admin_gui_footer_bg_color
admin_gui_footer_txt_color
admin_gui_login_banner_title
admin_gui_login_banner_body
See the Kong Manager section of the Configuration Property Reference for more information.
Fixes
Core
- Fixed an issue that occurred when using upstreams for load balancing, where Kong was attempting to resolve the upstream name instead of the hostname and failing with the errors
name resolution failed
anddns server error: 3 name error
. The following updates correct the issue:- Kong does not cache empty upstream name dictionaries.
- Kong does not assume upstreams don’t exist after init phases. 7010
Enterprise
- Fixed an issue with upgrades of Kong Gateway (Enterprise) from v1.5.x to v2.1.x. Before the fix, when admin consumers were shared across multiple workspaces, it was possible for the migration to fail. The upgrade would fail because plugin entities that depend on consumer entities must live in the same workspace as the consumer entity. This fix migrates these plugin entities to the same workspace as the consumer entities. Customers affected by this issue will need to upgrade their v2.1 install to at least v2.1.4.5 before attempting to migrate from v1.5 to v2.1.
- Fixed an issue where customers could not add roles to new admin users via Kong Manager. With this fix, role selection now properly displays available roles to assign.
Plugins
- (
exit-transformer
)- Fixed an issue where the plugin was running the exit hook twice. It now correctly runs the exit hook once.
2.3.3.0
Features
Plugins
- (
request-validator
)- Content-type failures are now reported as such when
verbose_response
is enabled.
- Content-type failures are now reported as such when
- Rate Limiting Advanced
- Disallows decimal values between 0,1 in
sync_rate
.
- Disallows decimal values between 0,1 in
Fixes
- Adjusted the
systemd reload
command to do akong prepare
. - Removed output messages from non-strict failure builds on license validation module.
- Fixed an FFI table overflow issue when syncing DB-less declarative config.
- Kong now accepts values for Subject Alternate Name (SAN) in a certificate as per RFC 5280. The Mutual TLS Authentication plugin is now processing presented Alternate Names.
- Fixed a Websocket issue where connection upgrades would fail with a 502 after upgrading to v2.3.2.0.
- Upgrade header is not cleared anymore when response Connection header contains Upgrade.
- Avoided potential race conditions that could result in HTTP 500 errors when using the least-connection algorithm in the case where an upstream target becomes inaccessible.
- Kong does not try to warm up upstream names when warming up DNS entries.
- Migrations order is now guaranteed to be always the same.
- Buffered responses are disabled on connection upgrades.
- Schema validations now log more descriptive error messages when types are invalid.
- Kong now ignores tags in Cassandra when filtering by multiple entities, which is the expected behavior and the one already existent when using PostgreSQL databases
- Kong accepts fully-qualified domain names ending in dots.
- Now Kong does not leave plugin servers alive after exiting and does not try to start them in the unsupported stream subsystem.
- Changed default values and validation rules for plugins that were not well-adjusted for DB-less or hybrid modes.
- Topological sort now prioritizes core, avoiding problems when plugin entities use core entities but don’t explicitly depend on them.
Plugins
- OpenID Connect (
openid-connect
)- Add
config.disable_session
to be able to disable session creation with specified authentication methods. - Changed
Cache-Control="no-store"
instead ofCache-Control="no-cache, no-store"
, and only setPragma="no-cache"
with HTTP 1.0 (and below). - Fixed
/openid-connect/jwks
to not expose private keys (this bug was introduced in v1.6.0 (Kong Enterprise v2.1.3.1) and affects all versions up to v1.8.3 (Kong Enterprise v2.3.2)). - Token introspection now checks the status code properly.
- More consistent response body checks on HTTP requests.
- Fixed an issue where enabling zlib compressor did not affect the size of the session cookie.
- Add
- (
rate-limiting-advanced
)- Now the plugin does not pre-create namespaces on
init-worker
. As a side effect to this patch the plugin will create namespaces on the fly. This may result in a slightly (10-20%) increased response time on the first request.
- Now the plugin does not pre-create namespaces on
- Request Validator (
request-validator
)- Now the plugin correctly decodes and normalizes arrays when there are multiple headers with the same field-name.
- (
mtls-auth
)- Remove CA existence check on plugin creation - the check was not compatible with DB-less mode.
- Correctly fetch certificates from the end of the proof chain when consumer credentials are used.
- AWS Lambda (
aws-lambda
)- The plugin now respects
skip_large_bodies
config setting when using AWS API Gateway compatibility.
- The plugin now respects
- (
acme
)- Bump
lua-resty-acme
to v0.6.x; this fixes several issues with Pebble test server.
- Bump
- OAuth 2.0 Authentication (
oauth2
)- The plugin now has better handling for multiple cases of client invalid token generation.
2.3.2.0
Release Date 2021/02/11
Kong Gateway (Enterprise)
The following sections list Kong Enterprise-exclusive updates, features, and fixes for the 2.3.2.0 version.
Kong Enterprise is renamed to Kong Gateway or Kong Gateway (Enterprise) going forward. For a more detailed explanation, including information about Kong Gateway (OSS), see .
Features
Enterprise
- Kong Gateway can now run in free mode, without a license, which gives users access to Kong Manager and an easy upgrade path to Enterprise.
- A (non-OSS) Kong Gateway running in its default free Mode can be upgraded to add Enterprise functionality modules and features including Kong Vitals, RBAC, Workspaces, and Enterprise Plugins simply by applying a new Kong license. Contact your Kong sales representative for more information.
- A new Admin API endpoint allows application of a license to Kong Gateway.
- In hybrid mode, the control plane now propagates its license to the connected data planes in the cluster. Data planes do not require individual licenses.
- The Kong Gateway installation packages now reside under https://bintray.com/kong/ and do not require a login. Search for “gateway” to list all available packages.
- Added details to the error message of the entity type and number of entities that are preventing a Workspace from being deleted if the Workspace is not empty.
- mTLS connections to PostgreSQL are now supported.
- PostgreSQL connection using scram-sha256 authentication are now supported.
Core
- Kong checks version compatibility between the control plane and any data planes to ensure the data planes and any plugins have compatibility with the control plane in hybrid mode. The sync is stopped if the major/minor version differ or if the installed plugin versions differ between control plane and data plane nodes. For more information, see Version and Compatibility Checks.
- Kong Gateway now accepts UTF-8 characters in route and service names. Entities with a
name
field now support UTF-8 characters. - Certificates now have
cert_alt
andkey_alt
fields to specify an alternative certificate and key pair. - The Go pluginserver
stderr
andstdout
are now written into Kong Gateway’s logs, allowing Golang’s nativelog.Printf()
.- Introduced support for multiple pluginservers. This feature is backward-compatible with the existing single Go pluginserver.
Plugin Development Kit (PDK)
- Introduced a
kong.node.get_hostname
method that returns current node’s host name. - Introduced a
kong.cluster.get_id
method that returns a unique ID for the current Kong Gateway cluster. If the gateway is running in DB-less mode without a cluster ID explicitly defined, this method returns nil. For Hybrid mode, all Control Planes and Data Planes belonging to the same cluster returns the same cluster ID. For traditional database type deployments, all Kong Gateway nodes pointing to the same database will also return the same cluster ID. - Introduced a
kong.log.set_serialize_value
, which allows customizing the output ofkong.log.serialize
.
Plugins
- The (
http-log
) plugin now lets you add a table of headers to the HTTP request using theheaders
configuration parameter, which will help you integrate with many observability systems. - The Key Authentication (
key-auth
) plugin has two new configuration parameters:key_in_header
andkey_in_query
. Both are booleans and tell Kong Gateway whether to accept (true) or reject (false) passed in either the header or the query string. Both default to “true.” - The (
request-size-limiting
) plugin has a new configurationrequire_content_length
that causes the plugin to ensure a valid Content-Length header exists before reading the request body. - The Serverless Functions (
serverless-functions
) plugin introduces a sandboxing capability, is enabled by default, and where only Kong PDK, OpenRestyngx
APIs, and Lua standard libraries are allowed. - The (
ldap-auth-advanced
) plugin has two new features:- added config
log_search_results
that allows displaying all of the LDAP search results received from the LDAP server. - additional debug log statements added for authenticated groups.
- added config
- Rate Limiting Advanced (
rate-limiting-advanced
) plugin has added a jitter (random delay) for the Retry-After header. - (
mtls-auth
) plugin has added support for tags in the DAO and now ensures the existence of any provided CAs when creating the plugin entry. - Response Transformer Advanced (
response-transformer-advanced
) has json paths for nested elements and arrays and transform gzipped content. - Collector (
collector
, used for Immunity) plugin supports hybrid mode and has removed thelog_bodies
configuration option. - OpenID Connect Library
- Token introspection now checks the status code properly.
- More consistent response body checks on HTTP requests.
Configuration
client_max_body_size
andclient_body_buffer_size
, that previously hardcoded to 10m, are now configurable through nginx_admin_client_max_body_size and .- Kong-generated SSL private keys now have
600
file system permission. - Properties
ssl_cert
,ssl_cert_key
,admin_ssl_cert
,admin_ssl_cert_key
,status_ssl_cert
, andstatus_ssl_cert_key
is now an array: previously, only an RSA certificate was generated by default; with this change, an ECDSA is also generated. On intermediate and modern cipher suites, the ECDSA certificate is set as the default fallback certificate; on old cipher suite, the RSA certificate remains as the default. On custom certificates, the first certificate specified in the array is used. - Kong Gateway now runs as a
kong
user if it exists; if user does not exist in the system, thenobody
user is used, as before.
Dependencies
- Bumped
kong-plugin-serverless-functions
from 1.0 to 2.1. - Bumped
lua-resty-dns-client
from 5.1.0 to 5.2.0. - Bumped
lua-resty-healthcheck
from 1.3.0 to 1.4.0. - Bumped
OpenSSL
from 1.1.1h to 1.1.1i. - Bumped
kong-plugin-zipkin
from 1.1 to 1.2. - Bumped
kong-plugin-request-transformer
from 1.2 to 1.3.
Fixes
Core
- Fixed an issue where certain incoming URI may make it possible to bypass security rules applied on Route objects. This fix make such attacks more difficult by always normalizing the incoming request’s URI before matching against the Router.
- Fixed issue where a Go plugin would fail to read
kong.ctx.shared
values set by Lua plugins. - Properly trigger
dao:delete_by:post
hook. - Fixed issue where a route that supports both http and https (and has a hosts and SNIs match criteria) would fail to proxy http requests, as it does not contain an SNI.
- Fixed issue where a
nil
request context would lead to errorsattempt to index local 'ctx'
being shown in the logs. - Reduced the number of needed timers to active health check upstreams and to resolve hosts.
- Schemas for full-schema validations are correctly cached now, avoiding memory leaks when reloading declarative configurations.
- The schema for the upstream entities now limits the highest configurable number of successes and failures to 255, respecting the limits imposed by
lua-resty-healthcheck
. - Certificates for database connections now are loaded in the right order avoiding failures to connect to PostgreSQL databases.
- Fixed Lua
validate_function
in sandbox module. - Mark boolean fields with default values as required.
Enterprise
- Fixed an issue that incorrectly enforced plugins when they exist in the default and a named workspace. The plugin configuration in the default workspace was incorrectly overriding the disabled plugin configuration in the named workspace.
- Fixed an issue for vitals when proxy-cached-advanced or forward-proxy plugins (possibly others) are in use.
- Requests that received a cache hit using the plugins were not showing up under service/route vitals, but were visible under workspace vitals.
CLI
- Fixed issue where
kong reload -c <config>
would fail. - Fixed issue where the Kong Gateway configuration cache would get corrupted.
- Kong migrations now accepts a
-p/--prefix
flag.
Developer Portal
- Fixed issue when applying permissions to developers using the Application Registration feature.
Plugin Development Kit (PDK)
- Ensure the log serializer encodes the
tries
field as an array when empty, rather than an object.
Plugins
- The JWT (
jwt
) plugin disallows on consumers. - The (
request-transformer
) plugin does not allownull
in config anymore as they can lead to runtime errors. - OpenID Connect (
openid-connect
) - Fixed issue causing a 500 auth error when falling back to an anonymous user.
- Fixed consumer and discovery invalidation events that were returning when the operation was create. This could leave some cache entries in cache that need to be invalidated.
- Fixed a circular dependency issue with redirect function.
- Fixed init worker on clients could take a long time.
- The (
rate-limiting
) has improved counter accuracy.
Deprecated
Kong Studio
- Kong Studio is deprecated.
Distributions
- Support for CentOS-6 is removed and entered end-of-life on Nov 30, 2020.
2.3.0.0 (beta)
Release Date 2021/01/20
Kong Enterprise
The following sections list Kong Enterprise-exclusive updates, features, and fixes for the 2.3.0.0 beta version.
Features
Enterprise
A (non-OSS) Kong Gateway running in its default Free Mode can be upgraded to add Enterprise functionality modules and features including Kong Vitals, RBAC, Workspaces, and Kong Enterprise Plugins simply by applying a new Kong license. Contact your Kong sales representative for more information.
Core
- Kong checks version compatibility between the control plane and any data planes to ensure the data planes and any plugins have compatibility with the control plane in hybrid mode. The sync is stopped if the major/minor version differ or if the installed plugin versions differ between control plane and data plane nodes. For more information, see Version and Compatibility Checks.
- Kong now accepts UTF-8 characters in route and service names. Entities with a
name
field now support UTF-8 characters. - Certificates now have
cert_alt
andkey_alt
fields to specify an alternative certificate and key pair. - The Go pluginserver
stderr
andstdout
are now written into Kong’s logs, allowing Golang’s nativelog.Printf()
.- Introduced support for multiple pluginservers. This feature is backward-compatible with the existing single Go pluginserver.
Plugin Development Kit (PDK)
- Introduced a
kong.node.get_hostname
method that returns current node’s host name. - Introduced a
kong.cluster.get_id
method that returns a unique ID for the current Kong cluster. If Kong is running in DB-less mode without a cluster ID explicitly defined, this method returns nil. For Hybrid mode, all Control Planes and Data Planes belonging to the same cluster returns the same cluster ID. For traditional database type deployments, all Kong nodes pointing to the same database will also return the same cluster ID. - Introduced a
kong.log.set_serialize_value
, which allows customizing the output ofkong.log.serialize
.
Plugins
- The (
http-log
) plugin has been improved to allow you to add a table of headers to the HTTP request using theheaders
configuration parameter, which will help you integrate with many observability systems. - The Key Authentication (
key-auth
) plugin has two new configuration parameters:key_in_header
andkey_in_query
. Both are booleans and tell Kong whether to accept (true) or reject (false) passed in either the header or the query string. Both default to “true.” - The (
request-size-limiting
) plugin has a new configurationrequire_content_length
that causes the plugin to ensure a valid Content-Length header exists before reading the request body. - The Serverless Functions (
serverless-functions
) plugin introduces a sandboxing capability, is enabled by default, and where only Kong PDK, OpenRestyngx
APIs, and Lua standard libraries are allowed.
Configuration
client_max_body_size
andclient_body_buffer_size
, that previously hardcoded to 10m, are now configurable through nginx_admin_client_max_body_size and .- Kong-generated SSL private keys now have
600
file system permission. - Properties
ssl_cert
,ssl_cert_key
,admin_ssl_cert
,admin_ssl_cert_key
,status_ssl_cert
, andstatus_ssl_cert_key
is now an array: previously, only an RSA certificate was generated by default; with this change, an ECDSA is also generated. On intermediate and modern cipher suites, the ECDSA certificate is set as the default fallback certificate; on old cipher suite, the RSA certificate remains as the default. On custom certificates, the first certificate specified in the array is used. - Kong now runs as a
kong
user if it exists; if user does not exist in the system, thenobody
user is used, as before.
Dependencies
- Bumped
kong-plugin-serverless-functions
from 1.0 to 2.1. - Bumped
lua-resty-dns-client
from 5.1.0 to 5.2.0. - Bumped
lua-resty-healthcheck
from 1.3.0 to 1.4.0. - Bumped
OpenSSL
from 1.1.1h to 1.1.1i. - Bumped
kong-plugin-zipkin
from 1.1 to 1.2. - Bumped
kong-plugin-request-transformer
from 1.2 to 1.3.
Fixes
Core
- Fixed issue where a Go plugin would fail to read
kong.ctx.shared
values set by Lua plugins. - Properly trigger
dao:delete_by:post
hook. - Fixed issue where a route that supports both http and https (and has a hosts and SNIs match criteria) would fail to proxy http requests, as it does not contain an SNI.
- Fixed issue where a
nil
request context would lead to errorsattempt to index local 'ctx'
being shown in the logs. - Reduced the number of needed timers to active health check upstreams and to resolve hosts.
- Schemas for full-schema validations are correctly cached now, avoiding memory leaks when reloading declarative configurations.
- The schema for the upstream entities now limits the highest configurable number of successes and failures to 255, respecting the limits imposed by
lua-resty-healthcheck
. - Certificates for database connections now are loaded in the right order avoiding failures to connect to PostgreSQL databases.
CLI
- Fixed issue where
kong reload -c <config>
would fail. - Fixed issue where the Kong configuration cache would get corrupted.
Developer Portal
- Fixed issue when applying permissions to developers using the Application Registration feature.
Plugin Development Kit (PDK)
- Ensure the log serializer encodes the
tries
field as an array when empty, rather than an object.
Plugins
- The (
request-transformer
) plugin does not allownull
in config anymore as they can lead to runtime errors. - OpenID Connect (
openid-connect
) issue fixed causing a 500 auth error when falling back to an anonymous user.
Deprecated
Distributions
- Support for CentOS-6 is removed and entered end-of-life on Nov 30, 2020.
2.2.1.5
Release Date 2021/09/02
Fixes
Enterprise
- This release fixes a regression in the Kong Dev Portal templates that removed dynamic menu navigation and other improvements from portals created in Kong Gateway v2.2.1.4.
2.2.1.4
Release Date 2021/08/18
Fixes
Enterprise
- Users can now successfully delete workspaces after deleting all entities associated with that workspace. Previously, Kong Gateway was not correctly cleaning up parent-child relationships. For example, creating an Admin also creates a Consumer and RBAC user. When deleting the Admin, the Consumer and RBAC user are also deleted, but accessing the
/workspaces/workspace_name/meta
endpoint would show counts for Consumers and RBAC users, which prevented the workspace from being deleted. Now deleting entities correctly updates the counts, allowing an empty workspace to be deleted. - Updates Kong Dev Portal templates’ JQuery dependency to v3.6.0, improving security.
Plugins
- OpenID Connect (
openid-connect
) With this fix, when the OpenID Connect plugin is configured with aconfig.anonymous
consumer andconfig.scopes_required
is set, a token missing the required scopes will have the anonymous consumer headers set when sent to the upstream.
2.2.1.3
Release Date 2021/04/22
This release includes internal updates that do not affect product functionality.
2.2.1.2
Release Date 2021/04/14
Fixes
Enterprise
- Fixed an issue with upgrades of Kong Gateway (Enterprise) from v1.5.x to v2.1.x. Before the fix, when admin consumers were shared across multiple workspaces, it was possible for the migration to fail. The upgrade would fail because plugin entities that depend on consumer entities must live in the same workspace as the consumer entity. This fix migrates these plugin entities to the same workspace as the consumer entities. Customers affected by this issue will need to upgrade their v2.1 install to at least v2.1.4.5 before attempting to migrate from v1.5 to v2.1.
- Fixed an issue where customers could not add roles to new admin users via the Kong Cloud Manager. With this fix, role selection now properly displays available roles to assign.
Plugins
- Exit Transformer (
exit-transformer
)- Fixed an issue where the plugin was running the exit hook twice. It now correctly runs the exit hook once.
2.2.1.1
Release Date 2021/03/26
Fixes
Core
- Fixed an issue where certain incoming URI may make it possible to bypass security rules applied on Route objects. This fix make such attacks more difficult by always normalizing the incoming request’s URI before matching against the Router.
- Sanitize sanitize path postfix for additional security.
Enterprise
- Kong now display errors to better identify the issue when
validate_key
fails. - Kong now uses the correct workspace ID when selecting SNI in DB-less/hybrid mode.
- Fixed verification when using combined certificates.
- Corrected healthchecker thresholds.
DevPortal
- Before, when enabling application registration with key authentication, developers who created applications were able to see all Services for which the application registration plugin was enabled, regardless of the permissions granted to their role. With this fix, developers who create applications will only see Services if the role they are assigned to has been granted permissions to the relevant specs.
Plugins
- (
openid-connect
)- Fixed init workers that were prolonging Kong startup time.
- Fixed consumer and discovery invalidation events that were returning when the operation was
create
. This could leave some cache entries in cache that need to be invalidated. - Fixed a circular dependency issue with
redirect
function. - Added
config.disable_session
to be able to disable session creation with specified authentication methods. - Changed
Cache-Control="no-store"
instead ofCache-Control="no-cache, no-store"
, and only setPragma="no-cache"
with HTTP 1.0 (and below). - Fixed
/openid-connect/jwks
to not expose private keys (this bug was introduced in v1.6.0 (Kong Enterprise v2.1.3.1) and affects all versions up to v1.8.3 (Kong Enterprise v2.3.2)). - Token introspection now checks the status code properly.
- More consistent response body checks on HTTP requests.
- Fixed an issue where enabling zlib compressor the size of the session cookie was not changing in value.
- AWS Lambda (
aws-lambda
)- The plugin now respects
skip_large_bodies
config setting when using AWS API Gateway compatibility.
- The plugin now respects
- (
acme
)- Bump
lua-resty-acme
to v0.6.x; this fixes several issues with Pebble test server.
- Bump
- Exit Transformer (
exit-transformer
)- The plugin now allows access to Kong modules within the sandbox, not only to
kong.request
.
- The plugin now allows access to Kong modules within the sandbox, not only to
Plugin Dependencies
- OpenID Connect Library
- Token introspection now checks the status code properly.
- Added more consistent response body checks on
HTTP
requests.
2.2.1.0
Release Date 2020/12/31
Features
Developer Portal
- Added
key-auth
support to Portal Application Registration.
Fixes
Core
- OpenSSL version bumped to 1.1.1i. The OpenSSL version bump is related to CVE-2020-1971. We have performed an extensive review of OpenSSL usage in Kong and have found the following:
- The core product is not vulnerable to the high severity CVE-2020-1971.
- The
mtls-auth
plugin had a potential exploit associated with with CVE-2020-1971, but it would require an attacker to control a trusted CA or have admin port access, which for numerous reasons. The updated OpenSSL version in this release additionally protects themtls-auth
plugin. - As a precautionary measure, we have bumped the OpenSSL dependency version to OpenSSL 1.1.1i.
Enterprise
- Fixed an issue where
/tmp
directories will not be deleted when running Kong or Kong CLI. - Fixed an issue that prevented the use of keyring encryption of Kong database fields.
RCE (Remote Code Execution) Plugin Mitigations: Several Kong plugins allow arbitrary code execution by design, including the
serverless
plugin (also known aspre-function
andpost-function
capabilities) and theexit-transformer
plugin (for example, allows an administrator to configure a Lua-based response transformation). Changes include:- A new change locks down these plugins so that they have limited functions available in a sandbox, providing significant additional security for a user with an exposed admin port.
- Functions such as “require” are no longer available to scripts that run in these plugins for security purposes, because allowing “require” allows embedded additional arbitrary code execution.
Important: This change causes a breaking change in this patch release and it cannot be avoided. Our recommendation is that to avoid attackers trying to exploit any API gateway, like Kong, to gain access to internal networks. If you need the previous release behavior, including the ability to arbitrarily “require” libraries or if you want to lock things down further, we have introduced three new settings you can use:
KONG_UNTRUSTED_LUA = off | sandbox | on
Sets whether any custom Lua code can be used outside of Kong’s distributed code. Defaults to “sandbox”.KONG_UNTRUSTED_LUA_SANDBOX_REQUIRES = foo,bar
Which libraries, if any, you want to require in the sandbox. Defaults to an empty list.KONG_UNTRUSTED_LUA_SANDBOX_ENVIRONMENT = kong.request
Any additional objects you want to pass through to the sandbox environments. Defaults to an empty list.
For detailed information about these new properties, see the property reference documentation.
Developer Portal
- In the Developer Portal Edit Application dialog, the Edit button is renamed to Save.
Plugins
- Collector (
collector
, used for Immunity)- Use
kong.request.get_body()
- Use
- (
mtls-auth
)- Fixed (log) updating auth errors to handle fallthrough scenarios.
- Fixed (route, ws) ensuring workspace options are used for cache lookups.
- Forward Proxy Advanced(
forward-proxy
)- Fixed an issue where PDK logging phase check causes an error.
- (
openid-connect
)- Bumped
lua-resty-session
dependency to 3.8 to allow passing connection options to redis cluster client.
- Bumped
- Session (
session
)- Added endpoint key to Admin API.
- Bumped
lua-resty-session
dependency to 3.8.
Configuration
- Kong now runs as a
kong
user if it exists; if user does not exist in the system, thenobody
user is used, as before.
Breaking Changes
- See RCE (Remote Code Execution) Plugin Mitigations in the Kong Enterprise section.
2.2.0.0
Release Date 2020/11/17
Important: Kong Enterprise 2.2.0.0 includes 2.2.0.0 (beta) features, fixes, known issues, and workarounds. The changelog for 2.2.0.0 version includes only the diff between 2.2.0.0 and 2.2.0.0 (beta). See the 2.2.0.0 (beta) changelog for more information.
Features
Note: Feature updates for Kong Enterprise 2.2.0.0 version include 2.2.0.0 (beta) features.
Kong Manager
- No new features.
- Kong Brain and Service Map are removed.
Plugins
- (
openid-connect
)- Added
config.enable_hs_signatures
(false
is the default). - Added
config.session_compressor
.
- Added
- JWT Signer (
jwt-signer
)- Added
config.enable_hs_signatures
(false
is the default).
- Added
- (
aws-lambda
)- Added support for
isBase64Encoded
flag in Lambda function responses.
- Added support for
- gRPC-Web (
grpc-web
)- New configuration
pass_stripped_path
, which, if set to true, causes the plugin to pass the stripped request path (see the Route attribute) to the upstream gRPC service.
- New configuration
Fixes
Note: Fixes for Kong Enterprise 2.2.0.0 version include fixes.
OpenID Connect Library
- Changed to disable HS-signature verification by default.
- Changed to use
client_secret
as a fallback secret for HS-signature verification only when it is a string and has more than one character in it. - Fixes vulnerability in the OpenID Connect and JWT Signer Plugins. Login to the for OIDC advisory and details.
Plugins
- (
openid-connect
)- HS-signature verification is now disabled by default.
- Changed to use
client_secret
as a fallback secret for HS-signature verification only when it is a string and has more than one character in it. - Updated
lua-resty-session
dependency to 3.7.
- JWT Signer (
jwt-signer
)- HS-signature verification is now disabled by default.
2.2.0.0 (beta)
Release Date 2020/10/27
Kong Enterprise
The following sections list Kong Enterprise-exclusive updates, features, and fixes for the 2.2.0.0 beta version.
Dependencies
- Bumped the required lua-resty-openssl version to 0.6.8.
Features
Core
- Added support for TLS Redis connections when using the Kong Redis library.
- Added support for running Kong as the non-root user
kong
on distributed systems.
Plugins
- OpenID Connect (
openid-connect
)- Added the
issuers_allowed
configuration parameter, which introduces the ability to specify valid issuers for access token ISS claim. - Added the ability to pass
urn:ietf:params:oauth:grant-type:jwt-bearer
assertions with theclient_credentials
authentication method. - Added the
userinfo_endpoint
configuration parameter, which allows manual definition of a user info endpoint. - Added the ability to find nested claims using array indices. Array indices start at 1, same as in Lua.
- Added issuer cache warmup on node start.
- Added the
- Encryption support: The Redis strategy now supports TLS connections. Introduced the
redis.ssl
,redis.ssl_verify
, andredis.server_name
parameters for configuring TLS connections. Applies to the following plugins:- Rate Limiting Advanced (
rate-limiting-advanced
) - Proxy Caching Advanced (
proxy-cache-advanced
)
- Rate Limiting Advanced (
Fixes
Core
- Hybrid mode:
- Fixed an issue where, in a cluster with multiple Control Planes, configuration changes made by one Control Plane would not be picked up by other Control Planes, and therefore would not be pushed to all Data Planes.
- Fixed an issue with custom certificates. When using a workspace other than
default
, Kong Gateway did not present the configured certificate when the correct SNI was sent.
Plugins
- OpenID Connect (
openid-connect
)- Fixed a bug in issuer normalization.
- Improved discovery and rediscovery to be more resilient.
- When refreshing tokens, the old
id_token
is now preserved if a new one is not given. - Fixed an issue where token decoding also re-verified claims. Changed it to skip claim verification when decoding tokens.
- Fixed issue of sharing the cache key using the same credentials but with different endpoint arguments. Added a new parameter:
cache_tokens_salt
. The value for this parameter is auto-generated by default, which means that the token endpoint cache is not automatically shared between different plugin instances. - Fixed issue that caused the
unexpected_redirect_uri
setting to be ignored. - Fixed redirects to use
kong.response.exit
, which implements the proper short-circuiting semantics in Kong.
- OAuth Introspection (
oauth2-introspection
)- Fixed an issue where the cache would not be properly invalidated when a Consumer username was updated.
- Proxy Caching Advanced (
proxy-cache-advanced
)- Fixed a 500 error that would appear when the URL contained empty query string parameters.
- Exit Transformer (
exit-transformer
)- Fixed some cases where an
unknown
exit would not be handled.
- Fixed some cases where an
- AWS Lambda (
aws-lambda
)- Respect the
skip_large_bodies
config setting even when not using AWS API Gateway compatibility.
- Respect the
- ACME (
acme
)- Changed the cache to use non-nil TTL in Hybrid mode. This fixes a bug for renewals not updating the certificate after Kong Gateway 2.0.5.
- Fixed a bug in database mode where the renewal configuration was not properly stored.
- Prometheus (
prometheus
)- Switched to using the
Kong.pdk.serializer
instead of the deprecated basic serializer.
- Switched to using the
- Collector (
collector
, used for Immunity)- Removed the
/service_maps
passthrough.
- Removed the
Kong Gateway (OSS)
Kong Enterprise 2.2.0.0 beta inherits the following changes from the open-source Kong Gateway 2.2.0.0:
Dependencies
- For Kong Gateway 2.2, the required OpenResty version has been bumped to , and the the set of patches included has changed, including the latest release of lua-kong-nginx-module. If you are installing Kong from one of our distribution packages, you are not affected by this change.
Bumped OpenSSL version from
1.1.1g
to1.1.1h
.Note: If you are not using one of our distribution packages and compiling OpenResty from source, you must still apply Kong’s OpenResty patches (and, as highlighted above, compile OpenResty with the new
lua-kong-nginx-module
). Our repository allows you to do both easily.Cassandra 2.x support is now deprecated. If you are still using Cassandra 2.x with Kong, we recommend you to upgrade, since this series of Cassandra is about to be EOL with the upcoming release of Cassandra 4.0.
Additions
Core
- UDP support: Kong now features support for UDP proxying in its stream subsystem. The
"udp"
protocol is now accepted in theprotocols
attribute of Routes and theprotocol
attribute of Services. Load balancing and logging plugins support UDP as well. #6215 - Configurable Request and Response Buffering: The buffering of requests or responses can now be enabled or disabled on a per-route basis, through setting attributes
Route.request_buffering
orRoute.response_buffering
totrue
orfalse
. The default behavior remains the same: buffering is enabled by default for requests and responses. - Option to Automatically Load OS Certificates: The configuration attribute
lua_ssl_trusted_certificate
was extended to accept a comma-separated list of certificate paths, as well as a specialsystem
value, which expands to the system default certificates file installed by the operating system. This follows a very simple heuristic to try to use the most common certificate file in the most popular distros. #6342 - The consistent-hashing load balancing algorithm does not need to use the entire target history to build the same proxying destinations table on all Kong nodes anymore. Now, deleted targets are removed from the database and the target entities can be manipulated by the Admin API the same way as any other entity.
- Added
X-Forwarded-Path
header: If a trusted source provides anX-Forwarded-Path
header, it is proxied as is. Otherwise, Kong sets the content of said header to the request’s path. #6251 - Hybrid Mode:
- The table of Data Plane nodes at the Control Plane is now cleaned up automatically, according to a delay value configurable using the
cluster_data_plane_purge_delay
attribute, set to 14 days by default. - Data Plane nodes now apply only the last config when receiving several updates in sequence, improving the performance when large configs are in use. #6299
- Synchronization performance improvements: Kong now uses a new internal synchronization method to push changes from the Control Plane to the Data Plane, drastically reducing the amount of communication between nodes during bulk updates.
- The table of Data Plane nodes at the Control Plane is now cleaned up automatically, according to a delay value configurable using the
- The
Upstream.client_certificate
attribute can now be used for proxying. This allows theclient_certificate
setting used for mTLS handshaking with theUpstream
server to be shared easily among different Services. However,Service.client_certificate
will take precedence overUpstream.client_certificate
if both are set simultaneously. In previous releases,Upstream.client_certificate
was only used for mTLS in active health checks. #6348 - New
shorthand_fields
top-level attribute in schema definitions, which deprecatesshorthands
and includes type definitions in addition to the shorthand callback.
Admin API
- Hybrid Mode: Introduced the new endpoint
/clustering/data-planes
, which returns complete information about all Data Plane nodes that are connected to the Control Plane cluster, regardless of the Control Plane node to which they are connected. - Admin API responses now honor the
headers
configuration setting for including or removing theServer
header. #6371
PDK
- New function
kong.request.get_forwarded_prefix
: Returns the prefix path component of the request’s URL that Kong stripped before proxying to upstream, respecting the value ofX-Forwarded-Prefix
when it comes from a trusted source. #6251 - The
kong.response.exit
now honors theheaders
configuration setting for including or removing theServer
header. - The
kong.log.serialize
function now can be called using the stream subsystem, allowing various logging plugins to work under TCP and TLS proxy modes. #6036 - Requests with
multipart/form-data
MIME type now can use the same part name multiple times.
Plugins
- New Response Phase for custom plugins: Both Go and Lua custom plugins now support a new plugin phase called
response
in Lua plugins andResponse
in Go. Using it automatically enables response buffering, which allows you to manipulate both the response headers and the response body in the same phase. This enables support for response handling in Go, where header and body filter phases are not available, allowing you to use PDK functions such askong.Response.GetBody()
, and provides an equivalent simplified feature for handling buffered responses from Lua plugins as well. - AWS Lambda (
aws-lambda
)- Bumped to version 3.5.0.
- Added support for the
isBase64Encoded
flag in Lambda function responses.
- gRPC Web (
grpc-web
)- Introduced the configuration parameter
pass_stripped_path
, which, if set to true, causes the plugin to pass the stripped request path (see the Route attribute) to the upstream gRPC service.
- Introduced the configuration parameter
- Rate Limiting (
rate-limiting
)- Added support for rate limiting by path using the
limit_by = "path"
configuration attribute. Thanks for the patch! #6286
- Added support for rate limiting by path using the
- (
correlation-id
)- The plugin now generates a
correlation-id
value by default if the correlation ID header arrives but is empty. #6358
- The plugin now generates a
Deprecated Features
- Hybrid mode: The
/clustering/status
endpoint is now deprecated, since it returned only information about Data Plane nodes directly connected to the Control Plane node to which the Admin API request was made. It is superseded by the new/clustering/data-planes
endpoint. - The
shorthands
attribute in schema definitions is deprecated in favor of the newshorthand_fields
top-level attribute.
2.1.4.7
Release Date 2021/08/18
Fixes
Enterprise
- Users can now successfully delete workspaces after deleting all entities associated with that workspace. Previously, Kong Gateway was not correctly cleaning up parent-child relationships. For example, creating an Admin also creates a Consumer and RBAC user. When deleting the Admin, the Consumer and RBAC user are also deleted, but accessing the
/workspaces/workspace_name/meta
endpoint would show counts for Consumers and RBAC users, which prevented the workspace from being deleted. Now deleting entities correctly updates the counts, allowing an empty workspace to be deleted. - Updates Kong Dev Portal templates’ JQuery dependency to v3.6.0, improving security.
Plugins
- OpenID Connect (
openid-connect
) With this fix, when the OpenID Connect plugin is configured with aconfig.anonymous
consumer andconfig.scopes_required
is set, a token missing the required scopes will have the anonymous consumer headers set when sent to the upstream.
2.1.4.6
Release Date 2021/04/21
This release includes internal updates that do not affect product functionality.
Fixes
Enterprise
- Fixed an issue encountered when users were deleting a Kong Dev Portal collection and the collection was not defined in
portal.conf.yaml
orportal.conf.yaml
did not exist. Instead of deleting the content, users received an error. This issue also occurred when users were using the Kong Dev Portal CLI to wipe or deploy templates. With this fix, deleting content from the Kong Dev Portal works as expected. - In Kong Manager, users could receive an empty set of roles from an API request, even when valid RBAC roles existed in the database because of a filtering issue with portal and default roles on a paginated set. With this fix, if valid RBAC roles exist in the database, an API request returns with those valid roles.
2.1.4.5
Release Date 2021/03/31
Fixes
Enterprise
Fixed an issue with upgrades of Kong Gateway (Enterprise) from v1.5.x to v2.1.x. Before the fix, when admin consumers were shared across multiple workspaces, it was possible for the migration to fail. The upgrade would fail because plugin entities that depend on consumer entities must live in the same workspace as the consumer entity. This fix migrates these plugin entities to the same workspace as the consumer entities. Customers affected by this issue will need to upgrade their v2.1 install to at least v2.1.4.5 before attempting to migrate from v1.5 to v2.1.
2.1.4.4
Release Date 2021/03/26
Fixes
Core
- Fixed an issue where certain incoming URI may make it possible to bypass security rules applied on Route objects. This fix make such attacks more difficult by always normalizing the incoming request’s URI before matching against the Router.
- Sanitize sanitize path postfix for additional security.
Enterprise
- If a trusted source provides an
X-Forwarded-Path
header, it’s proxied as-is; otherwise, Kong will set the content of the header to the request’s URI. - Fixed a migration issue where workspaces IDs (
ws_id
) were not being appended to more than 1000 entities, resulting inws_id
beingnull
after migrations have been successfully completed withkong migrations finish
.
DevPortal
- Before, when enabling application registration with key authentication, developers who created applications were able to see all Services for which the application registration plugin was enabled, regardless of the permissions granted to their role. With this fix, developers who create applications will only see Services if the role they are assigned to has been granted permissions to the relevant specs.
Plugins
- (
openid-connect
)- Fixed init workers that were prolonging Kong startup time.
- Fixed consumer and discovery invalidation events that were returning when the operation was
create
. This could leave some cache entries in cache that need to be invalidated. - Fixed a circular dependency issue with the redirect function.
- Added
config.disable_session
to be able to disable session creation with specified authentication methods. - Changed
Cache-Control="no-store"
instead ofCache-Control="no-cache, no-store"
, and only setPragma="no-cache"
with HTTP 1.0 (and below). - Fixed
/openid-connect/jwks
to not expose private keys (this bug was introduced in v1.6.0 (Kong Enterprise v2.1.3.1) and affects all versions up to v1.8.3 (Kong Enterprise v2.3.2)). - Token introspection now checks the status code properly.
- More consistent response body checks on HTTP requests.
- Fixed an issue where enabling zlib compressor did not affect the size of the session cookie.
- ACME (
acme
) (updated to v0.2.14)- Bump
lua-resty-acme
to v0.6.x; this fixes several issues with Pebble test server.
- Bump
- (
exit-transformer
)- The plugin now allows access to Kong modules within the sandbox, not only to
kong.request
.
- The plugin now allows access to Kong modules within the sandbox, not only to
Plugin Dependencies
- OpenID Connect Library
- Token introspection now checks the status code properly.
- Added more consistent response body checks on
HTTP
requests.
2.1.4.3
Release Date 2020/12/31
Fixes
Core
- OpenSSL version bumped to 1.1.1i. The OpenSSL version bump is related to CVE-2020-1971. We have performed an extensive review of OpenSSL usage in Kong and have found the following:
- The core product is not vulnerable to the high severity CVE-2020-1971.
- The
mtls-auth
plugin had a potential exploit associated with with CVE-2020-1971, but it would require an attacker to control a trusted CA or have admin port access, which we recommend you block from attackers for numerous reasons. The updated OpenSSL version in this release additionally protects themtls-auth
plugin. - As a precautionary measure, we have bumped the OpenSSL dependency version to OpenSSL 1.1.1i.
Kong Enterprise
RCE (Remote Code Execution) Plugin Mitigations: Several Kong plugins allow arbitrary code execution by design, including the
serverless
plugin (also known aspre-function
andpost-function
capabilities) and theexit-transformer
plugin (for example, allows an administrator to configure a Lua-based response transformation). Changes include:- A new change in this release locks down these plugins so that they have limited functions available in a sandbox, providing significant additional security for a user with an exposed admin port.
- Functions such as “require” are no longer available to scripts that run in these plugins for security purposes, because allowing “require” allows embedded additional arbitrary code execution.
Important: This change causes a breaking change in this patch release and it cannot be avoided. Our recommendation is that users lock down their admin ports to avoid attackers trying to exploit any API gateway, like Kong, to gain access to internal networks. If you need the previous release behavior, including the ability to arbitrarily “require” libraries or if you want to lock things down further, we have introduced three new settings you can use:
KONG_UNTRUSTED_LUA = off | sandbox | on
Sets whether any custom Lua code can be used outside of Kong’s distributed code. Defaults to “sandbox”.KONG_UNTRUSTED_LUA_SANDBOX_REQUIRES = foo,bar
Which libraries, if any, you want to require in the sandbox. Defaults to an empty list.KONG_UNTRUSTED_LUA_SANDBOX_ENVIRONMENT = kong.request
Any additional objects you want to pass through to the sandbox environments. Defaults to an empty list.
For detailed information about these new properties, see the .
Backport Admins Migration Fix: When upgrading from 1.5.x.y to versions prior to 2.2.0.0, there was a known migration issue that prevented the upgrade from continuing and also generated log errors. This issue was caused by a bug in the handling of which workspaces consumers were assigned to. Release 2.1.4.3 resolves this issue the same way it does for 2.2.0.0. It is recommended that if you are upgrading to 2.1.x.y, that you use 2.1.4.3 to avoid migration errors.
Kong Manager
- Fixed an issue causing the Developer registration link to not work.
Plugins
- Mutual TLS Authentication (
mtls-auth
)- Fixed (log) updating auth errors to handle fallthrough scenarios.
- Fixed (route, ws) ensuring workspace options are used for cache lookups.
Breaking Changes
- See RCE (Remote Code Execution) Plugin Mitigations in the Kong Enterprise section.
2.1.4.2
Release Date 2020/11/17
Fixes
Core
- Fixed an issue causing workspace entity count meta information to get out of sync when deleting entities by name.
Kong Manager
- Added Service path to information at the top of Service specific page.
Kong Developer Portal
- Fixed Application Save button label, changing from Edit to Save.
OpenID Connect Library
- Changed to disable HS-signature verification by default.
- Changed to use
client_secret
as a fallback secret for HS-signature verification only when it is a string and has more than one character in it. - Fixes vulnerability in the OpenID Connect and JWT Signer Plugins. Login to the for OIDC advisory and details.
Plugins
- Mutual TLS Authentication (
mtls-auth
)- Fixed an issue when client certificate is not requested for plugins applied in non-default workspace.
- Proxy Cache Advanced (
proxy-cache-advanced
)- Fixed cache usage when URL includes empty query string param.
- (
openid-connect
)- HS-signature verification is now disabled by default.
- Changed to use
client_secret
as a fallback secret for HS-signature verification only when it is a string and has more than one character in it. - Updated
lua-resty-session
dependency to 3.7.
- JWT Signer (
jwt-signer
)- HS-signature verification is now disabled by default.
2.1.4.1
Release Date 2020/10/30
Fixes
Core
- Fix unique violation error for workspaces when using PUT.
- Fix cluster telemetry server name default.
- Allow certificates to be applied from workspaces.
- Fix time waiting calculation for 499 errors.
- Migration optimizations and fixes:
- Remove extra connections in PostgreSQL.
- Ensure that multiple workspaces are not created for Cassandra.
- Database optimizations and fixes:
- Correct wait for schema agreement timeout with Cassandra.
- Remove rate limiting metrics on database export.
- Fix cluster level invalidation for hybrid control plane nodes.
- Optimize workspace ID retrieval.
Plugins
- (
exit-transformer
)- Fix error getting route.
- Mutual TLS Authentication (
mtls-auth
)- Ensure that the basic serializer generates the
request.tls.client_verify
field based on this module’s validation result.
- Ensure that the basic serializer generates the
- (
request-validator
)- Update the
lua-resty-ljsonschema
library dependency. See library changelog.
- Update the
2.1.4.0
Release Date 2020/10/01
Fixes
Kong Gateway
- Fixed upsert for RBAC users using Admin API.
- Allow PostgreSQL keepalive time to be configurable.
Kong Manager
- Added path to service on display page.
Kong Developer Portal
- Fixed app
Save
button to display asSave
instead ofEdit
. - Added
plugin.service
check inapp_reg
helper. - Fixed application registration issue rendered unusable with certain plugin configurations.
- Fixed sidebar links with “.”
Deprecated Features
- Kong Brain is deprecated and not available for use in Kong Enterprise.
2.1.3.1
Release Date 2020/08/31
Fixes
Kong Gateway
- Fixed issues to properly migrate workspaces associated with ACL groups.
- Improved the amount of logging in the migrations framework.
Kong Manager
- Fixed docs link and messaging on the Dev Portals page.
2.1.3.0
Release Date 2020/08/25
Kong Enterprise 2.1.3.0 version includes 2.1.0.0 (beta) features, fixes, known issues, and workarounds. See the 2.1.0.0 (beta) changelog for more details.
Features
Note: Feature updates for Kong Enterprise 2.1.3.0 version includes 2.1.0.0 (beta) features.
Kong Gateway
- Inherited changes from OSS Kong in releases 2.0.x, 2.1.0, 2.1.1, 2.1.2, and 2.1.3.
- Workspaces code has been refactored for performance. The feature should work the same for most users.
- TLS version may be specified when using TLS to connect to a PostgreSQL database.
Kong Manager
- Open ID Connect (
openid-connect
) can now be used with usingconfig.authenticated_groups_claim
. - Can now see the
created_at
timestamp for consumer credentials. - Provide a warning when a user’s session is about to expire.
- Generate an RBAC token for an administrator rather than letting them set one.
- Plugin forms now have docs links to the Plugins Hub.
Kong Developer Portal
- Application Registration can now be configured to use a third-party OAuth provider.
Plugins
- (
openid-connect
)- Added
X-Authenticated-Groups
request header when doing authenticated groups. - Added
config.groups_required
andconfig.groups_claim
. - Added and
config.roles_claim
. - Added
DELETE :8001/openid-connect/issuers
endpoint (for cache clearing). - Added
DELETE :8001/openid-connect/jwks
endpoint (for rotating the jwks). - Added Admin API for DB-less (it is a single node only).
- Added support for
x5t
key lookups. - Added support for same
x5t
but differentalg
lookups. - Changed that
config.authenticated_groups_claim
is considered even on successful consumer mapping so that it enables dynamic groups, while using consumer mapping. This feature is used with Mapping Service Directory Groups to Kong Roles. - Changed code to be more resilient on rediscovery errors.
- Changed
config.rediscovery_lifetime
to default to 30 seconds instead of 300 seconds (5 minutes). - Changed plugin to do rediscovery on configuration changes (while still respecting
config.rediscovery_lifetime
).
- Added
- (
response-transformer-advanced
)- Added support to specify JSON types for configuration values. For example, by doing
config.add.json.json_types
: [“number”], the plugin will convert “-1” added JSON values into -1. - Improved performance by not inheriting from the BasePlugin class.
- The plugin is now defensive against possible errors and nil header values.
- Added support to specify JSON types for configuration values. For example, by doing
- Request Transformer Advanced (
request-transformer-advanced
)- Standardize on
allow
instead ofwhitelist
to specify the parameter names that should be allowed in request JSON body. Previouswhitelist
nomenclature is deprecated and support will be removed in Kong 3.0.
- Standardize on
Documentation Updates
- Plugin examples now include declarative configuration (YAML) information.
- Upgrade and Migration instructions are updated for migrating from Kong Enterprise 1.5.x to 2.1.x, Kong Community Gateway 1.5 to Kong Enterprise 1.5, and Developer Portal templates.
Fixes
Note: Fixes for Kong Enterprise 2.1.3.0 version includes the fixes.
Kong Manager
- Auto-generated role
workspace-portal-admin
does not display link to Dev Portal Editor. - Routes form did not expose
path_handling
attribute for adding/editing. - When Kong Manager is secured with OIDC, new workspaces do not include the auto-generated roles.
- Able to enumerate usernames via the
/admins
endpoint. - Unable to install Kong Manager outside the root directory.
Kong Developer Portal
- The
/developers/:developer/applications
endpoint allowed applications to be created for a developer other than the one in the path. - The change password endpoint for developers did not require the original password.
- User was not redirected to Login after a session timeout.
- Unable to configure
Accept Http If Already Terminated
for Application Registration plugin. Instead, add both Application Registration and OAuth 2.0 Authentication, and set the config on the Oauth2 Authentication plugin.
Plugins
- Collector (
collector
, for Brain and Immunity)- Fixed a bug that would make the plugin try to parse request/response body regardless of the content-type.
- d (
gql-rate-limiting-advanced
)- Fixed configuration using transformation that breaks in hybrid mode.
gRPC Gateway documentation is improved.
-
- Changed PostgreSQL column type for keys in
jwt_signer_jwks
table from JSONB to JSONB[] for a better hybrid compatibility. - Changed PostgreSQL column type for previous in
jwt_signer_jwks
table from JSONB to JSONB[] for a better hybrid compatibility. - Changed JWKS URIs to return application/jwk-set+json instead of application/json.
- Remove
run_on
field for 2.1.0.0 compatibility.
- Changed PostgreSQL column type for keys in
- LDAP Authentication Advanced (
ldap-auth-advanced
)- Return a 500 when there’s an error.
- Respond with a 401 instead of 403.
- Case-sensitive groups.
- Accept AD group names containing spaces.
- (
openid-connect
)- Fixed DB-less to reload private key JWTS on each request.
- Fixed runtime error on two log statements when validating required claims.
- Changed arguments parser to use Kong PDK for building dynamic redirect URI. Works with Kong
port_maps
configuration. - OpenID Connect Library
- Fixed a small typo in error message.
- Removed azp claims verification on other tokens than the ID token.
- Rate Limiting Advanced (
rate-limiting-advanced
)- Fixed per service rate limiting.
- (
response-transformer-advanced
)- Improved performance by not inheriting from the
BasePlugin
class. - Empty arrays are correctly preserved.
- Prevent the plugin from throwing an error when its access handler did not get a chance to run (e.g., on short-circuited, unauthorized requests).
- Standardized on
allow
instead ofwhitelist
to specify the parameter names that should be allowed in response JSON body. - The plugin is now defensive against possible errors and nil header values.
- Fixed an issue where the plugin was validating the value in
config.replace.body
against the content type as defined in the Content-Type response header.
- Improved performance by not inheriting from the
- Request Transformer Advanced (
request-transformer-advanced
)- Template errors are properly thrown.
- Updated version compatibility for plugins bundled with Kong Enterprise to 2.1.x.
Known Issues and Workarounds
Note: Known issues and workarounds for Kong Enterprise includes 2.1.0.0 (beta) known issues and workarounds.
The LDAP Authentication and LDAP Authentication Advanced plugins require a workaround to support CLI access with RBAC tokens: .
The Rate Limiting Advanced plugin does not support the
cluster
strategy in hybrid mode. Theredis
strategy must be used instead.For the plugin, standardize on
allow
instead ofwhitelist
to specify the parameter names that should be allowed in request JSON body. Previouswhitelist
nomenclature is deprecated and support will be removed in Kong 3.0.Breaking changes
When performing upgrade and migration to 2.1.x, custom entities and plugins have breaking changes. See https://docs.konghq.com/enterprise/2.1.x/deployment/upgrades/custom-changes/.
run_on
is removed from plugins, as it has not been used for a long time but compatibility was kept in 1.x. Any plugin withrun_on
will now break because the schema no longer contains that entry. If testing custom plugins against this beta release, update the plugin’s schema.lua file and remove therun_on
field.The (
correlation-id
) plugin has a higher priority than in CE. This is an incompatible change with CE in casecorrelation-id
is configured against a Consumer.The ability to share an entity between Workspaces is no longer supported. The new method requires a copy of the entity to be created in the other Workspaces.
2.1.0.0 (beta)
Release Date 2020/07/16
Features
Kong Gateway
- Inherited changes from OSS Kong in releases 2.0.x and 2.1.0.
- Workspaces code has been refactored for performance. The feature should work the same for most users.
- TLS version may be specified when using TLS to connect to a PostgreSQL database.
Kong Manager
- Open ID Connect (
openid-connect
) can now be used with Mapping Service Directory Groups to Kong Roles usingconfig.authenticated_groups_claim
. - Can now see the
created_at
timestamp for consumer credentials. - Provide a warning when a user’s session is about to expire.
- Generate an RBAC token for an administrator rather than letting them set one.
- Plugin forms now have docs links to the .
Kong Developer Portal
- Application Registration can now be configured to use a third-party OAuth provider.
Plugins
- Open ID Connect (
openid-connect
)- Added
X-Authenticated-Groups
request header when doing authenticated groups. - Added
config.groups_required
andconfig.groups_claim
. - Added
config.roles_required
andconfig.roles_claim
. - Added
DELETE :8001/openid-connect/issuers
endpoint (for cache clearing). - Added
DELETE :8001/openid-connect/jwks
endpoint (for rotating the jwks). - Added Admin API for DB-less (it is a single node only).
- Added support for
x5t
key lookups. - Added support for same
x5t
but differentalg
lookups. - Changed that
config.authenticated_groups_claim
is considered even on successful consumer mapping so that it enables dynamic groups, while using consumer mapping. This feature is used with Mapping Service Directory Groups to Kong Roles. - Changed code to be more resilient on rediscovery errors.
- Changed
config.rediscovery_lifetime
to default to 30 seconds instead of 300 seconds (5 minutes). - Changed plugin to do rediscovery on configuration changes (while still respecting
config.rediscovery_lifetime
).
- Added
- Response Transformer Advanced (
response-transformer-advanced
)- Added support to specify JSON types for configuration values. For example, by doing
config.add.json.json_types
: [“number”], the plugin will convert “-1” added JSON values into -1. - Improved performance by not inheriting from the BasePlugin class.
- The plugin is now defensive against possible errors and nil header values.
- Added support to specify JSON types for configuration values. For example, by doing
Fixes
Kong Manager
- Auto-generated role
workspace-portal-admin
does not display link to Dev Portal Editor. - Routes form did not expose
path_handling
attribute for adding/editing. - When Kong Manager is secured with OIDC, new workspaces do not include the auto-generated roles.
- Able to enumerate usernames via the
/admins
endpoint. - Unable to install Kong Manager outside the root directory.
Kong Developer Portal
- The
/developers/:developer/applications
endpoint allowed applications to be created for a developer other than the one in the path. - The change password endpoint for developers did not require the original password.
- User was not redirected to Login after a session timeout.
- Unable to configure
Accept Http If Already Terminated
for Application Registration plugin. Instead, add both Application Registration and OAuth 2.0 Authentication, and set the config on the Oauth2 Authentication plugin.
Plugins
- Response Transformer Advanced (
response-transformer-advanced
)- Improved performance by not inheriting from the
BasePlugin
class. - Empty arrays are correctly preserved.
- Prevent the plugin from throwing an error when its access handler did not get a chance to run (e.g., on short-circuited, unauthorized requests).
- Standardized on
allow
instead ofwhitelist
to specify the parameter names that should be allowed in response JSON body. - The plugin is now defensive against possible errors and nil header values.
- Fixed an issue where the plugin was validating the value in
config.replace.body
against the content type as defined in the Content-Type response header.
- Improved performance by not inheriting from the
- Request Transformer Advanced (
request-transformer-advanced
)- Template errors are properly thrown.
- Open ID Connect (
openid-connect
)- Fixed DB-less to reload private key JWTS on each request.
- Rate Limiting Advanced (
rate-limiting-advanced
)- Fixed per service rate limiting.
- LDAP Authentication Advanced (
ldap-auth-advanced
)- Return a 500 when there’s an error.
- Respond with a 401 instead of 403.
- Case-sensitive groups.
- Collector (
collector
, for Brain and Immunity)- Fixed a bug that would make the plugin try to parse request/response body regardless of the content-type.
- GraphQL Rate Limiting Advanced (
gql-rate-limiting-advanced
)- Fixed configuration using transformation that breaks in hybrid mode.
- Updated for 2.1.0.0 compatibility
- Proxy Cache Advanced (
proxy-cache-advanced
) - Canary (
canary
) - Rate Limiting Advanced (
rate-limiting-advanced
) - Collector (
collector
) - Vault Authentication (
vault-auth
) - Mutual TLS Authentication (
mtls-auth
) - Route Transformer Advanced(
route-transformer-advanced
) - GraphQL Proxy Caching Advanced (
gql-proxy-cache-advanced
) - GraphQL Rate Limiting Advanced (
gql-rate-limiting-advanced
)
- Proxy Cache Advanced (
Known Issues and Workarounds
Key Authentication (
key-auth-enc
) does not function in hybrid deployment mode.Breaking changes
run_on
is removed from plugins, as it has not been used for a long time but compatibility was kept in 1.x. Any plugin withrun_on
will now break because the schema no longer contains that entry. If testing custom plugins against this beta release, update the plugin’s schema.lua file and remove therun_on
field.The Correlation ID (
correlation-id
) plugin has a higher priority than in CE. This is an incompatible change with CE in casecorrelation-id
is configured against a Consumer.The ability to share an entity between Workspaces is no longer supported. The new method requires a copy of the entity to be created in the other Workspaces.
1.5.0.11
Release Date 2021/04/22
This release includes internal updates that do not affect product functionality.
Fixes
Enterprise
- In Kong Manager, users could receive an empty set of roles from an API response, even when valid RBAC roles existed in the database because of a filtering issue with portal and default roles on a paginated set. With this fix, if valid RBAC roles exist in the database an API request returns with those valid roles.
1.5.0.10
Release Date 2021/03/26
Fixes
Core
- Fixed an issue where certain incoming URI may make it possible to bypass security rules applied on Route objects. This fix make such attacks more difficult by always normalizing the incoming request’s URI before matching against the Router.
- Sanitize path postfix for additional security.
Enterprise
- Added pgp signature to Bintray-rpm package of
kong-enterprise
, version 1.5.0.9. - Added the following updates with backport of bypass security vulnerability:
- Support for read transformations
- Support for
X-Forwarded-Prefix
X-Forwarded-Path
header
Developer Portal
- Before, when enabling application registration with key authentication, developers who created applications were able to see all Services for which the application registration plugin was enabled, regardless of the permissions granted to their role. With this fix, developers who create applications will only see Services if the role they are assigned to has been granted permissions to the relevant specs.
1.5.0.9
Release Date 2020/12/31
Fixes
Core
- OpenSSL version bumped to 1.1.1i. The OpenSSL version bump is related to CVE-2020-1971. We have performed an extensive review of OpenSSL usage in Kong and have found the following:
- The core product is not vulnerable to the high severity CVE-2020-1971.
- The
mtls-auth
plugin had a potential exploit associated with with CVE-2020-1971, but it would require an attacker to control a trusted CA or have admin port access, which for numerous reasons. The updated OpenSSL version in this release additionally protects themtls-auth
plugin. - As a precautionary measure, we have bumped the OpenSSL dependency version to OpenSSL 1.1.1i.
Kong Enterprise
RCE (Remote Code Execution) Plugin Mitigations: Several Kong plugins allow arbitrary code execution by design, including the
serverless
plugin (also known aspre-function
andpost-function
capabilities) and theexit-transformer
plugin (for example, allows an administrator to configure a Lua-based response transformation). Changes include:- A new change in this release locks down these plugins so that they have limited functions available in a sandbox, providing significant additional security for a user with an exposed admin port.
- Functions such as “require” are no longer available to scripts that run in these plugins for security purposes, because allowing “require” allows embedded additional arbitrary code execution.
Important: This change causes a breaking change in this patch release and it cannot be avoided. Our recommendation is that to avoid attackers trying to exploit any API gateway, like Kong, to gain access to internal networks. If you need the previous release behavior, including the ability to arbitrarily “require” libraries or if you want to lock things down further, we have introduced three new settings you can use:
KONG_UNTRUSTED_LUA = off | sandbox | on
Sets whether any custom Lua code can be used outside of Kong’s distributed code. Defaults to “sandbox”.KONG_UNTRUSTED_LUA_SANDBOX_REQUIRES = foo,bar
Which libraries, if any, you want to require in the sandbox. Defaults to an empty list.KONG_UNTRUSTED_LUA_SANDBOX_ENVIRONMENT = kong.request
Any additional objects you want to pass through to the sandbox environments. Defaults to an empty list.
For detailed information about these new properties, see the property reference documentation.
Breaking Changes
- See RCE (Remote Code Execution) Plugin Mitigations in the Kong Enterprise section.
1.5.0.8
Release Date 2020/11/17
Fixes
OpenID Connect Library
- Changed to disable HS-signature verification by default.
- Changed to use
client_secret
as a fallback secret for HS-signature verification only when it is a string and has more than one character in it. - Fixes vulnerability in the OpenID Connect and JWT Signer Plugins. Login to the for OIDC advisory and details.
1.5.0.7
Release Date 2020/11/11
Fixes
Kong Gateway
- Fixed PUT request issue causing unique violation error for workspaces.
- Improved cache warmup performance for reduced database calls.
- Added migration to create TTL indices.
Kong Manager
- Fixed broken link to docs and updated text on Dev Portals page.
Developer Portal
- Fixed issue to allow users to delete developers.
Dependencies
- Updated lua-resty-openssl version to 0.6.8.
Plugins
- Added ability to preserve empty arrays correctly.
Release Date 2020/10/01
Features
Kong Gateway
- Allow PostgreSQL keepalive time to be configurable.
Kong Manager
- Added path to service on display page.
Plugins
- Rate Limiting Advanced (
rate-limiting-advanced
)- Added RateLimit headers for draft Request for Comments (RFC).
Fixes
Kong Gateway
- Fixed propagation of posted health check across Nginx workers.
Plugins
- Collector (
collector
, for Brain and Immunity)- Fixed bug caused when trying to call
select_all
. - Fixed bug caused when trying to read a request body when parsing was unknown.
- Fixed bug caused when using the
basic_serializer
in the access stage.
- Fixed bug caused when trying to call
- Request Validator (
request-validator
)- Upgraded
lua-resty-ljsonschema
library to v1.1.0.
- Upgraded
1.5.0.5
Release Date 2020/08/13
Fixes
Kong Gateway
- Optimized Admin API requests when a large number of entities are in the system and RBAC is enabled.
- Improved Kong handling of the encoding of sparce arrays
Kong Manager
- Fixed the creation of default roles and permissions when a new Workspace is created.
Developer Portal
- Fixed the creation of pages, partials, and specs in the legacy Developer Portal.
- Fixed Catalog updates in the Developer Portal when a spec is deleted.
- Fixed an issue when updating a spec in the legacy Developer Portal.
Plugins
- Request Validator
- Requires a top-level
type
parameter for jsonschema - Bumped version to 1.0.0
- Requires a top-level
1.5.0.4
Release Date 2020/06/26
Fixes
Kong Gateway
- Upgraded PostgreSQL driver to support selecting the TLS version when connecting to Postgres.
- Fixed issue causing incorrect
service_count
for license report endpoint.
Kong Manager
- Exposed Routes
path_handling
attribute from the Admin API in Kong Manager.
Plugins
- OpenID Connect
- Fixed Consumers to call the correct function when setting an anonymous Consumer (introduced with 1.5.0).
- Fixed unauthorized responses giving 403 instead of 401 as a status code (introduced with 1.5.0).
- Collector
- Fixed issue that occurred when Kong returned a 404 and caused logs to fill with messages.
1.5.0.3
Release Date 2020/05/28
Fixes
Kong Gateway
- Fixed window counters issue caused when multiple sets of Redis cluster addresses are configured across multiple rate-limiting-advanced plugins
- Fixed an issue where authentication plugins could not load legacy and empty
config.anonymous
strings from the database - Reduced the log level of one line in the Balancer code from
ERROR
toWARN
Kong Manager
- Included a reference to Kong’s EULA in Kong Manager
Plugins
- Forward Proxy Advanced
- Fixed a runtime error caused by moving Vitals to the log phase
- Mutual TLS Authentication
- Fixed issue to correctly skip verification when mode is
IGNORE_CA_ERROR
- Fixed issue to correctly skip verification when mode is
- OpenID Connect
- Added support for Redis Clusters for session storage
- Added
config.session_redis_connect_timeout
- Added
config.session_redis_read_timeout
- Added
config.session_redis_send_timeout
- Added
config.session_redis_ssl
- Added
config.session_redis_ssl_verify
- Added
config.session_redis_server_name
- Added
config.session_redis_cluster_nodes
- Added
config.session_redis_cluster_maxredirections
- Added
config.preserve_query_args
- Added
config.introspection_headers_client
- Chore cookie removal function to be more robust
- Changed
config.verify_parameters
default parameter fromtrue
tofalse
- Bumped
lua-resty-session
dependency to 3.5 - Changed in issuer normalization that also removes standard OAuth 2.0 Authorization Server Metadata suffix from issuer
- Refactored code base for easier maintenance
- openid-connect library
- Added support for same kid but different
alg
lookups - Added support for OAuth 2.0 Authorization Server Metadata (rfc8414)
- Added support for same kid but different
- Request Validator
- Fixed support for numeric keys
- Auth plugins
- Fixed support for setting
anonymous=""
- Fixed support for setting
1.5.0.2
Release Date 2020/04/28
Fixes
Kong Gateway Community
- Fixed an issue where the frequent Target CRUD could result in a broken load balancer
Kong Manager
- Fixed the sorting order of Routes.
- Fixed an issue where editing a Developer meta field could cause the custom field name to revert to the default value
- Fixed an issue where listing Developers and Files only showed the first page of results
1.5.0.1
Release Date: 2020/04/16
Fixes
Plugins
- Kong OpenID Connect Library
- Changes
client_secret_jwk
andprivate_key_jwt
to not pass the rfc7521 optionalclient_id
as it was causing a problem with Okta
- Changes
- OpenID Connect
- Fixes
openid_connect/jwks
to not useerr_t
with JWKS custom DAO that is not returning theerr_t
- Fixes JWKS custom DAO to not return cache hit level as a third return value on errors. Previously, it was sometimes inaccurately treated as
err_t
- Adds a teardown migration to create the
oic_jwks
row, so that it is not needed to create on init_worker
- Fixes
- Request Transformer Advanced
- Fixes bug when adding a header with the same name as a removed one
- Improves performance by not inheriting from the BasePlugin class
- Converts the plugin away from deprecated functions
1.5.0.0
Release Date: 2020/04/09
Features
Kong Gateway Community
- Includes open-source features contained in Kong Gateway Community 1.4 and 1.5 releases, with the exception that Kong Enterprise does not support running on ARM processors at this time
Kong Manager
- Redesigned Service and Route pages to support Immunity Alerts
- Services, Routes, Consumers, and other entity lists are sortable
- Services, Routes, Consumers, and other entities can be viewed and exported as JSON
- Consumer Alerts added to the Immunity Alerts page
- Approve, reject, and revoke Portal Application Service Contracts
- Associate Portal Specs with Services through Documents
Kong Developer Portal
- : Developers can create Applications to consume Services using the Portal Application Registration plugin
Plugins
- Kong OpenID Connect Library
- Add support for
client_secret_jwt
andprivate_key_jwt
- Add support for
- OpenID Connect
- Add support for dynamic login redirect uri
- Add support for
config.session_strategy
configuration parameter - Add support for
session_cookie_idletime
configuration parameter - Make consumer cache keys generated similarly as in JWT Signer plugin
- Add support for
client_secret_jwt
andprivate_key_jwt
authentication - Add
config.client_auth
- Add
config.client_alg
- Add
config.client_jwk
- Add
config.introspection_endpoint_auth_method
- Add
config.revocation_endpoint_auth_method
- Add
config.display_errors
- Change
config.token_endpoint_auth_method
to includeclient_secret_jwt
andprivate_key_jwt
- Add support for
cookie
forconfig.bearer_token_param_type
- Add support for
config.bearer_token_cookie_name
- JWT Signer
- Add support for more signing algorithms: HS256, HS384, HS512, RS512, ES256, ES384, ES512, PS256, PS384, PS512, EdDSA
- IP Restriction
- Supports IPv6 addresses
- MTLS Auth
- Support for OCSP
- Support for CRL
- Collector
- Rewritten to follow more modern plugin approaches
- Added functionality to power Consumer Alerts
- Kafka Log
- Support for API version of a produce request
- Portal Application Registration
- Allow Portal Applications to request access and consume Services
- Serverless functions
- Add the ability to run functions in each request phase
- Upstream TLS
- The Upstream TLS plugin is not available in the Kong Enterprise 1.5.x release and is not supported. This plugin was deprecated in Kong Enterprise 1.3.0.0 and is only functional with Kong Enterprise versions 0.35 and 0.36. Be sure to remove this plugin before upgrading to the 1.5.x release to avoid errors or issues with your upgrade
Fixes
Kong Gateway
- Fixes a bug where entities loaded through cache warmup did not include Workspace properly
- Fixes a bug that could prevent a
ca_certificate
from being saved if it was more than 2713 bytes - Fixes a bug where a route collision was not detected when the content type of a POST request was sent as
application/x-www-form-urlencoded
- Fixes a bug where a route collision was not detected when a PATCH request was sent to the
/services/service_id/routes/route_id
endpoint - Added headers and
snis
route collision detection capabilities - Fixes an inconsistency where it was still possible to execute
db_export
despite it not being supported in Kong Enterprise
Kong Manager
- Fixes a bug that prevented updating a Service with a tag
- Fixes a bug in file permission on kconfig.js
- Fixes a bug configuring the OpenID Connect plugin
- Fixes a bug when resetting the password of an admin that is not in the default Workspace
- Fixes a bug where the Response Rate Limiting plugin could not be applied to a consumer
Kong Developer Portal
- Improve caching of Developers when accessing proxy via Developer Credentials
- Fixes a bug with a redirect on logout
- Fixes a bug when redirecting to login from a spec in a non-default workspace
- Fixes a bug with account verification links in Portals using sub-domains
- Fixes a bug with validation of * value for
portal_cors_origins
in Workspace config - Fixes various styling issues
Plugins
- OpenID Connect
- Fixes cluster invalidate consumer cache
- Fixes pcall kong.configuration to handle command-line invocations
- Optimize consumer cache key invalidations
- Unified session handling code in a single place
- Make the code more robust by checking the right data types
- Fixes issue when bearer
auth_method
was disabled that it was not disabled if introspection was enabled - Bump
lua-resty-session
dependency to 3.1
- JWT Signer
- Fixes consumer invalidation so that it now happens cluster wide, reverting the change made in 1.0.2
- Change the plugin so that it does not inherit anymore from BasePlugin
- Fixes a problem with RSA signature truncation in some edge case reported by a customer
- Updated lua-resty-nettle version to address jwt-signer plugin issue
- Logging plugins will strip
authorization
header - CorrelationID
- Raise the priority of the plugin so it is run first on a request
- Request Terminator
- Do not send a
Content-Length
header with a 204 response
- Do not send a
Known Issue and Workaround
- Mutual TLS Authentication Plugin
- For the parameter
config.revocation_check_mode
, the default valueIGNORE_CA_ERROR
has a known issue in version 1.5.0.0 and later. As a workaround, manually set the value toSKIP
- For the parameter
1.3.0.3
Release Date: 2020/11/19
Fixes
OpenID Connect Library
- Changed to disable HS-signature verification by default.
- Changed to use
client_secret
as a fallback secret for HS-signature verification only when it is a string and has more than one character in it. - Fixes vulnerability in the OpenID Connect and JWT Signer Plugins. Login to the for OIDC advisory and details.
1.3.0.2
Release Date: 2020/02/20
Kong Gateway
- Adds support for Amazon Linux 2
- Compiles NGINX OpenTracing module with Kong (currently only available for Amazon Linux 2 and Docker Alpine)
- Includes a Datadog tracer for Amazon Linux 2 at /usr/local/kong/lib/libdd_opentracing_plugin.so
- Includes a Jaeger tracer for Docker Alpine at /usr/local/kong/lib/libjaegertracing.so
- Provides a default logrotate configuration file
- Adds support for
pg_ssl_required
configuration which prevents connection to non-SSL enabled PostgreSQL server - Adds support for regular expressions when using
audit_log_ignore_paths
- Allows the Kong Enterprise systemd service to be reloaded with systemctl reload kong-enterprise-edition
Kong Manager
- Kafka plugins can now be configured
Plugins
- OpenID Connect
- Fixes header encoding to use Base64 (non-URL variant) with padding
- Adds support for keyring encryption of
client_id
andclient_secret
- Adds support for None with
config.session_cookie_samesite
andconfig.authorization_cookie_samesite
- Adds support for
config.session_cookie_maxsize
- Bumps
lua-resty-session
dependency to 2.26
- Rate Limiting Advanced
- Adds support for authentication when using Redis Sentinel node
- Response Transformer Advanced
- Adds support for removal of specific header values of a given header field, including with regular expression
- Request Validator
- Adds configuration to plugin which allows it to return validation error back to the client as part of request response
- AWS Lambda
- Additional AWS regions support
Fixes
Kong Gateway
- Fixes a condition that could put a target of an upstream into an improper
DNS_ERROR
state - Resolves a problem when using routes with custom header based routing that could lead to incorrect route matching
- Improves
LUA_CPATH
handling - Improves behavior and log messages when rate-limiting counter shared dict is out of space
- Resolves possible database deadlock situation when under high load conditions
- Resolves possible race condition on Cassandra when under high load of Admin API CRUD operations
Kong Developer Portal
- Fixes a bug that could lead to a stack overflow in certain conditions
Kong Manager
- Fixes incorrect schema violation error
claims_to_verify
when entering configuration for JWT plugin - Kong and Kong Manager now start correctly from a custom prefix
Plugins
- Mutual TLS Authentication
- Bug fixes related to configuration and ACL plugin usage
- OpenAPI2Kong
- Fixes a bug related to garbage collection
- Proxy Caching Advanced
- Fixes to allow Kong to properly cache responses when requests are passed through an additional NGINX before reaching Kong
1.3.0.1
Release Date: 2019/12/19
Features
- Kong Enterprise now officially supports RHEL 8
- Kong Enterprise now has a License Reports module for customers to view current usage metrics. For more information, contact your Kong Account Executive.
- (Alpha feature) Kong Enterprise can now perform encryption-at-rest for sensitive fields within the data store (PostgreSQL or Cassandra).
Kong Developer Portal
- Adds ability to customize the email templates used by the Kong Developer Portal
- Portal-CLI
- Adds more robust support for Windows
- Adds command line support for optional arguments to override the CLI configuration file
Kong Manager
- RBAC token control: A new property
rbac_token_enabled
on an Admin allows you to control whether that Admin can use and reset their RBAC token. When it is true, the Admin can log in to Kong Manager and can use their RBAC token on the Admin API. When it is false, the Admin can only use the Admin API in conjunction with a valid session.
Plugins
- OpenAPI2Kong
- Adds trace to errors to identify the originating YAML/JSON element that caused the error.
- Key Authentication - Encrypted
- Provides key authentication for Routes and Services, with authentication tokens stored in a format that is encrypted at rest.
Changes
- Removes the openapi2kong API endpoint
Kong Manager
- Adds icons for new Plugins
- Adds ability for read-only admins to view plugin configurations
Fixes
- Fixes issue where settings in the kong configuration file did not always update
.kong_env
- Fixes issue where updating a plugin with a similar payload as its initial configuration resulted in a schema violation
- Fixes issue where
db_import
would fail due to missing libraries
Kong Developer Portal
- Fixes various spec formatting issues
- Fixes issue where URLs were rendering incorrectly in code snippets
- Fixes issue where numeric keys were incorrectly parsed in yaml spec files
- Fixes issue where certain Swagger paths erred when header parameters were included
- Fixes issue where code snippets ignored JSON
- Fixes issue where Admins could not create new
portal.conf.yaml
orrouter.conf.yaml
files from the Editor - Portal-CLI
- Fixes issue where
deploy
did not remove files remotely that had been removed locally
- Fixes issue where
Kong Manager
- Fixes issue where breadcrumbs for Routes and Services showed the
uuid
instead of the name - Fixes issue where the JWT plugin did not include
RS512
in the list of supported algorithms - Fixes issue where users with no role saw a blank page on the “Dev Portals” tab
- Fixes issue where Service Map did not show the correct line colors indicating traffic time
- Fixes issue where Service Map showed incorrect placeholder text for selecting a Workspace
- Fixes issue where viewing an RBAC user in Workspace redirected to a blank page
- Fixes issue where registration links would not generate if RBAC was disabled
- Fixes issue where resetting a password did not enforce password complexity rules
- Fixes issue where LDAP Auth would not accept CamelCase in group names
- Fixes issue where
Average Error Rate
was incorrectly displayed on the Workspace Overview - Fixes issue where schemas and validation endpoints were not scoped correctly to Workspaces, resulting in incorrectly denying users permission to certain resources. Roles that allow Create and Update on an entity must include Read permission on the schema and validation endpoints for that entity.
- Fixes formatting issue where Dev Portal URLs would overflow their containers on the Dev Portal Overview page
Plugins
- AWS Lambda
- Fixes issue where Kong Enterprise did not package the AWS Lambda plugin with IAM Role support (versions less than 3.0.1). Now Kong Enterprise packages the latest version of the plugin, 3.0.1.
- JWT
- Fixes schema issue where colons in string values were incorrectly parsed
- OpenAPI2Kong
- Fixes unsupported OAuth 2.0 security flows to handle an array instead of an object
- Fixes issue where an array was added to empty routes, this fix will improve compatibility with decK
- Fixes issue that incorrectly added
body-validation
- Request Validator
- Fixes size limitation on the number of validation rules
- MTLS Authentication
- Fixes issue where disabled
mtls-auth
plugins were not correctly ignored while creating SNIs map
- Fixes issue where disabled
1.3
Release Date: 2019/11/05
Kong Gateway
- Kong Enterprise 1.3 inherits the following changes from Kong Gateway 1.3:
Changes
Dependencies
- The required OpenResty version has been bumped to . If you are installing Kong from one of our distribution packages, you are not affected by this change. See #4382. With this new version comes a number of improvements:
- The new .
- Configurable of upstream keepalive connections by timeout or number of requests.
- Support for ARM64 architectures.
- LuaJIT GC64 mode for x86_64 architectures, raising the LuaJIT GC-managed memory limit from 2GB to 128TB and producing more predictable GC performance.
- From this version on, the new lua-kong-nginx-module Nginx module is required to be built into OpenResty for Kong to function properly. This new module allows Kong to support new features such as mutual TLS authentication. If you are installing Kong from one of our distribution packages, you are not affected by this change.
Note: if you are not using one of our distribution packages and compiling OpenResty from source, you must still apply Kong’s OpenResty patches (and, as highlighted above, compile OpenResty with the new lua-kong-nginx-module). Our new repository will allow you to do both easily.
Core
- Bug fixes in the router may, in some edge-cases, result in different Routes being matched. It was reported to us that the router behaved incorrectly in some cases when configuring wildcard Hosts and regex paths (e.g. ). It may be so that you are subject to these bugs without realizing it. Please ensure that wildcard Hosts and regex paths Routes you have configured are matching as expected before upgrading. See 9ca4dc0, , and 6a03e1b for details.
- Upstream connections are now only kept-alive for 100 requests or 60 seconds (idle) by default. Previously, upstream connections were not actively closed by Kong. This is a (non-breaking) change in behavior, inherited from Nginx 1.15, and configurable via new configuration properties (see below).
Configuration
- The
upstream_keepalive
configuration property is deprecated, and replaced by the newnginx_http_upstream_keepalive
property. Its behavior is almost identical, but the notable difference is that the latter leverages the injected Nginx directives feature added in Kong 0.14.0. In future releases, we will gradually increase support for injected Nginx directives. We have high hopes that this will remove the occasional need for custom Nginx configuration templates.
Additions
Core
- Native gRPC proxying. Two new protocol types;
grpc
andgrpcs
correspond to gRPC over h2c and gRPC over h2. They can be specified on a Route or a Service’sprotocol
attribute (e.g.protocol = grpcs
). When an incoming HTTP/2 request matches a Route with agrpc(s)
protocol, the request will be handled by the ngx_http_grpc_module, and proxied to the upstream Service according to the gRPC protocol specifications. :warning: Note that not all Kong plugins are compatible with gRPC requests yet. - Mutual TLS handshake with upstream services. The Service entity now has a new
client_certificate
attribute, which is a foreign key to a Certificate entity. If specified, Kong will use the Certificate as a client TLS cert during the upstream TLS handshake. #4800 - Route by any request header. The router now has the ability to match Routes by any request header (not only
Host
). The Route entity now has a newheaders
attribute, which is a map of headers names and values. E.g.{ "X-Forwarded-Host": ["example.org"], "Version": ["2", "3"] }
. - Least-connection load-balancing. A new
algorithm
attribute has been added to the Upstream entity. It can be set to"round-robin"
(default),"consistent-hashing"
, or"least-connections"
. #4528 - Healthchecks now use the combination of IP + Port + Hostname when storing upstream health information. Previously, only IP + Port were used. This means that different virtual hosts served behind the same IP/port will be treated differently with regards to their health status. New endpoints were added to the Admin API to manually set a Target’s health status.
Configuration
- A new section in the
kong.conf
file describes (added to Kong 0.14.0) and specifies a few default ones. In future releases, we will gradually increase support for injected Nginx directives. We have high hopes that this will remove the occasional need for custom Nginx configuration templates. #4382 - New configuration properties allow for controlling the behavior of upstream keepalive connections.
nginx_http_upstream_keepalive_requests
andnginx_http_upstream_keepalive_timeout
respectively control the maximum number of proxied requests and idle timeout of an upstream connection. - New flags have been added to the
*_listen
properties:deferred
,bind
, andreuseport
. #4692
Admin API
- Many endpoints now support more levels of nesting for ease of access. For example:
/services/:services/routes/:routes
is now a valid API endpoint. #4713 - The API now accepts
form-urlencoded
payloads with deeply nested data structures. Previously, it was only possible to send such data structures via JSON payloads.
Plugins
- jwt-auth: The new
header_names
property accepts an array of header names the JWT plugin should inspect when authenticating a request. It defaults to["Authorization"]
. - azure-functions: Bumped to 0.4 for minor fixes and performance improvements.
- : The plugin is now more resilient to Kubernetes schema changes. Note that it is now deprecated, and that Kong recommends using kuma.io instead.
- serverless-functions:
- Bumped to 0.3 for minor performance improvements.
- Functions can now have upvalues.
- : Bumped to 0.4.1 for minor performance improvements.
- cors: add OPTIONS, TRACE and CONNECT to default allowed methods #4899 Thanks to for the patch!
- upstream-tls: The Upstream TLS plugin is deprecated as of Kong Enterprise 1.3.0.0 and is only functional with Kong Enterprise versions 0.35 and 0.36. Be sure to remove this plugin before upgrading to the 1.5.x release to avoid errors or issues with your upgrade, as the plugin will no longer be supported.
PDK
- New function
kong.service.set_tls_cert_key()
. This functions sets the client TLS certificate used while handshaking with the upstream service.
Fixes
Core
- Router: Fixed a bug causing invalid matches when configuring two or more Routes with a plain
hosts
attribute shadowing another Route’s wildcardhosts
attribute. Details of the issue can be seen in 01b1cb8. - Router: Ensure regex paths always have priority over plain paths. Details of the issue can be seen in 2683b86.
- Cleanup of expired rows in PostgreSQL is now much more efficient thanks to a new query plan. #4716
- Improved various query plans against Cassandra instances by increasing the default page size.
Plugins
- cors: ensure non-preflight OPTIONS requests can be proxied. Thanks to @eshepelyuk for the patch!
- Consumer references in various plugin entities are now properly marked as required, avoiding credentials that map to no Consumer.
- hmac-auth: Correct the encoding of HTTP/1.0 requests. #4839
- oauth2: empty client_id wasn’t checked, causing a server error.
- response-transformer: preserve empty arrays correctly. #4901
CLI
- Fixed an issue when running
kong restart
and Kong was not running, causing stdout/stderr logging to turn off. #4772
Admin API
- Ensure PUT works correctly when applied to plugin configurations. #4882
PDK
- Prevent PDK calls from failing in custom content blocks. This fixes a misbehavior affecting the Prometheus plugin. #4904
- Ensure
kong.response.add_header
works in therewrite
phase.
Enterprise-Exclusives
Changes
- Kong Service Mesh is transitioned and upgraded to our next-generation service mesh offering named “Kuma”. Go to kuma.io for more information about using Kuma.
- Phone home logging now uses a new shared dict: lua_shared_dict kong_reports_workspaces 1m; If you use a custom nginx template, make sure it’s there if you use phl.
- To configure Upstream TLS, use the NGINX directives proxy_ssl_trusted_certificate, , and proxy_ssl_verify_depth instead of the Upstream TLS plugin. The plugin is only functional for versions 0.35 and 0.36.
Features
- (Alpha feature) Kong Enterprise now has a License Reports module for customers to view current usage metrics. For more information, contact your Kong Account Executive.
Kong Enterprise Gateway
gRPC support
Upstream mTLS support (API-only)
DB-export (API-only)
Routing by header
Cassandra - refresh cluster topology
RPM packages are now signed with our own GPG keys. You can download our public key at
Route validation strategy now configurable and can enforce a route pattern by configuration
OpenID Connect Library:
- Add support for ES256 signing and key generation
- Add support for ES384 signing and key generation
- Add support for ES512 signing and key generation
- Add support for PS256 signing and key generation
- Add support for PS384 signing and key generation
- Add support for PS512 signing and key generation
- Add support for EdDSA signing, key generation and verification
- Update
lua-resty-nettle
dependency to 1.0
Docker
- Improved security by allowing the CentOS and Alpine images to run as the
kong
user.
Kong Manager
RBAC User Management (manage Admin API access within Kong Manager)
Service Directory Group to Kong Role Mapping (map AD groups or other service directory systems to roles & permission sets within Kong)
Service Map
- View requests flowing through Kong
- View Immunity notifications within Service Map, click to alert section
Immunity alert management & detail section
- Filterable by entity, severity
- Links through to alerted entities
- Admin Password Strength Configuration
- Configure and enforce strong Admin passwords
- Admin Login Attempts
- Configure allowed login attempts to the Kong Manager
Dev Portal
Easy theming within Kong Manager
- Easily set your color scheme, logo/branding, and go
Developer Permissions
- Decide what specs or content different sets of developers can access.
Separation of templates and user content
- Enable content editors to make changes with no coding required
- Easier future release/upgrades path
Flat file system
- Full access to JS/assets, customers can load a single page app, or serverside rendered portal we offer out of the box
Full serverside rendering
No need to hit the API via ajax for additional information in relationship to Kong, templating data object allows access to Kong data directly at load
Enables more extensive caching of pages/assets
Declarative configuration out of the box
Allows for more UI integrations
Conf files allow for source controlled configuration of your dev portal, including
Routing
Auth config
Permissions
Theming (colors, logos, meta info)
Developer Password Strength Configuration
- Configure and enforce strong Developer passwords
- Developer Login Attempts
- Configure allowed login attempts to the Developer Portal
Plugins
gRPC support, API & Kong Manager
Upstream mTLS support
DB export, API-only
Routing by header
Request Size Limiting - enhanced units on size limit
- Request Transformer Advanced - Support for filtering JSON body with new configuration
config.whitelist.body
- Response Transformer Advanced:
- Support for filtering JSON body with new configuration config.whitelist.body, Support arbitrary transformations via Lua functions
- Fixes a bug where the plugin was returning an empty body in the response for status codes outside of those specified in
config.replace.if_status
. For example, if we specified aconfig.replace.if_status=404
and a bodyconfig.replace.body=test
and the status code was 200, the response would be empty.
- Route Transformer Advanced - New
- GraphQL Proxy Cache Advanced - New
- GraphQL Rate Limiting Advanced - New
- Degraphql - New
- Exit Transformer - New
- Kafka Log - New
- Kafka Upstream - New
- mTLS Auth:
- Update cert request logic ask client cert when:
- To every route irrespective of workspace when plugin enabled in global scope
- To every route irrespective of workspace when plugin applied at service level but not all its routes have SNIs set
- To every route irrespective of workspace when plugin applied at route level but SNIs not set on route
- To specific route only when plugin applied at route level and it has SNIs set
- skip_consumer_lookup config to skip consumer lookup if request has trusted client certificate.
- authenticated_group_by config to block/allow validated certificate using ACL plugin
- Update cert request logic ask client cert when:
- Key-Auth keys now support a ttl property and can expire
- AWS Lambda plugin supports IAM roles
- Session plugin can now store authenticated groups from other authentication plugins.
CLI
- Adds runner
Fixes
Plugins
OpenID Connect
- Fixes issue when discovery did not return issuer information (against OpenID Connect specification), and which could lead to 500 error on 401 and 403 responses.
LDAP Auth Advanced
- LDAP Auth Advanced - fixed issue where plugin tries to start a secure connection on an existing pooled connection from previous requests
Request Transformer Advanced
- Fixes a bug where the plugin was returning an empty body in the response for status codes outside of those specified in
config.replace.if_status
. For example, if we specified aconfig.replace.if_status=404
and a bodyconfig.replace.body=test
and the status code was 200, the response would be empty.
Kong Enterprise Gateway
- Fixes: audit log entries did not include timestamps indicating when the event occurred.
- Fixes: allow put requests to nonexistent foreign entities.
- Fixes: granular tracing did not work when certain plugins (for example, the key-auth) were used.
Docker
- Fixes: centos and alpine images did not work on some OpenShift setups with relaxed anyuid SCC settings.
0.36-7
Release Date 2020/11/20
Fixes
OpenID Connect Library
- Changed to disable HS-signature verification by default.
- Changed to use
client_secret
as a fallback secret for HS-signature verification only when it is a string and has more than one character in it. - Fixes vulnerability in the OpenID Connect and JWT Signer Plugins. Login to the for OIDC advisory and details.
0.36-6
Release Date: 2020-06-18
Fixes
- Fixes Kong PDK
get_method()
function to return a correct HTTP method when there are connectivity issues with the Upstream. - Reverted Service Mesh changes which affect
proxy_ssl_*
directives.
0.36-5
Release Date: 2020-04-02
Fixes
- Fixes an issue with jwt-signer plugin that requires only lua-resty-nettle update.
0.36-4
Release Date: 2019/12/12
Fixes
migrate-community-to-enterprise
script changed from batch query execution to multiple single queries for Cassandra strategy.- Fixes Workspace counters calculation logic when you run
migrate-community-to-enterprise
script. - Fixes DAO fetching functionality to fetch all requested records from the database instead of first
1000
records that was before. - Updated Nettle version from
3.4.1
to3.5.1
which is required by the plugins that useOIDC
library to work properly. - Fixes an issue where enabling tracing and setting a tracing header caused all HTTPS requests to fail immediately when attempting to fetch headers during the ssl_cert phase.
0.36-3
Release Date: 2019/11/18
Features
- Adds an endpoint
/entities/migrate
for migrating entities from Community Edition to Enterprise Edition.
Plugins
kong-openid-connect
- Add support for ES256 signing and key generation
- Add support for ES384 signing and key generation
- Add support for ES512 signing and key generation
- Add support for PS256 signing and key generation
- Add support for PS384 signing and key generation
- Add support for PS512 signing and key generation
- Add support for EdDSA signing, key generation and verification
- Update lua-resty-nettle dependency to 1.0
- Change verification JWT header’s typ claim by adding support for at+jwt that for example IdentityServer4 is using by default.
- Change issuer verification bit more permissive (e.g. the difference in ending slash (present or absent) does not make the verification to fail)
Fixes
- Fixes router proxy path issues.
0.36-2
Notifications
- Kong Enterprise 0.36 inherits from Kong 1.2.1 with some exceptions:
- Declarative Configuration and DB-less mode of Kong Gateway is designed for limited scenarios that do not allow for the Kong Enterprise to function as-is. As such the mode is not available in Kong Enterprise today.
Release Date: 2019/8/30
Features
Dev Portal
- Adds
custom_id
field to developers to allow easier mapping
Plugins
- Request-transformer
- Allows rendering values from kong.ctx.shared
Fixes
Plugins
- Rate Limiting Advanced
- Fixes an issue where user failed to import Rate Limiting Advanced declarative YAML file via
kong config db_import
- Fixes an issue where user failed to import Rate Limiting Advanced declarative YAML file via
Core
- Workspaces
- Fixes an issue where user can rename a workspace with
PUT
request
- Fixes an issue where user can rename a workspace with
- Migrations
- Fixes an issue where migration from 0.35-x to 0.36-x making plugin
protocols
field mandatory duringPATCH
request. - Fixes an issue where unique fields of entities are not migrated properly when migrating from Kong CE to EE using CLI
kong migrations migrate-community-to-enterprise
- Fixes an issue where migration from 0.35-x to 0.36-x making plugin
- Vitals
- Fixes an issue where Kong fails to remove old stats table when they are not part of public schema
0.36-1
Notifications
- Kong Enterprise 0.36 inherits from Kong 1.2.1 with some exceptions:
- Declarative Configuration and DB-less mode of Kong Gateway is designed for limited scenarios that do not allow for the Kong Enterprise to function as-is. As such the mode is not available in Kong Enterprise today.
Release Date: 2019/8/19
Fixes
- Fixes NGINX CVEs:
- Fixes issue in which Enterprise will not start if configured with a stream listen directive
- Fixes issue in which LuaPath is not correctly configured and prevents use of Luarocks
0.36
Notifications
- Kong Enterprise 0.36 inherits from Kong 1.2.1 with some exceptions:
- Declarative Configuration and DB-less mode of Kong Gateway is designed for limited scenarios that do not allow for the Kong Enterprise to function as-is. As such the mode is not available in Kong Enterprise today.
Release Date: 2019/8/5
Features
Core
- Support for wildcard SNI matching: the
ssl_certificate_by_lua
phase and the streampreread
phase) is now able to match a client hello SNI against any registered wildcard SNI. This is particularly helpful for deployments serving a certificate for multiple subdomains. - HTTPS Routes can now be matched by SNI: the
snis
Route attribute (previously only available fortls
Routes) can now be set forhttps
Routes and is evaluated by the HTTP router. - Native support for HTTPS redirects: Routes have a new
https_redirect_status_code
attribute specifying the status code to send back to the client if a plain text request was sent to anhttps
Route. - Schema fields can now be marked as immutable.
- Support for loading custom DAO strategies from plugins.
- Support for IPv6 to
tcp
andtls
Routes. - Transparent proxying - the
service
attribute on Routes is now optional; a Route without an assigned Service will proxy transparently - Support for tags in entities
- Every core entity now adds a
tags
field
- Every core entity now adds a
- New
protocols
field in the Plugin entity, allowing plugin instances to be set for specific protocols only (http
,https
,tcp
ortls
).- It filters out plugins during execution according to their
protocols
field - It throws an error when trying to associate a Plugin to a Route which is not compatible, protocols-wise, or to a Service with no compatible routes.
- It filters out plugins during execution according to their
Configuration
- Asynchronous router updates: a new configuration property
router_consistency
accepts two possible values:strict
andeventual
. The former is the default setting and makes router rebuilds highly consistent between Nginx workers. It can result in long tail latency if frequent Routes and Services updates are expected. The latter helps preventing long tail latency issues by instructing Kong to rebuild the router asynchronously (with eventual consistency between Nginx workers). - Database cache warmup: Kong can now preload entities during its initialization. A new configuration property (
db_cache_warmup_entities
) was introduced, allowing users to specify which entities should be preloaded. DB cache warmup allows for ahead-of-time DNS resolution for Services with a hostname. This feature reduces first requests latency, improving the overall P99 latency tail. - Improved PostgreSQL connection management: two new configuration properties have been added:
pg_max_concurrent_queries
sets the maximum number of concurrent queries to the database, andpg_semaphore_timeout
allows for tuning the timeout when acquiring access to a database connection. The default behavior remains the same, with no concurrency limitation. - New option in
kong.conf
:pg_schema
to specify PostgreSQL schema to be used - The Stream subsystem now supports Nginx directive injections
nginx_stream_*
(orKONG_NGINX_STREAM_*
environment variables) for injecting entries to thestream
blocknginx_sproxy_*
(orKONG_NGINX_SPROXY_*
environment variables) for injecting entries to theserver
block insidestream
Admin API
- Add a schema validation endpoint for entities: a new endpoint
/schemas/:entity_name/validate
can be used to validate an instance of any entity type in Kong without creating the entity itself. - Add memory statistics to the
/status
endpoint. The response now includes amemory
field, which contains thelua_shared_dicts
andworkers_lua_vms
fields with statistics on shared dictionaries and workers Lua VM memory usage.- When using the new
database=off
configuration option, the Admin API endpoints for entities (such as/routes
and/services
) are read-only, since the configuration can only be updated via/config
- When using the new
- Admin API endpoints now support searching by tag (for example,
/consumers?tags=example_tag
)- You can search by multiple tags:
/services?tags=serv1,mobile
to search for services matching tagsserv1
andmobile
/services?tags=serv1/serv2
to search for services matching tagsserv1
orserv2
- You can search by multiple tags:
- New Admin API endpoint
/tags/
for listing entities by tag:/tags/example_tag
PDK
- New function
kong.node.get_memory_stats()
. This function returns statistics on shared dictionaries and workers Lua VM memory usage, and powers the memory statistics newly exposed by the/status
endpoint. - New PDK function:
kong.client.get_protocol
for obtaining the protocol in use during the current request - New PDK function:
kong.nginx.get_subsystem
, so plugins can detect whether they are running on the HTTP or Stream subsystem
Plugins
- Logging plugins: log request TLS version, cipher, and verification status.
- Plugin development: inheriting from
BasePlugin
is now optional. Avoiding the inheritance paradigm improves plugins’ performance. - Support for ACL authenticated groups, so that authentication plugins that use a 3rd party (other than Kong) to store credentials can benefit from using a central ACL plugin to do authorization for them.
- The Kubernetes Sidecar Injection plugin is now bundled into Kong for a smoother K8s experience.
- AWS Lambda now includes the AWS China region.
CLI
- Bulk database import using the same declarative configuration format as the in-memory mode, using the new command:
kong config db_import kong.yml
. This command upserts all entities specified in the givenkong.yml
file in bulk.- Known issue for db_import/db_export in Kong Enterprise
db_import
supports all API Gateway entities, with the exception of Admins and RBAC users and roles. This limitation is because credentials are hashed.db_export
is not supported at all.
- Known issue for db_import/db_export in Kong Enterprise
- New command:
kong config init
to generate a templatekong.yml
file to get you started - New command:
kong config parse kong.yml
to verify the syntax of thekong.yml
file before using it - New option
--wait
inkong quit
to ease graceful termination when using orchestration tools.
Fixes
Core
- Resolve hostnames properly during initialization of Cassandra contact points
- Fix health checks for Targets that need two-level DNS resolution (e.g. SRV → A → IP)
- Fix serialization of map types in the Cassandra backend
- Fix target cleanup and cascade-delete for Targets
- Avoid crash when failing to obtain list of Upstreams
- Disallow invalid timeout value of 0ms for attributes in Services
- DAO fix for foreign fields used as primary keys
- Cassandra: ensures serial consistency is
LOCAL_SERIAL
when a datacenter-aware load balancing policy is in use. This fixes unavailability exceptions sometimes experienced when connecting to a multi-datacenter cluster with cross-datacenter connectivity issues. - Schemas: fixes an issue in the schema validator that would not allow specifying
false
in some schema rules, such a{ type = "boolean", eq = false }
. - Fixes an underlying issue with regards to database entities cache keys generation.
- Ensure the migration path for Cassandra does not corrupt the database schema.
- Allow the
kong config init
command to run without a pointing to a prefix directory. - Adds support for , which allows Kong to pre-load all necessary entries into Kong nodes’ memory on start.
- Provides support in declarative configuration for Workspaces and RBAC.
- Provides support for the Redis Cluster library.
- Active healthchecks:
http
checks are not performed fortcp
andtls
Services anymore; onlytcp
healthchecks are performed against such Services. - Fix an issue where updates in migrations would not correctly populate default values.
- Improvements in the reentrancy of Cassandra migrations.
- Fix an issue causing the PostgreSQL strategy to not bootstrap the schema when using a PostgreSQL account with limited permissions.
- Address issue where field type “record” nested values reset on update
- Correctly manage primary keys of type “foreign”
Admin API
- Proper support for
PUT /{entities}/{entity}/plugins/{plugin}
- Fix Admin API inferencing of map types using form-encoded
- Accept UUID-like values in
/consumers?custom_id=
Dev Portal
- Adds per workspace Session Config. The Dev Portal will now allow session configuration for every portal-per-workspace instance.
- Adds email verification. Developers will be sent a verification link after requesting access to a Dev Portal.
Plugins
- Request Validator
- Adds support for JSON Schema Draft 4
- Adds support for parameter validation
- Adds the option to override validation for specific content types
- OAuth2 Introspection
- Can now find and load consumers by
username
andcustom_id
. OAuth2username
maps to Consumer’susername
, while theclient_id
maps to a Consumer’scustom_id
- New
consumer_by
configuration allows users to customize whether Consumers are fetched byclient_id
orusername
(returned by the introspection request) - New
introspect_request
configuration that causes the plugin to send information about the current request as headers in the introspection endpoint request. Currently, the request path and HTTP methods are sent asX-Request-Path
andX-Request-Http-Method
headers - New
custom_introspection_headers
configuration list of user-supplied headers to be sent in the introspection endpoint request - New
custom_claims_forward
configuration list of additional claims. The introspection endpoint request will return this list to forward as headers to the upstream service request.
- Can now find and load consumers by
- basic-auth, ldap-auth, key-auth, jwt, hmac-auth: fixed status code for unauthorized requests: they now return HTTP 401 instead of 403
- tcp-log: remove spurious trailing carriage return
- jwt: fix
typ
handling for supporting JOSE (JSON Object Signature and Validation) - Fixes to the best-effort auto-converter for legacy plugin schemas
- Ensures the
cassandra_local_datacenter
configuration property is specified when a datacenter-aware Cassandra load balancing policy is in use. - request-transformer: fixes an issue that would prevent adding a body to requests without one.
- kubernetes-sidecar-injector: fixes an issue causing mutating webhook calls to fail.
- basic-auth: ignore password if nil on basic auth credential patch
- http-log: Simplify queueing mechanism. Fixed a bug where traces were lost in some cases.
- request-transformer: validate header values in plugin configuration.
- rate-limiting: added index on rate-limiting metrics.
- Upstream-tls
- Fixes an issue where bundled certificates in PEM format were not loaded into the certificate store correctly.
- ldap-auth: ensure TLS connections are reused.
- oauth2: ensured access tokens preserve their
token_expiration
value when migrating from previous Kong versions.
Workspaces
- Fixes permission bug where an Admin with
workspace-super-admin
Role was not able to access the Workspace that the Role was assigned to.
Upstreams
- Fixes an issue where it was not possible to delete an Upstream object if it had no associated Target.
Kong Manager
- Fixes a bug where Kong Manager could only display 100 Workspaces.
- Fixes a bug where a Route’s details would not include a link to a Service that did not have a name.
Dev Portal
- Fixes a bug in the sign-up meta fields that caused data to disappear when a Developer is updated.
- Fixes an issue where clicking on a Developer after clicking the credentials section ACL causes a 500 error.
CLI
- Fix
kong db_import
to support inserting entities without specifying a UUID for their primary key. Entities with a unique identifier (e.g.name
for Services) can have their primary key omitted. - The
kong migrations [up|finish] -f
commands does not run anymore if there are no previously executed migrations.
Changes
- Brain
- Renames Brain to Collector
0.35-5
Release Date: 2020/05/14
Fixes
- Reverted breaking changes introduced by involving the handling of slashes inside the router.
- Reverted service mesh changes affecting
proxy_ssl_*
directives.
0.35-4
Release Date: 2019/08/19
Notifications
- Kong Enterprise 0.35-3 inherits from Kong 1.0.3; read the Kong Changelog for details.
Fixes
- Fixes for NGINX CVEs resolving security vulnerabilities in the HTTP/2 protocol which may cause excessive memory consumption and CPU usage: CVE-2018-16843, , CVE-2019-9511, , and CVE-2019-9516
0.35-3
Release Date: 2019/07/17
Notifications
- Kong Enterprise 0.35-3 inherits from Kong 1.0.3; read the for details.
Features
Core
- New CLI migrations command
migrate-apis
to convert all existing API objects to Services and Routes - New CLI migrations command
migrate-community-to-enterprise
for moving Core entities to Enterprise entities - Support for Redis Cluster as a backend for
rate-limiting-advanced
andproxy-cache
plugins - Cache-warming configuration to load specified entities at startup to improve first request latency
Kong Manager
- New page to reset RBAC token and manage user password
Plugins
upstream-tls
- allows verification of upstream certificates, custom CA certificates, and verification depth
Fixes
Core
- Correctly count
workspace_entities
when moving from previous versions
Dev Portal
- Dev Portal Docs now point to 0.35
- Unauthenticated Spec rendering is fixed
Plugins
jwt-signer
- Fix IMPORTANT! verify expiry and scopes checks on JWT tokens
- Fix finding Consumer by custom ID
- Fix runtime error on unexpected function,
kong.log.error
->kong.log.err
- Change invalidation to happen locally, not cluster wide, each node invalidates on their own
openid-connect
- Change invalidations to local invalidation instead of cluster-wide invalidation
- Fix Admin API to properly call the cleanup function on entity endpoint
- Fix
hide_credentials
not clearing X-Access-Token header - Change debug logging to not log about disabled authentication methods
- Change TTL code and fix some edge cases
0.35-1
Release Date: 2019/05/28
Notifications
- Kong Enterprise 0.35-1 inherits from Kong 1.0.3; read the Kong Changelog for details.
Features
Plugins
- Allow Redis strategy configuration for Rate Limiting Advanced
Fixes
Kong Manager
- If a Kong Manager Super Admin was already created, setting
KONG_PASSWORD
duringmigrations up
to 0.35 would error. Running migrations when Super Admin already exists andKONG_PASSWORD
environment variable is set is fixed.
Dev Portal
- Fixes Dev Portal documentation not showing after upgrading to 0.35
- Fixes Dev Portal OAPI spec rendering of long request URL wrapping
Plugins
rate-limiting-advanced
schema validation rules prevented use of Redis Sentinel (config.strategy=redis
andconfig.redis.sentinel_addresses
) for counters data store. Validation rule is fixed.
Core
- Upgrade from 0.34-1 to 0.35 using Cassandra no longer creates duplicate Workspace.
- Migrations from 0.34-1to 0.35 did not properly handle Certificates and SNIs in context of Workspaces. Migrating from 0.34-1 with this fix does not support zero downtime in this release. To get a fully functional 0.35 instance with Certificates, you must run
migrations finish
. Proper creation of Workspace links for Certificates and SNIs is fixed. - Cassandra
read before write
pattern did not correctly use schema defaults and preventedPATCH
of the Plugins entity. Usage of schema default values in Cassandraread before write
pattern is fixed. plugins.run_on default
now correctly set on migrations upgrade.
0.35
Release Date: 2019/05/17
Notifications
- Kong Enterprise 0.35 inherits from Kong 1.0.3; read the Kong Changelog for details.
Changes
Admin API
- RBAC: Following Kong 1.0’s changes, referenced (
foreign_key
) entities like RBAC Users and RBAC Roles are returned as nested JSON tables instead of flattenedrole_id
oruser_id
fields in top-level entity. user_token
must now be provided when creating a new RBAC user (in a POST request torbac/users
) and is no longer auto-generated if left blank
Core
- New RBAC user tokens are not stored in plaintext. If upgrading to this version, any existing tokens will remain in plaintext until either a) the token is used in an Admin API call or b) the
rbac_user
record is PATCHed even if the PATCH request includes the existing value ofuser_token
).
Features
Kong Manager
- User information is no longer stored in local storage. A user exchanges credentials for a session. See the Session Plugin for details.
- Enable and view Plugins in context of a Service and Route
- Type-ahead service name/ID search on routes form
- Easily scan/copy IDs in service table
- Contextual help and error messages for forms
- Adds page breadcrumbs
- In-context documentation links
- Global navigation links to documentation and Support Portal
- Improved Info tab for cluster & config info
- Detailed debug tracing can be enabled which outputs information about various portions of the request lifecycle, such as DB or DNS queries, plugin execution, core handler timing, etc
Dev Portal
- Dev Portal files now rendered server-side for increased performance.
- Developers can now sign up to multiple Workspaces with the same email address.
- Dev Portal is disabled for each Workspace by default.
- Default theme shipped with Kong Enterprise now supports IE11.
- User information is no longer stored in local storage. A user exchanges credentials for a session. See the Session Plugin for details.
- Dev Portal page, partial, and specification look-ups moved to server-side.
- Added support for OAS3 body parameters.
- Added CORS header configuration option to workspace portal configuration object to allow explicit CORS configuration.
- Added a live editor built on VSCode core for improved customization of Dev Portal within Kong Manager
- Added custom registration fields support and custom registration field interface.
- Added methods to links in the sidebar on documentation in the default portal theme.
- Added hover states to drop-downs in the sidebar of documentation in the default portal theme.
- Added a right border to the sidebar in the default portal theme.
- Changed
full Name
registration field to be a custom registration field, and can be managed through the custom fields interface in Kong Manager. - Changed custom checkbox to native checkbox in the default Dev Portal theme on the dashboard.
Plugins
- Response Transformer Advanced (NEW):
- Conditional transformations on response status through the new flag if_status, a subfield in all transformations (e.g.,
add.if_status
,remove.if_status
); the transformation only happens if the response code matches one of the codes in theif_status field
- Full-body replacement through the new config.replace.body
- Added a support of status code ranges for
if_status
configuration parameter. Now you can provide status code ranges and single status codes together (e.g.,201-204,401
)
- Conditional transformations on response status through the new flag if_status, a subfield in all transformations (e.g.,
- Request Validator (NEW):
- Validate the request body against a schema; if the payload is not valid JSON or if it doesn’t conform to the schema, the plugin returns a 400 Bad Request response before the request reaches upstream. This version of the plugin does not support JSON Schema; it uses Kong’s schema format
- Canary:
- Healthchecks: new configuration upstream_fallback allows the plugin to skip applying the canary upstream if it’s not healthy. Note: it only works if the host specified in upstream_host points to a Kong upstream, and if that upstream has healthchecks enabled on it)
- Oauth2 Introspection:
- Set Id to Rate limiting may detect calls to introspection endpoint
- Set credential id to allow rate limiting based on access token
- The Kong Session Plugin:
- The Kong Session Plugin adds session support for Kong Manager and Dev Portal. Sessions can be stored via cookie or database. See the accompanying documentation for how to configure the plugin for use with Kong Manager.
- Vault-Auth:
- Authenticate requests via Vault. See Vault Auth for details.
- OpenID Connect:
- Update
lua-resty-http
to>= 0.13
- Update
lua-resty-session
to2.23
- Add
config.authorization_endpoint
- Add
config.token_endpoint
- Add
config.response_type
- Add
config.token_post_args_client
- Add
config.token_headers_names
- Add
config.token_headers_values
- Add
config.introspection_post_args_names
- Add
config.introspection_post_args_values
- Add
config.instrospection_post_args_client
- Add
config.session_secret
- Add
config.session_cookie_renew
- Add
config.ignore_signature
- Add
config.cache_ttl_max
- Add
config.cache_ttl_min
- Add
config.cache_ttl_neg
- Add
config.cache_ttl_resurrect
- Add
config.upstream_session_id_header
- Add
config.downstream_session_id_header
- Add
tokens
option toconfig.login_tokens
to return full token endpoint results withresponse
orredirect
specified inconfig.login_action
- Add
introspection
option toconfig.login_tokens
to return introspection results withresponse
orredirect
specified inconfig.login_action
- Change Kong 1.0 support
- Change Refresh-token headers can now have
Bearer
in front of the token. - Change to forbid only unapproved developers
- Change
config.scopes_claim
is also searched in introspected jwt token results - Change
config.audience_claim
is also searched in introspected jwt token results - Change
config.consumer_claim
is also searched in introspected jwt token results - Change
config.consumer_claim
is also searched with user info whenconfig.search_user_info
is enabled - Change
config.credential_claim
is searched fromid token
as well - Change
config.credential_claim
is also searched in introspected jwt token results - Change
config.credential_claim
is also searched with user info whenconfig.search_user_info
is enabled - Change
config.authenticated_groups_claim
is searched fromid token
as well - Change
config.authenticated_groups_claim
is also searched with user info whenconfig.search_user_info
is enabled - Change
config.upstream_headers_claims
andconfig.downstream_headers_claims
are now searched from introspection results, jwt access token and id token, and user info whenconfig.search_user_info
is enabled - Change
id_token
is not anymore copied over when refreshing tokens to prevent further claims verification errors. The token endpoint can return a new id token, or user info can be used instead. - Change hide
secret
from admin api - Change
config.issuer
to semi-optional (you still need to specify it but code won’t error if http request to issuer fails) - Change more reentrant migrations
- Change issuer to be optional
- Change signature verification to look suitable key by algorithm as well in case where key identifier is missing or cannot be found
- Remove developer status/type check from plugin
- Remove
daos
that were never used - Remove all the sub-plugins (openid-connect-verification, openid-connect-authentication, and openid-connect-protection)
- Fix issue with Kong OAuth 2.0 and OpenID Connect sharing incompatible values with same cache key
- Update
- Forward Proxy:
- Fix an issue preventing the plugin from working with requests using chunked TE
- LDAP Auth Advanced:
- Added LDAPS protocol support
- Added tests for multiple connection strategies
- Fixed an issue where plugin tries to start a secure connection on an existing pooled connection from previous requests
StatsD Advanced
Added filter by status code functionality for responses to be logged. Admins can add status code ranges for responses which want to be logged and sent to StatsD server. If Admin doesn’t provide any status code, all responses will be logged.
Security
Set security headers in Kong Manager and Dev Portal
- Guard against frame misuse in Kong Manager and Dev Portal
Fixes
Kong Manager
- Clear option for turning off New Relic data collection
- Keyword search bug fixed in Kong Manager
- Info tab of Kong Manager no longer empty (shows license information)
- Custom Plugins viewable within plugin groupings
- Error messages on Workspace form don’t remain longer than intended
- Column overflow issue in services table in Kong Manager fixed
- New Routes were accidentally accepting strings for
regex_priority
when submitting a new Routes, fixed as part of Kong 1.0 merge - Fixes CORS breaking when configuring
KONG_ADMIN_API_URI
with a port. - Fixes issue in Kong Manager where Dev Portal pages would display the wrong content when disabled from
kong.conf
. - Fixes issue in Kong Manager where email validation would accept invalid inputs.
Dev Portal
- Fixes issue in Dev Portal where email validation would accept invalid inputs.
- Fixes Dev Portal “Forgot Email” template URL pointing to the wrong location.
- Fixes CORS error shown when loading content if Dev Portal is improperly configured.
- Fixes default spec renderer improperly rendering request bodies.
- Fixes issues in the portal theme preventing loading in Internet Explorer
- Fixes long titles overflowing and stretching the sidebar in the default portal theme.
- Fixes sidebar drop-down arrow not rotating in default portal theme.
- Fixes sidebar overlapping main body content in default portal theme.
- Fixes main body content overflowing container in default portal theme.
- Fixes issue in the default portal theme where transitioning from the mobile to full-screen would retain the sidebar overlay.
- Fixes issue in the default portal theme where links on documentation would not navigate due to spaces.
- Fixes issue in the default portal theme where on logout a user would be redirected to the default workspace portal.
- Fixes issue in the portal theme sync script where environment flags were not properly evaluated as booleans.
- Fixes issue in the portal theme sync script where relative links would add the theme name to files inserted on a workspace.
0.34-1
Release Date: 2018/12/19
Notifications
- Kong EE 0.34 inherits from Kong CE 0.13.1; make sure to read 0.13.1 - and 0.13.0 - changelogs:
- Kong EE 0.34 has these notices from Kong CE 0.13:
- Support for PostgreSQL 9.4 has been removed - starting with 0.32, Kong Enterprise does not start with PostgreSQL 9.4 or prior
- Support for Cassandra 2.1 has been deprecated, but Kong will still start - versions beyond 0.33 will not start with Cassandra 2.1 or prior
- Dev Portal requires Cassandra 3.0+
- Galileo - DEPRECATED: Galileo plugin is deprecated and will reach EOL soon
Changes
- Kong Manager
- Email addresses are stored in lower-case. These addresses must be case-insensitively unique. In previous versions, you could store mixed case email addresses. A migration for PostgreSQL converts all existing email addresses to lower case. Cassandra users should review the email address of their admins and developers and update them to lower-case if necessary. Use the Kong Manager or the Admin API to make these updates.
- Plugins
- Forward Proxy
- Do not do a DNS request to the original upstream that would be discarded anyway as proxy will manage the resolving of the configured host.
- OpenID Connect
- Remove obsolete daos (adds migration)
- Hide secret from Admin API (used with sessions)
- Bump lua-resty-session to 2.23
- Change token verification to check token types when requested
- Forward Proxy
Features
- Dev Portal
- repository:
- A public repository containing dev portal themes, examples, and dev tools for working with the Dev Portal template files.
- sync.js:
- Script which allows dev portal developers to
push
,pull
, andwatch
the most up to date template files to and from kong to their local machine.
- Script which allows dev portal developers to
- default portal theme:
- Directory containing the most up to date version of the default portal template files that ship with Kong EE each release.
- Bug fixes, updates, and template features will be pushed here regularly and independently of the EE release cycle.
- Dev Portal now caches static JS assets
- repository:
- Plugins
- OpenID Connect
- add
config.http_proxy_authorization
(note: this is not yet in upstream lua-resty-http) - add
config.https_proxy_authorization
(note: this is not yet in upstream lua-resty-http) - add
config.no_proxy
- add
config.logout_revoke_access_token
- add
config.logout_revoke_refresh_token
- add
config.refresh_token_param_name
- add
config.refresh_token_param_type
- add
config.refresh_tokens
- add
- OpenID Connect
- CORE
- License
- Added an increasingly “loud” logging to notify via nginx logs as the expiration date approaches.
- 90 days before the expiration date: Daily WARN log
- 30 days before the expiration date: Daily ERR log
- After the expiration date: Daily CRIT log
- Added an increasingly “loud” logging to notify via nginx logs as the expiration date approaches.
- DB
- Cassandra
- Support request-aware load-balancing policies in conf & DAOs.
cassandra_lb_policy
now supports two new policies RequestRoundRobin and RequestDCAwareRoundRobin.
- Support request-aware load-balancing policies in conf & DAOs.
- Cassandra
- License
Fixes
- Admin API
- Prevent creating or modifying developers and admins through the /consumers endpoints
- Prevent creating or modifying consumers through the /admins endpoints
- Fix error on /admins when trying to create an admin with the same name as an existing RBAC user
- Roll back if a POST to /admins fails
- Dev Portal
- KONG_PORTAL_AUTH_CONF parameter values can now handle escaped characters such as #
- ACL plugin credential management no longer accessible from Dev Portal client
- “Return to login” CTA on the password-reset page now redirects to appropriate workspace
- Improved support for OAS 3 specifications
- General SwaggerUI improvements
- Developer approval email will only send once (on first approval). A developer will not receive an additional email if they are revoked and re-approved.
- Kong Manager
- When creating a new workspace, always create roles for that workspace
- List workspace roles in alphabetical order
- Provide a button on the Admin show page to generate a registration URL
- Fix misleading error message when adding an existing user to a new workspace
- Add validation of image type when creating a workspace with an avatar
- Add configuration fields and icon for the JWT signer plugin
- Clean up console errors due to lack of permissions
- Make the UTC button on Vitals charts work in Firefox
- Change the display order of plugins to match the Plugin Hub
- CORE
- Workspaces
- When removing an entity from a workspace, delete the entity itself if it only belongs to that workspace.
- Developers nor admins do not affect consumer counters in workspaces. Only proxy consumers do.
- DB
- Cassandra
- Fix an issue where Insert operation fails to return an entity as not all Cassandra nodes are synced yet while reading the data.
- Now Kong will make one try to fetch the inserted row before throwing error. (Fix: )
- Cassandra
- Workspaces
- Plugins
- Rate-limiting
- Use database-based redis connection pool to reduce unnecessary select call
- Response-ratelimiting
- Use database-based redis connection pool to reduce unnecessary select call
- OpenID Connect
- Fix schema
self_check
to verify issuer only when given (e.g. when usingPATCH
to update configuration)
- Fix schema
- Rate-limiting
0.34
Release Date: 2018/11/17
Notifications
- Kong EE 0.34 inherits from Kong CE 0.13.1; make sure to read 0.13.1 - and 0.13.0 - changelogs:
- Kong EE 0.34 has these notices from Kong CE 0.13:
- Support for PostgreSQL 9.4 has been removed - starting with 0.32, Kong Enterprise does not start with PostgreSQL 9.4 or prior
- Support for Cassandra 2.1 has been deprecated, but Kong will still start - versions beyond 0.33 will not start with Cassandra 2.1 or prior
- Dev Portal requires Cassandra 3.0+
- Galileo - DEPRECATED: Galileo plugin is deprecated and will reach EOL soon
- Kong Manager
- The name of the
Admin GUI
has changed toKong Manager
- The name of the
- Licensing
- License expiration logs: Kong will start logging the license expiration date once a day - with a
WARN
log - 90 days before the expiry; 30 days before, the log severity increases toERR
and, after expiration, toCRIT
- License expiration logs: Kong will start logging the license expiration date once a day - with a
Changes
- Admin API
- The system-generated
default
role for an RBAC user is no longer accessible via the Admin API - Auto-config OAPI endpoint available for Admin API (configure services & routes via Swagger)
- The system-generated
- Workspaces
- Workspaces on Workspaces has been disabled, meaning that workspaces do not apply on
/workspaces/
endpoints - Renaming workspaces is no longer allowed
- Workspaces on Workspaces has been disabled, meaning that workspaces do not apply on
- Vitals
- Now enabled by default when starting Kong for the first time
- Dev Portal
- Breaking change - change of config options
portal_gui_url
is removed, andprotocol
,host
, andportal_gui_use_subdomains
addedprotocol
andhost
replaceportal_gui_url
portal_gui_use_subdomains
avoids conflicts if base path name matches workspace name
Plugins
- Prometheus
- Warning - Dropped metrics that were aggregated across services in Kong. These metrics can be obtained much more efficiently using queries in Prometheus.
- Zipkin
- Add kong.node.id tag
- Proxy Cache
- Add
application/json
to configcontent-type
- Add
- All logging plugins
- Workspace of the request is logged
- StatsD Advanced
- Add workspace support with new metrics
status_count_per_workspace
- Add workspace support with new metrics
OpenID Connect
- NOTE - If using an older version of the OpenID Connect plugin, with sub-plugins, Kong will not start after upgrading to 0.34. Sub-plugins are now disabled by default will be removed completely in subsequent releases. To make sure Kong starts, enable OIDC sub-plugins manually, with the custom_plugins configuration directive - or through the
KONG_CUSTOM_PLUGINS
environment variable; for example:
Set the following in the kong.conf file:
Or the following environment variable:
KONG_CUSTOM_PLUGINS=openid-connect-verification,openid-connect-authentication,openid-connect-protection
The all-in-one version of OIDC is enabled by default (and is not deprecated).
- Always log the original error message when authorization code flow verification fails
- Optimize usage of ngx.ctx by loading it once and then passing it to functions
- Breaking change - Change config.ssl_verify default to false.
- NOTE - If using an older version of the OpenID Connect plugin, with sub-plugins, Kong will not start after upgrading to 0.34. Sub-plugins are now disabled by default will be removed completely in subsequent releases. To make sure Kong starts, enable OIDC sub-plugins manually, with the custom_plugins configuration directive - or through the
- Prometheus
Features
- Dev Portal
- Filterable API list
- Improved portal management in Kong Manager
- Overview page with quick links to portal, create pages
- Split out pages, specs, partials for ease of navigation
- SMTP support and admin/access request workflow improvements
- Global search
- Option for one dev portal per workspace, and option to enable within Kong Manager
- Improved OAS 3.0 support
- Markdown support
- Kong Manager
- Workspaces are now configurable in Kong Manager
- Creation, management of workspaces for super admin
- RBAC assignment globally for super admin
- Vitals is workspace-aware
- Support for inviting additional users
- Self-service credential management
- General UI cleanup (tables, modals, forms, notifications)
- New menu/navigation system
- Workspaces are now configurable in Kong Manager
- Vitals
- Functionality to support storing Vitals data in Prometheus (via the StatsD Advanced plugin)
- InfluxDB support for Vitals
- Plugins
- HTTPS support for Forward Proxy plugin
- Route by header added to the package - docs can be found here
- JWT Signer added to the package - docs can be found
- OpenID Connect
- Add
config.unauthorized_error_message
- Add
config.forbidden_error_message
- Add
config.http_proxy
- Add
config.https_proxy
- Add
config.keepalive
- Add
config.authenticated_groups_claim
- Add
config.rediscovery_lifetime
- Add support for
X-Forwarded-*
headers in automaticconfig.redirect_uri
generation - Add
config.session_cookie_path
- Add
config.session_cookie_domain
- Add
config.session_cookie_samesite
- Add
config.session_cookie_httponly
- Add
config.session_cookie_secure
- Add
config.authorization_cookie_path
- Add
config.authorization_cookie_domain
- Add
config.authorization_cookie_samesite
- Add
config.authorization_cookie_httponly
- Add
config.authorization_cookie_secure
- Add
- CORE
- Admin API and DAO Audit Log
- Healthchecks
- HTTPS support
- License
- Added an increasingly
loud
logging to notify via nginx logs as the expiration date approaches- 90 days before the expiration date: Daily
WARN
log - 30 days before the expiration date: Daily
ERR
log - After the expiration date: Daily
CRIT
log
- 90 days before the expiration date: Daily
- Added an increasingly
- Workspaces
- Added endpoint
/workspaces/:ws_id/meta
that provides info about workspacews_id
. Current counts of entities per entity type are returned
- Added endpoint
Fixes
- CORE
- Plugin runloop
- Fix issue where Log phase plugins are not executed for request with non-matching routes. Note: For request with non-matching routes, every logging phase plugin enabled in the cluster will run irrespective of the workspace where it’s configured
- Workspaces
- Logging plugins log workspace info about requests
- Fix issue where attempt to share an entity outside the current request’s workspace would result in an Internal Server Error
- Fix issue where a global plugin would be executed for a workspace where it doesn’t belong
- RBAC
- Fix issue where admin could grant privileges to workspaces on which they don’t have permissions
- Permissions created with the
/rbac/roles/:role/endpoints
endpoint receive the current request’s workspace instead of the default workspace - Return HTTP status code 500 for database errors instead of 401 and 404
- Fix issue where a user with Admin privilege was able to access RBAC admin endpoints
- DAO
- Allow self-signed certificates in Cassandra connections
- check for schema consensus in Cassandra migration
- Ensure ScyllaDB compatibility in Cassandra migration
- Config
- IPv6 addresses in listen configuration directives are correctly parsed
- Certificates & SNIs
- Fix issue where internal server error was returned when CRUD operations were performed on Certificate endpoint
- Plugin runloop
- Plugins
- Request Termination
- Allow user to unset the value of
config.body
orconfig.message
or both
- Allow user to unset the value of
- Zipkin
- Fix failures when request is invalid or exits early
- Fix issue when service name is missing
- Proxy Cache
- Fix issue where responses were not cached if they met at least one positive criteria and did not meet any negative criteria
- Allow caching of responses without an explicit
public
directive in theCache-Control
header
- HMAC Authentication
- Fix issue where request was not correctly validated against the digest header when
config.validate_request_body
was set and request had no body
- Fix issue where request was not correctly validated against the digest header when
- OpenID Connect
- Fix
cache.tokens_load
ttl fallback to access token exp in case when expires_in is missing - Fix headers to not set when header value is
ngx.null
(a bit more robust now) - Fix encoding of complex upstream and downstream headers
- Fix multiple authentication plugins AND / OR scenarios
- Fix expiry leeway counting when there is refresh token available and when there is not.
- Fix issue when using password grant or client credentials grant with token caching enabled, and rotating keys on IdP that caused the cached tokens to give 403. The cached tokens will now be flushed and new tokens will be retrieved from the IdP.
- Fix a bug that prevented sub-plugins from loading the issuer data.
- Fix
- Request Termination
0.33-2
Release Date: 2018/10/09
Notifications
- Kong EE 0.33 inherits from Kong CE 0.13.1; make sure to read 0.13.1 - and 0.13.0 - changelogs:
- Kong EE 0.33 has these notices from Kong CE 0.13:
- Support for PostgreSQL 9.4 has been removed - starting with 0.32, Kong Enterprise does not start with PostgreSQL 9.4 or prior
- Support for Cassandra 2.1 has been deprecated, but Kong will still start - versions beyond 0.33 will not start with Cassandra 2.1 or prior
- Dev Portal requires Cassandra 3.0+
- Galileo - DEPRECATED: Galileo plugin is deprecated and will reach EOL soon
- Breaking: Since 0.32, the
latest
tag in Kong Enterprise Docker repository changed from CentOS to Alpine - which might result in breakage if additional packages are assumed to be in the image pointed to bylatest
, as the Alpine image only contains a minimal set of packages installed by default
Fixes
- Core
- DB
- lua-cassandra version bumped to 1.3.2
- Fix an issue encountered in environments with DNS load-balancing in effect for contact_points provided as hostnames (e.g.Kubernetes with
contact_points = { "cassandra" }
).
- Fix an issue encountered in environments with DNS load-balancing in effect for contact_points provided as hostnames (e.g.Kubernetes with
- lua-cassandra version bumped to 1.3.2
- Plugin Runloop
- Plugin runloop performance optimizations
- Reduce the number of invocations of the plugins iterator by attempting to load configurations only for plugins we know are configured on the cluster
- Pre-calculate plugins cache key
- Avoid unnecessary L2 cache deserialization
- Plugin runloop performance optimizations
- Balancer
- Fix issue where Upstream for different workspace getting cached to same key
- Fix an issue where Balancer are not run into limited workspace scope
- Dev Portal
- Fix an issue which may expose information on the URL query string
- Breaking: If you are updating from a previous version (not a clean install), you will need to update the files below in order to take advantage of security and performance updates.
- DB
unauthenticated/login (page)
{{#> unauthenticated/layout pageTitle="Login" }}
{{#*inline "content-block"}}
<div class="authentication">
{{#unless authData.authType}}
<h1>404 - Not Found</h1>
{{/unless}}
{{#if authData.authType}}
<h1>Login</h1>
<form id="login" method="post">
{{#if (eq authData.authType 'basic-auth')}}
<label for="username">Email</label>
<input id="username" type="text" name="username" required />
<label for="password">Password</label>
<input id="password" type="password" name="password" required />
<button id="login-button" class="button button-primary" type="submit">Login</button>
{{/if}}
{{#if (eq authData.authType 'key-auth')}}
<label for="key">Api Key</label>
<input id="key" type="text" name="key" required />
<button id="login-button" class="button button-primary" type="submit">Login</button>
{{/if}}
{{#if (eq authData.authType 'openid-connect')}}
<a href="{{config.PROXY_URL}}" class="button button-outline">
<svg class="google-button-icon" viewBox="0 0 366 372" xmlns="http://www.w3.org/2000/svg"><path d="M125.9 10.2c40.2-13.9 85.3-13.6 125.3 1.1 22.2 8.2 42.5 21 59.9 37.1-5.8 6.3-12.1 12.2-18.1 18.3l-34.2 34.2c-11.3-10.8-25.1-19-40.1-23.6-17.6-5.3-36.6-6.1-54.6-2.2-21 4.5-40.5 15.5-55.6 30.9-12.2 12.3-21.4 27.5-27 43.9-20.3-15.8-40.6-31.5-61-47.3 21.5-43 60.1-76.9 105.4-92.4z" id="Shape" fill="#EA4335"/><path d="M20.6 102.4c20.3 15.8 40.6 31.5 61 47.3-8 23.3-8 49.2 0 72.4-20.3 15.8-40.6 31.6-60.9 47.3C1.9 232.7-3.8 189.6 4.4 149.2c3.3-16.2 8.7-32 16.2-46.8z" id="Shape" fill="#FBBC05"/><path d="M361.7 151.1c5.8 32.7 4.5 66.8-4.7 98.8-8.5 29.3-24.6 56.5-47.1 77.2l-59.1-45.9c19.5-13.1 33.3-34.3 37.2-57.5H186.6c.1-24.2.1-48.4.1-72.6h175z" id="Shape" fill="#4285F4"/><path d="M81.4 222.2c7.8 22.9 22.8 43.2 42.6 57.1 12.4 8.7 26.6 14.9 41.4 17.9 14.6 3 29.7 2.6 44.4.1 14.6-2.6 28.7-7.9 41-16.2l59.1 45.9c-21.3 19.7-48 33.1-76.2 39.6-31.2 7.1-64.2 7.3-95.2-1-24.6-6.5-47.7-18.2-67.6-34.1-20.9-16.6-38.3-38-50.4-62 20.3-15.7 40.6-31.5 60.9-47.3z" fill="#34A853"/></svg>
<span class="google-button-text">Sign in with Google</span>
</a>
{{/if}}
</form>
{{/if}}
</div>
{{/inline}}
{{/unauthenticated/layout}}
unauthenticated/register (page)
unauthenticated/custom-css (partial)
{{!--
|--------------------------------------------------------------------------
| Here's where the magic happens. This is where you can add your own
| custom CSS as well as override any default styling we've provided.
| This file is broken up by section, but feel free to organize as you
| see fit!
|
| Helpful articles on customizing your Developer Portal:
| - https://getkong.org/docs/enterprise/latest/developer-portal/introduction/
| - https://getkong.org/docs/enterprise/latest/developer-portal/getting-started/
| - https://getkong.org/docs/enterprise/latest/developer-portal/understand/
| - https://getkong.org/docs/enterprise/latest/developer-portal/customization/
| - https://getkong.org/docs/enterprise/latest/developer-portal/authentication/
| - https://getkong.org/docs/enterprise/latest/developer-portal/faq/
|
|--------------------------------------------------------------------------
|
--}}
{{!-- Custom fonts --}}
{{!-- <link href="https://fonts.googleapis.com/css?family=Roboto" rel="stylesheet">
<link href="//cdnjs.cloudflare.com/ajax/libs/highlight.js/9.12.0/styles/default.min.css" rel="stylesheet"> --}}
<style>
/*
|--------------------------------------------------------------------------
| Typography:
| h1, h2, h3, h4, h5, h6, p
|--------------------------------------------------------------------------
|
*/
h1 {}
h2 {}
h3 {}
h4 {}
h5 {}
h6 {}
p {}
/* Header */
#header {}
/* Sidebar */
#sidebar {}
/* Footer */
#footer {}
/* Swagger UI */
.swagger-ui .side-panel {}
/*
|--------------------------------------------------------------------------
| Code block prismjs theme.
| e.g. https://github.com/PrismJS/prism-themes
|--------------------------------------------------------------------------
|
*/
.token.block-comment,
.token.cdata,
.token.comment,
.token.doctype,
.token.prolog {
color: #999
}
.token.punctuation {
color: #ccc
}
.token.attr-name,
.token.deleted,
.token.namespace,
.token.tag {
color: #e2777a
}
.token.function-name {
color: #6196cc
}
.token.boolean,
.token.function,
.token.number {
color: #f08d49
}
.token.class-name,
.token.constant,
.token.property,
.token.symbol {
color: #f8c555
}
.token.atrule,
.token.builtin,
.token.important,
.token.keyword,
.token.selector {
color: #cc99cd
}
.token.attr-value,
.token.char,
.token.regex,
.token.string,
.token.variable {
color: #7ec699
}
.token.entity,
.token.operator,
.token.url {
color: #67cdcc
}
.token.bold,
.token.important {
font-weight: 700
}
.token.italic {
font-style: italic
}
.token.entity {
cursor: help
}
.token.inserted {
color: green
}
</style>
- Plugins
- LDAP Auth Advanced
- Fix an issue where the plugin fails to authenticate a user when the LDAP server doesn’t return the user’s password as part of the search result
- Fix issue where the username field wasn’t allowed to contain non-alaphanumeric characters
- LDAP Auth Advanced
0.33-1
Release Date: 2018/09/05
Notifications
- Kong EE 0.33 inherits from Kong CE 0.13.1; make sure to read 0.13.1 - and 0.13.0 - changelogs:
- Kong EE 0.33 has these notices from Kong CE 0.13:
- Support for PostgreSQL 9.4 has been removed - starting with 0.32, Kong Enterprise does not start with PostgreSQL 9.4 or prior
- Support for Cassandra 2.1 has been deprecated, but Kong will still start - versions beyond 0.33 will not start with Cassandra 2.1 or prior
- Dev Portal requires Cassandra 3.0+
- Galileo - DEPRECATED: Galileo plugin is deprecated and will reach EOL soon
- Breaking: Since 0.32, the
latest
tag in Kong Enterprise Docker repository changed from CentOS to Alpine - which might result in breakage if additional packages are assumed to be in the image pointed to bylatest
, as the Alpine image only contains a minimal set of packages installed by default
Changes
- Plugins
- HMAC Auth
- Attempt signature generation without querystring arguments if the newer signature verification, that includes querystring, fails
- StatsD Advanced
- Improve performance when constructing the metrics key
- Allow hostname to be written into the key prefix, based on a boolean plugin config flag
- HMAC Auth
Fixes
- Core
- RBAC
- Fix an issue where entities are not added to the role-entities table when id is not the primary key
- Fix an issue where role-entities and role-endpoints relationships are not deleted when role is removed
- Fix issue leading to SNI creation failure when RBAC is on
- Workspaces
- Fix an issue where authentication keys prefixed with a workspace name would be considered valid
- DB
- Cassandra
- Fix Cassandra unique violation check on update
- Cassandra
- Migrations
- Remove dependency on “public” schema or “pg_default” tablespaces in PostgreSQL - such a dependency would cause migrations to fail if such tablespaces weren’t being used
- Healthchecks
- Fix Host header in active healthchecks
- Fix for connection timeouts on passive healthchecks
- Dev Portal
- Fix issue leading migrations
2018-04-10-094800_dev_portal_consumer_types_statuses
and2018-05-08-143700_consumer_dev_portal_columns
to fail - Automatically log users in after registering when auto-approve is on
- Reduce the size of the mobile breakpoint
- Improve performance and file sizes of bundled code
- Fix issue causing Portal to list spec files twice
- Swagger Improvements:
- Fix for rendering OAS 3.0 spec files
- Ensure that page loading isn’t blocked by Swagger UI rendering
- Fix issue leading migrations
- RBAC
- Plugins
- LDAP Auth & LDAP Auth Advanced
- Fix an issue where a request would fail when the password field had more than 128 characters in length
- Make the password part of the cache key, so that an invalid credential can be cached without blocking valid credentials
- Zipkin
- Fix operation when service and/or route are missing
- Fix cause of missing kong.credential field
- Support for deprecated Kong “api” entity via kong.api tag
- Rate Limiting Advanced Plugin
- Fix issue preventing the plugin to correctly propagate configuration changes across Kong Nginx workers
- Fix issue preventing the plugin to load configuration and create sync timers
- Fix plugin name in log messages
- Canary
- Fixed the type attribute for port configuration setting
- Forward Proxy
- Fix Kong core dependency causing the access phase handle to fail
- Proxy Cache
- Fix issue leading to cache key collision in some scenarios - e.g., for requests issued by the same consumer
- Fix cache key for Routes and Services: previously, distinct routes/services entities would be given the same cache key
- LDAP Auth & LDAP Auth Advanced
0.33
Release Date: 2018/07/24
Notifications
- Kong EE 0.33 inherits from Kong CE 0.13.1; make sure to read 0.13.1 - and 0.13.0 - changelogs:
- Kong EE 0.33 has these notices from Kong CE 0.13:
- Support for PostgreSQL 9.4 has been removed - starting with 0.32, Kong Enterprise does not start with PostgreSQL 9.4 or prior
- Support for Cassandra 2.1 has been deprecated, but Kong will still start - versions beyond 0.33 will not start with Cassandra 2.1 or prior
- Additional requirements:
- Vitals requires PostgreSQL 9.5+
- Dev Portal requires Cassandra 3.0+
- Galileo - DEPRECATED: Galileo plugin is deprecated and will reach EOL soon
- Breaking: Since 0.32, the
latest
tag in Kong Enterprise Docker repository changed from CentOS to Alpine - which might result in breakage if additional packages are assumed to be in the image pointed to bylatest
, as the Alpine image only contains a minimal set of packages installed by default
Changes
- Vitals
- Internal proxies are no longer tracked
- Admin API endpoint
/vitals/consumers/:username_or_id/nodes
, deprecated in 0.32, has been removed
Prometheus Plugin
The plugin uses a dedicated shared dictionary. If you use a custom template, define the following for Prometheus:
lua_shared_dict prometheus_metrics 5m;
OpenID Connect Plugin
- Change
config_consumer_claim
from string to array
- Change
Features
- Core
- New RBAC implementation, supporting both endpoint and entity-level access control - read the docs
- Workspaces, allowing segmentation of Admin API entities - read the docs here. Note that workspaces are available in the API only, and not in the Admin GUI
- Admin GUI
- Log in to the Admin GUI using Kong’s own authentication plugins; supported plugins are key-auth, basic-auth, and ldap-auth-advanced. Use of other authentication plugins has not been tested.
- Add ability to see what plugins are configured on a consumer
- Dev Portal
- Revoked Dev Portal Users/Consumers are blocked at proxy
- Files API Improvements
- File editor in Admin GUI
- Consumer API usage on Dev Portal user area
- OpenID Connect Plugin
- Add
config.consumer_optional
- Add
config.token_endpoint_auth_method
- Add
consumer.status
check for internal authentication
- Add
- Forward Proxy Plugin
- Add support for delayed response
- Add
via
header
- Canary Plugin
- Added whitelist and blacklist options to be able to select consumers instead of having random consumers
- Added a port parameter to be able to be set a new port for the alternate upstream
- LDAP Auth Advanced
- Find consumers by
consumer_by
fields and map to ldap-auth user. This will set the authenticated consumer so thatX-Consumer-{ID, USERNAME, CUSTOM_ID}
headers are set and consumer functionality is available - Add fields
consumer_by
: optional, default:{username, custom_id}
consumer_optional
: optional, default:false
- Find consumers by
- StatsD Plugin
- New plugin; see documentation
- Prometheus Plugin
- New plugin; see documentation here
Fixes
- Core
- Healthchecks: health status no longer resets when a Target is added to an Upstream
- Runloop: properly throw errors from plugins fetch
- DB: fix double-wraping of
err_t
strategy error
- Plugins
- Azure delayed response
- Lambda delayed response
- Request Termination delayed response
- Admin GUI
- Fix a problem where a plugin value cannot be unset
- Fix a problem where error messages on the login screen fail to display
- Portal
- Auto-approve messaging
- OpenID Connect Plugin
- Fix
kong_oauth2
auth_method
so that it works without having to also add bearer or introspection toconfig.auth_method
- Fix
ngx.ctx.authenticated_credential
so that it isn’t set when a value withconfig.credential_claim
isn’t found
- Fix
- Zipkin Plugin
- Fix an issue with how timestamps can sometimes be encoded with scientific notation, causing the Zipkin collector to refuse some traces
- LDAP Auth Advanced Plugin
- Fix require statements pointing to Kong CE’s version of the plugin
- Fix usage of the LuaJIT FFI, where an external symbol was not accessed properly, resulting in an Internal Server Error
Rate Limiting Advanced Plugin
- Fix an issue in Cassandra migrations that would stop the migration process
- Allow existing plugin configurations without a value for the recently-introduced introduced
dictionary_name
field to use the default dictionary for the plugin -kong_rate_limiting_counters
. Customers using a custom Nginx template are advised to check if such a dictionary is defined in their template:
0.32
Release Date: 2018/05/24
Notifications
- Kong EE 0.32 inherits from Kong CE 0.13.1; make sure to read 0.13.1 - and 0.13.0 - changelogs:
- Kong EE 0.32 has these notices from Kong CE 0.13:
- Support for PostgreSQL 9.4 has been removed - starting with 0.32, Kong Enterprise will not start with PostgreSQL 9.4 or prior
- Support for Cassandra 2.1 has been deprecated, but Kong will still start - versions beyond 0.33 will not start with Cassandra 2.1 or prior
- Additional requirements:
- Vitals requires PostgreSQL 9.5+
- Dev Portal requires Cassandra 3.0+
- Galileo - DEPRECATED: Galileo plugin is deprecated and will reach EOL soon
- Breaking: The
latest
tag in Kong Enterprise Docker repository changed from CentOS to Alpine - which might result in breakage if additional packages are assumed to be in the image, as the Alpine image only contains a minimal set of packages installed - OpenID Connect
- The plugins listed below were deprecated in favor of the all-in-one openid-connect plugin:
openid-connect-authentication
openid-connect-protection
openid-connect-verification
- The plugins listed below were deprecated in favor of the all-in-one openid-connect plugin:
Changes
- New Data Model - Kong EE 0.32 is the first Enterprise version including the , released with Kong CE 0.13, which includes Routes and Services
Rate Limiting Advanced
- Breaking - the Enterprise Rate Limiting plugin, named
rate-limiting
up to EE 0.31, was renamedrate-limiting-advanced
and CE Rate Limiting was imported asrate-limiting
. Any Admin API calls that were previously targeting the Enterprise Rate Limiting plugin in Kong EE up to 0.31 need to be updated to targetrate-limiting-advanced
Rate Limiting Advanced, similarly to CE rate-limiting, now uses a dedicated shared dictionary named
kong_rate_limiting_counters
for its counters; if you are using a custom template, make sure to define the following shared memory zones:lua_shared_dict kong_rate_limiting_counters 12m;
- Breaking - the Enterprise Rate Limiting plugin, named
Vitals
Vitals uses two dedicated shared dictionaries. If you use a custom template, define the following shared memory zones for Vitals:
lua_shared_dict kong_vitals_counters 50m;
lua_shared_dict kong_vitals_lists 1m;
You can remove any existing shared dictionaries that begin with
kong_vitals_
, e.g.,kong_vitals_requests_consumers
OpenID Connect
- Remove multipart parsing of ID tokens - they were not proxy safe
- Change expired or non-active access tokens to give
401
instead of403
Features
- Admin GUI
- New Listeners (Admin GUI + Developer Portal)
- Routes and Services GUI
- New Plugins thumbnail view
- Healthchecks GUI
- Syntax for form-encoded array elements
- Dev Portal Overview tab
- Developers management tab
- Vitals
- Status Code tracking - GUI and API
- Status Code groups per Cluster - counts of
1xx
,2xx
,3xx
,4xx
,5xx
groups across the cluster over time. Visible in the Admin GUI atADMIN_URL/vitals/status-codes
- Status Codes per Service - count of individual status codes correlated to a particular service. Visible in the Admin GUI at
ADMIN_URL/services/{service_id}
- Status Codes per Route - count of individual status codes correlated to a particular route. Visible in the Admin GUI at
ADMIN_URL/routes/{route_id}
- Status Codes per Consumer and Route - count of individual status codes returned to a given consumer on a given route. Visible in the Admin GUI at
ADMIN_URL/consumers/{consumer_id}
- Status Code groups per Cluster - counts of
- Status Code tracking - GUI and API
- Dev Portal
- Code Snippets
- Developer “request access” full life-cycle
- Default Dev Portal included in Kong distributions (with default theme)
- Authentication on Dev Portal out of box (uncomment in Kong.conf)
- Docs for Routes/Services for Dev Portal
- Docs for Admin API
- Requires Migration -
/files
endpoint is now protected by RBAC
- Plugins
- Rate Limiting Advanced: add a
dictionary_name
configuration, to allow using a custom dictionary for storing counters - Requires Migration - Rate Limiting CE is now included in EE
- Request Transformer CE is now included in EE
- Edge Compute: plugin-based, Lua-only preview
- Proxy Cache: Customize the cache key, selecting specific headers or query params to be included
- Opentracing Plugin: Kong now adds detailed spans to Zipkin and Jaeger distributed tracing tools
- Azure Functions Plugin: Invoke Azure functions from Kong
- LDAP Advanced: LDAP plugin with augmented ability to search by LDAP fields
- Rate Limiting Advanced: add a
- OpenID Connect
- Add
self_check
function to validate that OIDC discovery information can be downloaded - Bearer token is now looked up on
Access-Token
andX-Access-Token
headers in addition to Authorization Bearer header (query and body args are supported as before) - JWKs are rediscovered and the new keys are cached cluster wide (works better with keys rotation schemes)
- Admin API does self-check for discovery endpoint when the plugin is added and reports possible errors back
- Add configuration directives
config.extra_jwks_uris
config.credential_claim
config.session_storage
config.session_memcache_prefix
config.session_memcache_socket
config.session_memcache_host
config.session_memcache_port
config.session_redis_prefix
config.session_redis_socket
config.session_redis_host
config.session_redis_port
config.session_redis_auth
config.session_cookie_lifetime
config.authorization_cookie_lifetime
config.forbidden_destroy_session
config.forbidden_redirect_uri
config.unauthorized_redirect_uri
config.unexpected_redirect_uri
config.scopes_required
config.scopes_claim
config.audience_required
config.audience_claim
config.discovery_headers_names
config.discovery_headers_values
config.introspect_jwt_tokens
config.introspection_hint
config.introspection_headers_names
config.introspection_headers_values
config.token_exchange_endpoint
config.cache_token_exchange
config.bearer_token_param_type
config.client_credentials_param_type
config.password_param_type
config.hide_credentials
config.cache_ttl
config.run_on_preflight
config.upstream_headers_claims
config.upstream_headers_names
config.downstream_headers_claims
config.downstream_headers_names
- Add
Fixes
- Core
- Healthchecks
- Fix an issue where updates made through
/health
or/unhealth
wouldn’t be propagated to other Kong nodes - Fix internal management of healthcheck counters, which corrects detection of state flapping
- Fix an issue where updates made through
- DNS: a number of fixes and improvements were made to Kong’s DNS client library, including:
- The ring-balancer now supports
targets
resolving to an SRV record without port information (port=0
) - IPv6 nameservers with a scope in their address (For example,
nameserver fe80::1%wlan0
) will now be skipped instead of throwing errors
- The ring-balancer now supports
- Healthchecks
- Rate Limiting Advanced
- Fix
failed to upsert counters
error - Fix issue where an attempt to acquire a lock would result in an error
- Mitigate issue where lock acquisitions would lead to RL counters being lost
- Fix
- Proxy Cache
- Fix issue where proxy-cache would short-circuit requests that resulted in a cache hit, not allowing subsequent plugins - e.g., logging plugins - to run
- Fix issue where PATCH requests would result in a 500 response
- Fix issue where Proxy Cache would overwrite X-RateLimit headers
- Request Transformer
- Fix issue leading to an Internal Server Error in cases where the Rate Limiting plugin returned a 429 Too Many Requests response
- AWS Lambda
- Fix issue where an empty array
[]
was returned as an empty object{}
- Fix issue where an empty array
- Galileo - DEPRECATED
- Fix issue that prevented Galileo from reporting requests that were cached by proxy-cache
- Fix issue that prevented Galileo from showing request/response bodies of requests served by proxy-cache
- OpenID Connect
- Fix
exp
retrieval - Fix
jwt_session_cookie
verification - Fix consumer mapping using introspection where the claim was searched in an inexistent location
- Fix header values when their callbacks fail to get the value - instead of setting their values as
function ...
- Fix
config.scopes
when set tonull
or""
so that it doesn’t add an OpenID scope forcibly, as the plugin is not only OpenID Connect only, but also OAuth2
- Fix
0.31-1
Release Date: 2018/04/25
Changes
- New shared dictionaries named
kong_rl_counters
andkong_db_cache_miss
were defined in Kong’s default template - customers using custom templates are encouraged to update them to include those, as they avoid the reuse of thekong_cache
shared dict; such a reuse is known to be one of the culprits behindno memory
errors - see diff below - The rate-limiting plugin now accepts a
dictionary_name
argument, which is used for temporarily storing rate-limiting counters
NOTE: if you use a custom Nginx configuration template, apply the following patch to your template:
Fixes
- Bump mlcache to 2.0.2 and mitigates a number of issues known to be causing
no memory
errors - Fixes an issue where boolean values (and boolean values as strings) were not correctly marshalled when using Cassandra
- Fixes an issue in Redis Sentinel configuration parsing
0.31
Release Date: 2018/03/16
Kong Enterprise 0.31 is shipped with all the changes present in Kong Community Edition 0.12.3, as well as with the following additions:
Changes
- Galileo plugin is disabled by default in this version, needing to be explicitly enabled via the custom_plugins configuration
- NOTE: If a user had the Galileo plugin applied in an older version and migrate to 0.31, Kong will fail to restart unless the user enables it via the configuration; however, it is still possible to enable the plugin per API or globally without adding it to custom_plugins
- OpenID Connect plugin:
- Change
config.client_secret
fromrequired
tooptional
- Change
- Change
config.client_id
fromrequired
tooptional
- If
anonymous
consumer is not found Internal Server Error is returned instead of Forbidden - Breaking Change -
config.anonymous
now behaves similarly to other plugins and doesn’t halt execution or proxying (previously it was used just as a fallback for consumer mapping) and the plugin always needed valid credentials to be allowed to proxy if the client wasn’t already authenticated by higher priority auth plugin - Anonymous consumer now uses a simple cache key that is used in other plugins
- In case of auth plugins concatenation, the OpenID Connect plugin now removes remnants of anonymous
Fixes
- Admin GUI
- Remove deprecated orderlist field from Admin GUI Upstreams entity settings
- Fix issue where Admin GUI would break when running Kong in a custom prefix
- Fix issue where Healthchecks had a field typed as number instead of string.
- Fix issue where Healthchecks form had incorrect default values.
- Fix issue where table row text was overflowing and expanding the page.
- Fix issue where notification bar in mobile view could have text overflow beyond the container.
- Fix issue where deleting multiple entities in a list would cause the delete modal to not show.
- Fix issue where cards on the dashboard were not evenly sized and spaced.
- Fix issue where cards on the dashboard in certain widths could have text overflow beyond their container.
- Fix issue where Array’s on Plugin Entities were not being processed and sent to the Admin API.
- Fix issue where Models were improperly handled when not updated and not sending default values properly.
- Fix issue where Plugin lists were not displaying config object.
- Fix issue where Kong was not processing SSL configuration for Admin GUI
- OpenID Connect plugin
- Fixed anonymous consumer mapping
Vitals
- Correct the stats returned in the “metadata” attribute of the /vitals/consumers/:consumer_id/* endpoints
- Correct a problem where workers get out of sync when adding their data to cache
- Correct inconsistencies in chart axes when toggling between views or when Kong has no traffic
- Proxy Cache
- Fix issue that prevented cached requests from showing up in Vitals or Total Requests graphs
- Fixes inherited from Kong Community Edition 0.12.3.
Features
- Admin GUI
- Add notification bar alerting users that their license is about to expire, and has expired.
- Add new design to vitals overview, table breakdown, and a new tabbed chart interface.
- Add top-level vitals section to the sidebar.
- Requires migration - Vitals
- New datastore support: Cassandra 2.1+
- Support for averages for Proxy Request Latency and Upstream Latency
- Requires migration - Dev Portal
- Not-production-ready feature preview of:
- “Public only” Portal - no authentication (the portal is fully accessible to anyone who can access it)
- Authenticated Portal - Developers must log in, and then they can see what they are entitled to see
- Not-production-ready feature preview of:
0.30
Release Date: 2018/01/24
Kong Enterprise 0.30 is shipped with all the changes present in , as well as with the following additions:
Notifications
- EE 0.30 inherits dependency deprecation notices from CE 0.12. See the “Deprecation Notes” section of Kong 0.12.0 changelog
⚠️ By default, the Admin API now only listens on the local interface. We consider this change to be an improvement in the default security policy of Kong. If you are already using Kong, and your Admin API still binds to all interfaces, consider updating it as well. You can do so by updating the
admin_listen
configuration value, like so:admin_listen = 127.0.0.1:8001
.🔴 Note to Docker users: Beware of this change as you may have to ensure that your Admin API is reachable via the host’s interface. You can use the
-e KONG_ADMIN_LISTEN
argument when provisioning your container(s) to update this value; for example,-e KONG_ADMIN_LISTEN=0.0.0.0:8001
.
Changes
- Renaming of Enterprise plugin
request-transformer
becomesrequest-transformer-advanced
- Rate-limiting plugin
- Change default
config.identifier
in EE’s fromip
toconsumer
- Change default
- Vitals
- Aggregate minutes data at the same time as seconds data
- Breaking Change: Replace previous Vitals API (part of the Admin API) with new version. Not backwards compatible.
- Upgrading from Kong EE (0.29) will result in the loss of previous Vitals data
- Admin GUI
- Vitals chart settings stored in local storage
- Improve vital chart legends
- Change Make A Wish email to <a href=”mailto:wish@konghq.com`>wish@konghq.com</a>
- OpenID Connect Plugins
- Change
config.login_redirect_uri
fromstring
toarray
- Add new configuration parameters
- config.authorization_query_args_client
- config.client_arg
- config.logout_redirect_uri
- config.logout_query_arg
- config.logout_post_arg
- config.logout_uri_suffix
- config.logout_methods
- config.logout_revoke
- config.revocation_endpoint
- config.end_session_endpoint
- Change
- OpenID Connect Library
- Function now return as a third parameter, the grant type if one was found - previously, it returned parameter location in HTTP request
- Issuer is no longer verified on discovery as some IdPs report different value (it is still verified with claims verification)
Added
New Canary Release plugin
Vitals
- Addition of “node-specific” dimension for previously-released metrics (Kong Request Latency and Datastore Cache)
- New metrics and dimensions:
- Request Count per Consumer, by Node or Cluster
- Total Request Count, by Node or Cluster
- Upstream Latency (the time between a request being sent upstream by Kong, and the response being received by Kong), by Node or Cluster
- All new metrics and dimensions accessible in Admin GUI and API
- Important limitations and notifications:
- PostgreSQL 9.5+ only - no Cassandra support yet
- Upgrading from the previous version of Kong EE will result in all historic Vitals data being dropped
- The previous Vitals API (which is part of the Admin API) is replaced with a new, better one (the old API disappears, and there is no backwards compatibility)
- Proxy Cache
- Implement Redis (stand-alone and Sentinel) caching of proxy cache entities
- Enterprise Rate Limiting
- Provide fixed-window quota rate limiting (which is essentially what the CE rate-limiting plugin does) in addition to the current sliding window rate limiting
- Add hide_client_headers configuration to disable response headers returned by the rate limiting plugin
- Admin GUI
- Addition of “Form Control Grouping” for the new Upstream health-check configuration options.
- Add Healthy or Unhealthy buttons for the new health-check functionality on Upstream Targets table.
- Add Hostname and Hostname + Id reporting and labeling functionality to Vitals components.
- Add Total Requests per Consumer chart to individual consumer pages.
- Add Total Requests and Upstream Latency charts to the Vitals page.
- Add information dialogs for vital charts next to chart titles.
- Introduced Total Requests chart on Dashboard.
- Automatically saves chart preferences and restores on reload.
- OpenID Connect plugins
- Support passing dynamic arguments to authorization endpoint from client
- Support logout with optional revocation and RP-initiated logout
- Features inherited from Kong Community Edition 0.12.0 - includes:
- Health checks
- Hash-based load balancing
- Logging plugins track unauthorized and rate-limited requests
- And more…
- Proxy Cache
- Better handling of input configuration data types. In some cases configuration sent from the GUI would case requests to be bypassed when they should have been cached.
- OAuth2 Introspection
- Improved error handling in TCP/HTTP connections to the introspection server.
- Vitals
- Aggregating minutes at the same time as seconds are being written.
- Returning more than one minute’s worth of seconds data.
- Admin GUI
- Input type for Certificates is now a text area box.
- Fixes inherited from Kong Community Edition 0.12.0.