Execute a Request Using a Generated OpenAPI Client
The usage of the OpenAPI clients is similar to the clients for OData. The OpenAPI clients consist of at least one API, which in turn has at least one function. What APIs and functions are available in a client depends on the service specification.
Executing a Request
The request execution always follows the same structure. You invoke a function of an API, optionally configure your request and then execute it against a destination:
const responseData = await MyApi.myFunction().execute(destination);
In the example above you invoke the function myFunction()
of the API MyApi
without further configuration and execute it against a destination named destination
.
The execute()
method returns the response data directly as a Promise
, if available.
Responses without response body, result in the return type Promise<void>
.
You can configure your request by setting custom headers, a custom request configuration or disabling CSRF token fetching. If you need more information than the response data, you can also get the raw response.
Passing Parameters
Often, resources are accessible under paths that require path parameters and/or query parameters and write requests often send a request body to modify resources. The clients generated by the SAP Cloud SDK OpenAPI generator require you to set the parameters that are mandatory and allow you to set those that are optional.
Path Parameters
Path parameters are always mandatory.
If path parameters are present in the path pattern for a request, e.g. '/my-resource/{resourceId}'
, those are the first mandatory arguments in the generated function, e.g. MyApi.getMyResource(resourceId)
.
The types of the arguments depend on the specification.
Their names are always camel case and the order is determined by their occurrence in the path pattern.
Query Parameters
Query parameters can be both mandatory and optional.
Query parameters are provided as an object, e.g. if you can set a limit
parameter, MyApi.getMyResource(resourceId, { limit: 10 })
.
The types of the parameters depend on the specification.
By default, the parameter names and values are URI encoded.
Their names are as specified in the original OpenAPI document.
Header Parameters
Header parameters can be both mandatory and optional.
If header parameters for a certain API function exist, they are always the last argument of the function.
Header parameters are also provided as an object, e.g. extending the example above, MyApi.getMyResource(resourceId, { limit: 10 }, { Authorization: 'my-auth-key' })
.
The types of the parameters depend on the specification.
If there are optional query parameters and required header parameters in the spec, you must pass an empty object for the query parameters if you do not intend to provide any.
This is because optional parameters cannot precede required parameters.
For example: MyApi.getMyResource(resourceId, {}, { Authorization: 'my-auth-key' })
.
Request Bodies
Request bodies can be both mandatory and optional.
The according function argument is always body
and it is always between the path and query parameters, e.g. when the body is a simple object containing a title, MyApi.updateMyResource(resourceId, { title: 'My Title' }, { lang: 'en' })
.
If the request body is optional, you have to pass undefined
, e.g. MyApi.updateMyResource(resourceId, undefined, { lang: 'en' })
.
Setting Custom Headers
The SAP Cloud SDK sets all mandatory headers by default.
To set additional headers or change the default values used in the headers, use the addCustomHeaders()
method.
You can pass an object, where the key is the name of the header and the value, well the value.
MyApi.myFunction()
.addCustomHeaders({
apikey: 'my-api-key'
})
.execute(destination);
Custom headers take precedence over default headers. The example above can be used to execute requests against the sandbox systems of the SAP Business Accelerator Hub.
Setting a Custom Request Configuration
By default, the SAP Cloud SDK uses axios as an HTTP client for executing requests.
The SAP Cloud SDK derives and configures most request options including url
, headers
, etc.
You can provide a custom request configuration to pass additional options to axios.
The example below demonstrates how to configure the response data type, typically used when downloading a file from an endpoint.
MyEntity.requestBuilder()
.getAll()
.addCustomRequestConfiguration({ responseType: 'arraybuffer' });
To ensure API consistency, the SAP Cloud SDK does not allow overriding the following options:
url
baseURL
data
headers
params
Setting a Custom Service Path
A custom service path can be manually set in the options-per-service.json
by providing a basePath
property during client generation.
It can also be adjusted per request by using the setBasePath()
method:
MyApi.myFunction().setBasePath('/base/path/to/service').execute(destination);
This will change the base path of the request.
Executing the example request above against a destination with the URL https://my.some-system.com
will result in a request against the target like this: https://my.some-system.com/base/path/to/service/myFunctionPath
, where /myFunctionPath
is the API path parameter.
Setting Middlewares
You can specify middlewares for a request via the middleware()
method on the request builder:
MyApi.myFunction().middleware(myMiddlewares).execute(destination);
The method accepts variable number of single elements as well as arrays. Middleware is a general concept used to add arbitrary enhancements to the request. A typical use case is to also add resilience to requests.
Getting a Raw Response
In addition to the execute()
method, you can execute a request using the executeRaw()
method.
It returns an HttpResponse
instance, which contains the following properties:
status
: the status code of the responseheaders
: the response headersdata
: the response bodyrequest
: the original request
Example:
const httpResponse: HttpResponse = MyEntity.requestBuilder()
.getAll()
.executeRaw(destination);
Typical cases, where you might need to use the executeRaw()
method are:
- You need additional information about the response, like the status code or response headers.
- You need additional information about the request, like payload, method, or request headers.
- The
execute()
method is omitted in some request builders because the response data cannot be deserialized by the request builder. - Debugging purposes.
Handling of Cross-Site Request Forgery Tokens
To create, update, and delete requests the SAP Cloud SDK will try to send a CSRF token. Upon execution, the request will try to fetch a token first before issuing the create request. Many services require this behavior for security reasons. However, the create request will be made without a CSRF token if none could be obtained.
Skip CSRF Token Handling
For some services, the CSRF
token is not required even for non-GET
requests.
Therefore, skipping to fetch the CSRF
token makes sense as a performance improvement.
You can disable the CSRF
token request by using the skipCsrfTokenFetching()
method like below:
const responseData = await MyApi.myFunction()
.skipCsrfTokenFetching()
.execute(destination);
Custom CSRF
Token Handling
If you need to adjust the way CSRF tokens are fetched, you can do so by using middlewares:
- Disable the token fetching to deactivate the default code.
- Add a middleware to include your custom token fetching.
The SAP Cloud SDK offers a csrf
middleware which allows to configure some basic options:
method
The HTTP method used to get a tokenURL
The URL which is called to retrieve a tokenmiddleware
Middlewares used for the token retrieval request
const responseData = await MyApi.myFunction()
.skipCsrfTokenFetching()
.middleware([csrf({ url: 'https://example.com/csrf/token/url' })])
.execute(destination);