Document updated on May 3, 2023
The wildcard functionality allows you to declare endpoints that have many implicit paths in their backend. Instead of declaring all possible routes one by one, you can create one or more endpoints that will respond to a path pattern instead. The gateway then forwards all routes starting with the configured path to the backend(s).
For instance, you can declare an endpoint /foo/*
that forwards all traffic starting with /foo/
to a specific backend. When a user calls /foo/bar
or /foo/bar/vaz
, the request is processed by the same endpoint and backends.
Since paths are implicit, KrakenD does not know if a request is valid or not beyond checking that the pattern is correct, or checking additional components you might add. Therefore, everything it can do is to “hope for the best” before routing the request, and it is the responsibility of the backend to determine if the path is valid.
The wildcard functionality is a good candidate when you are in a migration scenario and you need to expose a lot of endpoints quickly. However, it would be best to transition to an explicit declaration instead, and you should aim for it if security is a concern.
To enable wildcards, you only need to write a string ending in /*
in the’ endpoint’ path. Then, the receiving backend will automatically append the remaining request to its url_pattern
. For instance, given the following configuration:
{
"endpoint": "/v1/*",
"backend": [{
"host": ["http://legacy-api"],
"url_pattern": "/"
}]
}
When requesting to http://krakend/v1/hello
, you get a request to your backend ashttp://legacy-api/hello
. Notice that you don’t need to write any asterisk in the url_pattern
.
The wildcard applies to the path only. If you want to use multiple methods (GET
, PUT
, POST
, etc.), you still need to create an entry per method as in any other KrakenD endpoint.
Make sure to declare wildcards per the following rules:
/v1/*/foo/*
). Instead, use {placeholders}
. E.g., /v1/{service}/foo/*
."endpoint": "/*"
). Therefore, you must declare at least one directory level before placing the wildcard. See the Catch-All endpoint for such uses.Examples of valid paths:
/a/b/c/*
/a/*
/{var}/*
/{foo}/{bar}/*
Examples of invalid paths:
/abc*
(doesn’t end in /*
)/*
(forwards all traffic, use Catch-All instead)/*/a/*
(multiple uses of *
)As you can see, combining the wildcard with endpoint variables is possible. For instance, you could have the following paths configured:
{
"endpoints": [
{
"endpoint": "/v1/{service}/*",
"backend": [{
"url_pattern": "/v1/{service}/"
}]
},
{
"endpoint": "/{owmamma}/*",
"backend": [{
"url_pattern": "/{owmamma}/"
}]
}
]
}
If you used Wildcards before EE v2.3, eliminate now all entries referring to plugins. This means:
plugin
entry in the root level.plugin/http-server
objects if they only use the wildcardwildcard
object in the configurationplugin/http-client
with an insider wildcard
entry."X-Krakend-Wildcard"
entries in input_headers
.For instance, if you had this configuration:
{
"version": 3,
"port": 8080,
"plugin": {
"pattern":".so",
"folder": "/opt/krakend/plugins/"
},
"extra_config": {
"plugin/http-server": {
"name": [ "wildcard" ],
"wildcard": {
"endpoints": {
"/__wildcard/foo": [ "/foo" ],
"/__wildcard/legacy": [ "/v1" ]
}
}
}
},
"endpoints": [
{
"endpoint": "/__wildcard/foo",
"input_headers": [ "X-Krakend-Wildcard" ],
"backend": [
{
"host": [ "http://localhost:8080" ],
"url_pattern": "/__debug/foo",
"extra_config": {
"plugin/http-client": {
"name": "wildcard"
}
}
}
]
},
{
"endpoint": "/__wildcard/legacy",
"input_headers": [ "X-Krakend-Wildcard" ],
"backend": [
{
"host": [ "http://localhost:8080" ],
"url_pattern": "/__debug/legacy",
"extra_config": {
"plugin/http-client": {
"name": "wildcard"
}
}
}
]
}
]
}
Since EE 2.3, it has become:
{
"version": 3,
"port": 8080,
"endpoints": [
{
"endpoint": "/foo/*",
"backend": [
{
"host": [ "http://localhost:8080" ],
"url_pattern": "/__debug/"
}
]
},
{
"endpoint": "/v1/*",
"backend": [
{
"host": [ "http://localhost:8080" ],
"url_pattern": "/__debug/"
}
]
}
]
}
The documentation is only a piece of the help you can get! Whether you are looking for Open Source or Enterprise support, see more support channels that can help you.