Advanced Gateway features configuration
Advanced Gateway features configuration
As a system programmer who wants to configure advanced Gateway features of the API Mediation Layer, you can customize Gateway parameters by modifying either of the following files:
<Zowe install directory>/components/gateway/bin/start-gateway.sh
<Zowe instance directory>/instance.env
The parameters begin with the -D
prefix, similar to all the other parameters in the file.
Note: Restart Zowe to apply changes to the parameter.
Follow the procedures in the following sections to customize Gateway parameters according to your preferences:
- Prefer IP Address for API Layer services
- SAF as an Authentication provider
- Enable Jwt token refresh endpoint
- Gateway retry policy
- Gateway client certificate authentication
- Gateway timeouts
- CORS handling
- Encoded slashes
- Connection limits
- Routed instance header
- Distributed load balancer cache
- Replace or remove catalog with another service
- API Mediation Layer as a standalone component
- SAF resource checking
#
Prefer IP Address for API Layer servicesAPI Mediation Layer services use the hostname when communicating with each other. This behavior can be changed so that the IP address is used instead.
Follow these steps:
- Open the
<Zowe instance directory>/instance.env
configuration file. - Find the property
APIML_PREFER_IP_ADDRESS
and set the value totrue
. - Restart Zowe&trade.
Note: Changing the value of this property might introduce problems with certificates. Ensure that the IP Address is present on the certificate SAN name.
#
SAF as an Authentication providerBy default, the API Gateway uses z/OSMF as an authentication provider. It is possible to switch to SAF as the authentication provider instead of z/OSMF. The intended usage of SAF as an authentication provider is for systems without z/OSMF. If SAF is used and the z/OSMF is available on the system, the created tokens are not accepted by z/OSMF. Use the following procedure to switch to SAF.
Follow these steps:
- Open the
<Zowe instance directory>/instance.env
configuration file. - Find the property
APIML_SECURITY_AUTH_PROVIDER
and set the value tosaf
. - Restart Zowe&trade.
Authentication requests now utilize SAF as the authentication provider. API ML can run without z/OSMF present on the system.
#
Enable Jwt token refresh endpointEnable the /gateway/api/v1/auth/refresh
endpoint to exchange a valid JWT token for a new token with a new expiration date. Call the endpoint with a valid JWT token and trusted client certificate. In case of z/OSMF authentication provider, enable API Mediation Layer for passticket generation and configure z/OSMF APPLID. Configure Passtickets
Follow these steps:
Open the file
<Zowe instance directory>/instance.env
.Configure the following properties:
APIML_SECURITY_ALLOWTOKENREFRESH=true
Add this property to enable the refresh endpoint.
APIML_SECURITY_ZOSMF_APPLID
If you use z/OSMF as an authentication provider, provide a valid
APPLID
. The API ML generates a passticket for the specifiedAPPLID
and subsequently uses this passticket to authenticate to z/OSMF. The default value in the installation of z/OSMF isIZUDFLT
.
Restart Zowe.
#
Change password with SAF providerUpdate the user password using the SAF Authentication provider. To use this functionality, add the parameter newPassword
on the login endpoint /gateway/api/v1/auth/login
. The Gateway service returns a valid JWT with the response code 204
as a result of successful password change. The user is then authenticated and can consume APIs through the Gateway. If it is not possible to change the password for any reason, the response code is 401
.
Use a POST
REST call against the URL /gateway/api/v1/auth/login
:
{"username" : "<username>","password" : "<password>","newPassword" : "<newPassword>"}
Note:
It is a common practice to set the limit for changing the password in the ESM. This value is set by the parameter MINCHANGE
for PASSWORD
. The password can be changed once. Subsequently, it is necessary to wait the specified time period before changing the password again.
Example:
MINCHANGE=120
where:
120
Specifies the number of days before the password can be reset
#
Gateway retry policyTo change the Gateway retry policy, edit properties in the <Zowe install directory>/components/gateway/bin/start.sh
file:
All requests are disabled as the default configuration for retry with one exception: the server retries GET
requests that finish with status code 503
.
To change this default configuration, include the following parameters:
ribbon.retryableStatusCodes
Provides a list of status codes, for which the server should retry the request.
Example:
-Dribbon.retryableStatusCodes="503, 404"
ribbon.OkToRetryOnAllOperations
Specifies whether to retry all operations for this service. The default value is
false
. In this case, onlyGET
requests are retried if they return a response code that is listed inribbon.retryableStatusCodes
. Setting this parameter totrue
enables retry requests for all methods which return a response code listed inribbon.retryableStatusCodes
.Note: Enabling retry can impact server resources due to request body buffering.
ribbon.MaxAutoRetries
Specifies the number of times a failed request is retried on the same server. This number is multiplied with
ribbon.MaxAutoRetriesNextServer
. The default value is0
.ribbon.MaxAutoRetriesNextServer
Specifies the number of additional servers that attempt to make the request. This number excludes the first server. The default value is
5
.
#
Gateway client certificate authenticationBeginning with release 1.19 LTS, it is possible to authenticate using client certificates. The feature is functional and tested, but automated testing on various security systems is not complete. As such, the feature is provided as a beta release for early preview. If you would like to offer feedback using client certificate authentication, please create an issue against the api-layer repository. Client Certificate authentication will move out of Beta once test automation is fully implemented across different security systems.
Use the following procedure to enable the feature to use a client certificate as the method of authentication for the API Mediation Layer Gateway.
Follow these steps:
Open the
<Zowe instance directory>/instance.env
configuration file.Configure the following properties:
APIML_SECURITY_X509_ENABLED
This property is the global feature toggle. Set the value to
true
to enable client certificate functionality.APIML_SECURITY_ZOSMF_APPLID
When z/OSMF is used as an authentication provider, provide a valid
APPLID
to allow for client certificate authentication. The API ML generates a passticket for the specifiedAPPLID
and subsequently uses this passticket to authenticate to z/OSMF. The default value in the installation of z/OSMF isIZUDFLT
.Note: The following steps are only required if the ZSS hostname or default Zowe user name are altered:
Change the following property if user mapping is provided by an external API:
- APIML_GATEWAY_EXTERNAL_MAPPER
Note: Skip this step if user mapping is not provided by an external API.
The API Mediation Gateway uses an external API to map a certificate to the owner in SAF. This property informs the Gateway about the location of this API. ZSS is the default API provider in Zowe. You can provide your own API to perform the mapping. In this case, it is necessary to customize this value.
The following URL is the default value for Zowe and ZSS:
https://${ZOWE_EXPLORER_HOST}:${GATEWAY_PORT}/zss/api/v1/certificate/x509/map
Add the following property if the Zowe runtime userId is altered from the default
ZWESVUSR
:- APIML_GATEWAY_MAPPER_USER
Note: Skip this step if the Zowe runtime userId is not altered from the default
ZWESVUSR
.To authenticate to the mapping API, a JWT is sent with the request. The token represents the user that is configured with this property. The user authorization is required to use the
IRR.RUSERMAP
resource within theFACILITY
class. The default value isZWESVUSR
. Permissions are set up during installation with theZWESECUR
JCL or workflow.If you customized the
ZWESECUR
JCL or workflow (the customization of zowe runtime user:// SET ZOWEUSER=ZWESVUSR * userid for Zowe started task
) and changed the default USERID, create theAPIML_GATEWAY_MAPPER_USER
property and set the value by adding a new line as in the following example:Example:
APIML_GATEWAY_MAPPER_USER=yournewuserid
Restart
Zowe&trade
.
#
Gateway timeoutsUse the following procedure to change the global timeout value for the API Mediation Layer instance.
Follow these steps:
- Open the file
<Zowe instance directory>/instance.env
. - Find the property
APIML_GATEWAY_TIMEOUT_MILLIS
, and set the value to the desired value. - Restart
Zowe&trade
.
If you require finer control, you can edit the <Zowe install directory>/components/gateway/bin/start.sh
, and modify the following properties:
apiml.gateway.timeoutMillis
This property defines the global value for http/ws client timeout.
Add the following properties to the file for the API Gateway:
Note: Ribbon configures the client that connects to the routed services.
ribbon.connectTimeout
Specifies the value in milliseconds which corresponds to the period in which API ML should establish a single, non-managed connection with the service. If omitted, the default value specified in the API ML Gateway service configuration is used.
ribbon.readTimeout
Specifies the time in milliseconds of inactivity between two packets in response from this service to API ML. If omitted, the default value specified in the API ML Gateway service configuration is used.
ribbon.connectionManagerTimeout
The HttpClient employs a special entity to manage access to HTTP connections called by the HTTP connection manager. The purpose of an HTTP connection manager is to serve as a factory for new HTTP connections, to manage the life cycle of persistent connections, and to synchronize access to persistent connections. Internally, the connections that are managed serve as proxies for real connections.
ConnectionManagerTimeout
specifies a period during which managed connections with API ML should be established. The value is in milliseconds. If omitted, the default value specified in the API ML Gateway service configuration is used.
#
CORS handlingYou can enable the Gateway to terminate CORS requests for itself and also for routed services. By default, Cross-Origin Resource Sharing (CORS) handling is disabled for Gateway routes api/v1/gateway/**
and for individual services. After enabling the feature as stated in the prodecure below, API Gateway endpoints start handling CORS requests and individual services can control whether they want the Gateway to handle CORS for them through the Custom Metadata parameters.
When the Gateway handles CORS on behalf of the service, it sanitizes defined headers from the communication (upstream and downstream). Access-Control-Request-Method,Access-Control-Request-Headers,Access-Control-Allow-Origin,Access-Control-Allow-Methods,Access-Control-Allow-Headers,Access-Control-Allow-Credentials,Origin
The resulting request to the service is not a CORS request and the service does not need to do anything extra. The list can be overridden by specifying different comma-separated list in the property APIML_SERVICE_IGNOREDHEADERSWHENCORSENABLED
in <Zowe instance directory>/instance.env
Additionally, the Gateway handles the preflight requests on behalf of the service, replying with CORS headers:
Access-Control-Allow-Methods: GET,HEAD,POST,DELETE,PUT,OPTIONS
Access-Control-Allow-Headers: origin, x-requested-with
Access-Control-Allow-Credentials: true
Access-Control-Allow-Origin: *
or a list of origins as configured by the service.
Use the following procedure to enable CORS handling.
Follow these steps:
- Open the file
<Zowe instance directory>/instance.env
. - Find the property
APIML_CORS_ENABLED
and set the value totrue
. - Restart
Zowe&trade
.
Requests through the Gateway now contain a CORS header.
#
Encoded slashesBy default, the API Mediation Layer accepts encoded slashes in the URL path of the request. If you are onboarding applications which expose endpoints that expect encoded slashes, it is necessary to keep the default configuration. We recommend that you change the property to false
if you do not expect the applications to use the encoded slashes.
Use the following procedure to reject encoded slashes.
Follow these steps:
- Open the file
<Zowe instance directory>/instance.env
. - Find the property
APIML_ALLOW_ENCODED_SLASHES
and set the value tofalse
. - Restart
Zowe&trade
.
Requests with encoded slashes are now rejected by the API Mediation Layer.
#
Connection limitsBy default, the API Gateway accepts up to 100 concurrent connections per route, and 1000 total concurrent connections. Any further concurrent requests are queued until the completion of an existing request. The API Gateway is built on top of Apache HTTP components that require these two connection limits for concurrent requests. For more information, see Apache documentation.
Use the following procedure to change the number of concurrent connections.
Follow these steps:
- Open the file
<Zowe instance directory>/instance.env
. - Find the property
APIML_MAX_CONNECTIONS_PER_ROUTE
and set the value to an appropriate positive integer. - Find the property
APIML_MAX_TOTAL_CONNECTIONS
and set the value to an appropriate positive integer.
#
Routed instance headerThe API Gateway can output a special header that contains the value of the instance ID of the API service that the request has been routed to. This is useful for understanding which service instance is being called.
The header name is X-InstanceId
, and the sample value is discoverable-client:discoverableclient:10012
. This is identical to instanceId
property in the registration of the Discovery service.
Use the following procedure to output a special header that contains the value of the instance ID of the API service.
Follow these steps:
- Open the file
<Zowe instance directory>/instance.env
. - Add the property with value
APIML_ROUTING_INSTANCEIDHEADER=true
. - Restart Zowe.
#
Distributed load balancer cacheYou can choose to distribute the load balancer cache between instances of the API Gateway. To distribute the load balancer cache, it is necessary that the caching service is running. Gateway service instances are reuqired to have the same DN (Distinguished name) on the server certificate.
Use the following procedure to distribute the load balancer cache between instances of the API Gateway.
Follow these steps:
- Open the file
<Zowe instance directory>/instance.env
. - Add the property with value
APIML_LOADBALANCER_DISTRIBUTE=true
. - Restart Zowe.
#
Replace or remove the Catalog with another serviceBy default, the API Mediation Layer contains API Catalog as a service showing available services. As the API Mediation Layer can be successfully run without this component it is possible to replace or remove the service from the Gateway home page and health checks. The following section describes the behavior of the Gateway home page and health checks.
The default option displays the API Catalog.
APIML_GATEWAY_CATALOG_ID = apicatalog
A value can also be applied to API_GATEWAY_CATALOG_ID
.
Examples:
none
Nothing is displayed on the Gateway home page and the Catalog is removed from
/application/health
alternative-catalog
An alternative to the API Catalog is displayed
metrics-dashboard
A possible dashboard that could appear in place of the API Catalog
Notes:
- If the application contains the
homePageUrl
andstatusPageRelativeUrl
, then the full set of information is displayed. - If the application contains the
homePageUrl
the link is displayed without theUP
information. - If the application contains the
statusPageRelativeUrl
thenUP
orDOWN
is displayed based on thestatusPage
without the link.
Use the following procedure to change or replace the Catalog service.
Follow these steps:
Open the file
<Zowe instance directory>/instance.env
.At the end of the file with the property
APIML_GATEWAY_CATALOG_ID
add a new line. Set the value with the following options:- Set the value to
none
to remove the Catalog service. - Set the value to the ID of the service that is onboarded to the API Mediation Layer.
- Set the value to
#
API Mediation Layer as a standalone componentYou can start the API Mediation Layer independently of other Zowe components. By default, the Gateway, Zowe System Services, and Virtual Desktop start when Zowe runs. To limit consumed resources when the Virtual Desktop or Zowe System Services are not required, it is possible to specify which components start in the context of Zowe. No change is required during the installation process to support this setup.
Once Zowe is installed, use the following procedure to limit which components start.
Follow these steps:
- Open the file
<Zowe instance directory>/instance.env
. - Find the property
ZWE_LAUNCH_COMPONENTS
and setdiscovery,gateway,api-catalog
- Restart
Zowe&trade
.
To learn more about the related section of the environment file, see Creating and configuring the Zowe instance directory. We recommend you open this page in a new tab.
#
SAF Resource CheckingThe API ML can check for the authorization of the user on certain endpoints. Access to a SAF resource is checked with ESM.
Verification of the SAF resource is provided by the following three providers:
endpoint
This is the highest priority provider, such as a REST endpoint call (ZSS or similar one). This option is disabled by default. In Zowe, ZSS has the API to check for SAF resource authorization.
native
The Native JZOS classes from Java are used to determine SAF resource access. This is the default provider.
dummy
This is the lowest priority provider. This is the dummy implementation and is defined in a file.
Note: Verification of the SAF resource uses the first available provider based on the specified priority. The default configuration resolves to the native provider.
You can select a specific provider by specifying the APIML_SECURITY_AUTHORIZATION_PROVIDER
key in the instance.env
file. Use the parameter value to
strictly define a provider. If verification is disabled, select the endpoint
option.
Follow these steps:
- Open the file
<Zowe instance directory>/instance.env
. - Add the property
APIML_SECURITY_AUTHORIZATION_PROVIDER
and set desired value. - Restart
Zowe&trade
.
Examples:
APIML_SECURITY_AUTHORIZATION_PROVIDER=endpoint
Note: To configure the endpoint
provider, add the following additional property:
APIML_SECURITY_AUTHORIZATION_ENDPOINT_ENABLED=true
APIML_SECURITY_AUTHORIZATION_PROVIDER=native
APIML_SECURITY_AUTHORIZATION_PROVIDER=dummy
To use the endpoint provider, customize the URL corresponding to the SAF resource authorization. By default, the ZSS API is configured and used.
Follow these steps:
- Open the file
<Zowe instance directory>/instance.env
. - Modify the property
APIML_SECURITY_AUTHORIZATION_ENDPOINT_URL
and set desired value. The default value for ZSS API ishttps://${ZOWE_EXPLORER_HOST}:${GATEWAY_PORT}/zss/api/v1/saf-auth
- Restart
Zowe&trade
.
#
Checking providers#
REST endpoint callThe REST provider calls the external API to retrieve information about access rights. To enable the feature outside of the mainframe, such as when running in Docker, you can use a REST endpoint call using the GET
method:
- Method:
GET
- URL:
{base path}/{userId}/{class}/{entity}/{level}
- Response:
{ "authorized": "{true|false}", "error": "{true|false}", "message": "{message}" }
Note: For more information about this REST endpoint call, see ZSS implementation.
#
NativeThe Native provider is the easiest approach to use the SAF resource checking feature on the mainframe.
Enable this provider when classes com.ibm.os390.security.PlatformAccessControl
and com.ibm.os390.security.PlatformReturned
are available on the classpath. This approach uses the following method described in the IBM documentation: method.
Note: Ensure that the version of Java on your system has the same version of classes and method signatures.
#
Dummy implementationThe Dummy provider is for testing purpose outside of the mainframe.
Create the file saf.yml
and locate it in the folder, where is application running or create file mock-saf.yml
in the
test module (root folder). The highest priority is to read the file outside of the JAR. A file (inner or outside) has to exist.
The following YAML presents the structure of the file:
safAccess: {CLASS}: {RESOURCE}: - {UserID}
Notes:
- Classes and resources are mapped into a map, user IDs into a list.
- The load method does not support formatting with dots, such as shown in the following example: Example: {CLASS}.{RESOURCE} Ensure that each element is separated.
- The field
safAccess
is not required to define an empty file without a definition. - Classes and resources cannot be defined without the user ID list.
- When a user has multiple definitions of the same class and resource, only the most privileged access level loads.