API Docs: https://sap.github.io/cloud-sdk/api/3.8.1
- [eslint-config] Update eslint plugins (d6bbd3210)
API Docs: https://sap.github.io/cloud-sdk/api/3.8.0
- [connectivity] Remove unused internal functionality around JWT property access, like
userFromJwt
(removed) andaudiences
(changed). (693cd655f)
- [mail-client] Add Support for
Location ID
in destinations of typeMAIL
(8516b7f04)
- [generator] Don't generate
delete()
,update()
, andgetByKey()
methods in the RequestBuilder of an entity without keys.- @sap-cloud-sdk/[email protected]
- @sap-cloud-sdk/[email protected]
- @sap-cloud-sdk/[email protected]
- @sap-cloud-sdk/[email protected]
- @sap-cloud-sdk/[email protected] (34ef77a1c)
API Docs: https://sap.github.io/cloud-sdk/api/3.7.0
- [odata-common, odata-v2, odata-v4, generator, generator-common] Do not send
null
values in the request payload for properties that are not set while creating or updating an entity. [Fixed Issue] FixRangeError: Maximum call stack size exceeded
error that occurs when updating an entity after callinggetByKey
. (bdcf14f85)
API Docs: https://sap.github.io/cloud-sdk/api/3.6.0
- [connectivity] Proxy configuration is no longer realized through a proxy agent, but with the native axios proxy setting instead. (025b6aa2c)
- [connectivity] Use axios native proxy, instead of proxy agent, which causes connection issues for write requests on SAP Cloud Connector. (025b6aa2c)
- [http-client] Fix CSRF token fetching against OnPremise systems. (c2a2987c5)
API Docs: https://sap.github.io/cloud-sdk/api/3.5.0
- [connectivity] Compare
selectionStrategy
inDestinationFetchOptions
based on value instead of reference. (7ed5ceb52) - [connectivity] Fix destination caching for destinations from service bindings. The destinations are not cached repeatedly. The function
getDestinationFromServiceBinding()
returnsundefined
for destinations which have expired JWTs. (bf54df09b) - [connectivity] Support destinations of type
ClientCertificateAuthentication
without password.- @sap-cloud-sdk/[email protected]
- @sap-cloud-sdk/[email protected] (2277f9443)
- [odata-common, odata-v2, odata-v4] Fix OData v2 serialization for
Edm.Decimal
to serialize tostring
. (ee7477ce2)
API Docs: https://sap.github.io/cloud-sdk/api/3.4.0
- [connectivity] Deprecate
destinationForServiceBinding()
andPartialDestinationFetchOptions
. UsegetDestinationFromServiceBinding()
andServiceBindingTransformOptions
instead. (bde64634d)
- [connectivity] Always add a name to destinations from service bindings created with
getDestinationFromServiceBinding()
. (db0780f1b) - [connectivity] Support forwarding of auth tokens for destinations from the destination service, service bindings and environment variables. (bde64634d)
- [odata-common, odata-v4] Serialize properties of type "Edm.Decimal" to numbers when they are within the safe range and strings when they are not. (431d2a542)
API Docs: https://sap.github.io/cloud-sdk/api/3.3.0
-
[connectivity] The
expiresIn
property ofauthTokens
on aDestination
can be undefined. (c09b1d06f) -
[connectivity] Deprecate
getAgentConfig()
:- Temporarily use replacement function
getAgentConfigAsync()
. - Rename
getAgentConfigAsync()
togetAgentConfig()
in next major version. (36a01f775)
- Temporarily use replacement function
- [connectivity] Add option to cache mTLS certificates. (36a01f775)
- [connectivity] Do not rely on XSUAA service when caching service tokens. Cache keys are now based on service credentials URL. (0583836bc)
- [connectivity] Do not rely on the XSUAA service binding to retrieve tenant information when registering destinations. If tenant is unknown and no binding is found, set it to a default value (
'tenant_id'
). (8f54207b6) - [connectivity] Read mTLS certificates asynchronously. (36a01f775)
- [connectivity] Remove dependency to XSUAA service binding when checking whether a JWT was issued by XSUAA for destination retrieval. Now, the
ext_attr.ehancer
property is checked. (6b58354e8) - [http-client] Do not set default tenant ID in the context of middlewares, if the tenant ID is unknown. In those cases it will be
undefined
from now on. (8f54207b6)
API Docs: https://sap.github.io/cloud-sdk/api/3.2.0
- [connectivity] Enable the use of mTLS certificates for registered destinations on CloudFoundry. (616d77b85)
- [connectivity] Set the default validity time of the client credentials token cache to 5 minutes instead of never expiring. (782b9e37e)
- [connectivity, http-client] Forward the user JWT irrespective of the destination authentication type when
forwardAuthToken
is set to true on a destination (56c3f70f4) - [http-client] Improve CSRF token fetching for large requests. (73ff0ab03)
- [odata-common] Remove encoding of keys in the
getEntityKeys()
as it should only happen once ingetResourcePathForKeys()
.Fixes the errorvalue.format is not a function
when executing requests for entities withEdm.Date
type key property. (aa1a4bdb0) - [resilience] Fix parsing error when the last response in a chain of retries returned undefined.
- @sap-cloud-sdk/[email protected] (234675fc3)
API Docs: https://sap.github.io/cloud-sdk/api/3.1.1
- [resilience] Fix transpilation on OData generation, where types for 'opossum' could not be found.
- @sap-cloud-sdk/[email protected] (166a16d82)
API Docs: https://sap.github.io/cloud-sdk/api/3.1.0
- [connectivity] The combination of
iss
andjwt
is now supported when fetching destinations. When both properties are set, theiss
property is no longer ignored. (28b7af86f)
- [connectivity] Add support for authentication type
NoAuthentication
on-premise destinations. (039412e59) - [connectivity] Allow combination of
iss
anjwt
when fetching a destination. In this case theiss
URL will be used to fetch the destination service token andjwt
will be used for thex-user-token
header of user based authentication types. (28b7af86f)
- [odata-common] Adjust
FromJsonType
to stricter typings in TypeScript 5. (cc8425abc)
API Docs: https://sap.github.io/cloud-sdk/api/3.0.2
- [odata-common, odata-v2, odata-v4] The
ActionFunctionImportRequestBuilderBase
has an additional mandatory type parameter to pass the according (de-)serializer type. This was missing previously due to a bug. (2fa8c36a6)
- [connectivity] Fix the
The proxy configuration is undefined
error for OnPremMAIL
destinations by removing theisHttpDestination
check when adding proxyConfiguration to the destination object.- @sap-cloud-sdk/[email protected]
- @sap-cloud-sdk/[email protected] (47fc7278d)
- [mail-client] Fix error
Greeting never received
when sending emails to On-Premise mail servers. The_readableListening
property of socket is set totrue
to allow nodemailer to receive SMTP greeting messages. (47fc7278d) - [mail-client] Fix
Invalid greeting
error from nodemailer by removing thetransport.verify
function call. (be04dafc2) - [odata-common, odata-v2, odata-v4] Fix batch requests to accept only functions or actions. (2fa8c36a6)
API Docs: https://sap.github.io/cloud-sdk/api/3.0.1
- [resilience] Deprecate erroneously exposed
circuitBreakerHttp()
function in favor ofcircuitBreaker()
.- @sap-cloud-sdk/[email protected] (fcab06c4b)
- [generator-common] Improve logs when generating OData clients without package.json
- @sap-cloud-sdk/[email protected] (c78c16ddf)
API Docs: https://sap.github.io/cloud-sdk/api/2.10.0
- [odata-common, odata-v2, odata-v4] Changed constructor argument of class
EntityBase
fromschema
to_entityApi
. (144ff66f4)
- [openapi-generator] Add
force
option torm
commands, when settingclearOutputDir
to true. (f76da3060)
- [odata-v2, odata-v4] Fix the "entity generic type" of the "delete request builder". (f76da3060)
- [generator, openapi-generator] Show detailed error message of compilation errors instead of
[object Object]
. (f76da3060) - [generator-common] Show detailed error message of compilation errors instead of
[object Object]
.- @sap-cloud-sdk/[email protected] (f76da3060)
API Docs: https://sap.github.io/cloud-sdk/api/2.11.0
- [odata-common] Add
getBatchReference()
andsetBatchId()
in request builders to use the batch ID as a reference to an entity in a batch request changeset. Batch reference are available increate
,delete
,getByKey
,update
andactions/functions
request builder. (79e0fe811) - [odata-v4, generator] Support parsing and generating OData bound functions and actions in OData v4 (8ea28151b)
- [generator, openapi-generator, generator-common] Generated sources are formatted using prettier with default config. Use the CLI option
prettierConfigPath
to provide a custom config. (74e14427a)
- [odata-common] Change the place where batch ID is generated from on serialization to request creation. (79e0fe811)
API Docs: https://sap.github.io/cloud-sdk/api/2.7.1
- [mail-client] Fix proxy authorization for sending emails.
- @sap-cloud-sdk/[email protected]
- @sap-cloud-sdk/[email protected] (e7fa8d35)
API Docs: https://sap.github.io/cloud-sdk/api/2.5.0
- [odata-common, generator] Change
Edm.String
,Edm.Boolean
andEdm.Guid
to be orderable to supportlt
/lessThan()
,le
/lessOrEqual()
,gt
/greaterThan()
, andge
/greaterOrEqual
operators. Re-generate odata services to adopt the changes. (c3166ff6) - [util] Stop using
VCAP_SERVICES
to determine the log format. UsesetLogFormat
andsetGlobalLogFormat
to specify the log format. By default, the log format is set tokibana
forNODE_ENV=production
andlocal
otherwise. (89f1c423)
- [http-client] Fix the
executeHttpRequest
function, so it accepts the same parameters as in version 1. [Compatibility Note] Deprecate one overload of theexecuteHttpRequest
function, that acceptsHttpRequestConfigWithOrigin
as a parameter. Use the new functionexecuteHttpRequestWithOrigin
as replacement. [New Functionality] Support defining header options and query parameter options with origins. (9481ec69)
API Docs: https://sap.github.io/cloud-sdk/api/2.4.0
- [connectivity] Only log the successful retrieval of destinations on the
info
log level, log everything else is on thedebug
orwarn
level. (04726a35) - [connectivity] Mark the function
noDestinationErrorMessage
as internal API. (0a008674) - [odata-v4] Mark the function
uriConverter
as internal API. (0a008674) - [eslint-config] Switch the following
jsdoc
related levels fromwarn
toerror
:jsdoc/check-param-names
jsdoc/require-description-complete-sentence
jsdoc/require-jsdoc
jsdoc/require-param
jsdoc/require-returns
(0a008674)
- [connectivity] Support self-signed certificate using the
trustStore
property of the destination object. (0a008674)
- [connectivity] Reduce default log output on the
info
level significantly. (04726a35) - [http-client] Reduce default log output on the
info
level significantly. [Compatibility Note] Only log the successful retrieval of destinations on theinfo
log level, log everything else is on thedebug
orwarn
level. (04726a35)
- [util] Fix a bug in the implementation of the trim method. (0a008674)
API Docs: https://sap.github.io/cloud-sdk/api/2.6.0
- [odata-v4, temporal-de-serializers] Adjust parsing of
Edm.Date
,Edm.DateTimeOffset
,Edm.Time
, andEdm.Duration
to be closer to the OData v4 specification. There may be loss of precision if using the default (de-)serializers with high-precision fractional seconds. (de851289) - [generator] Deprecate generator option
versionInPackageJson
. If you need to set the version, use the newinclude
option to add your ownpackage.json
file instead. (069aa168) - [generator] The hidden generator option
additionalFiles
is renamed toinclude
. (069aa168)
- [connectivity] Support JWTs without a
JKU
property. (cb598c16) - [connectivity] Add interface
DestinationCacheInterface
and methodsetDestinationCache
to support implementation of custom destination cache. (09094607) - [connectivity] Fetch client credential token for destinations created by service bindings. (93d41281)
- [generator] New generator option
include
which allows to add files to generated packages. (069aa168)
- [http-client] Make
requestConfig
ofOriginOptions
optional. (e46bb51d)
- [connectivity] Fix
getDestination()
to allow passing an async transform functionserviceBindingTransformFn
inoptions
. The transform function can also be passed byexecute()
,executeHttpRequest()
,executeRaw()
, etc. [Compatibility Note] RenametransformationFn
intoserviceBindingTransformFn
inDestinationForServiceBindingsOptions
to avoid ambiguity and make the function async. (8fdfebd6) - [http-client] Fix the
executeHttpRequest
/executeHttpRequestWithOrigin
function, so the warning is only shown when overwriting headers by using custom headers. (e44c214a) - [odata-common, odata-v4, temporal-de-serializers] Fix parsing of
Edm.DateTimeOffset
with high-precision fractional seconds and edge-cases like 5-digit years. (de851289) - [odata-common, generator] Allow OData service to contain an entity name 'entity'. (0675ee3b)
- [odata-v2] Support negative epoch timestamps in serialization. (9ffe0824)
API Docs: https://sap.github.io/cloud-sdk/api/2.7.0
- [openapi-generator] Support globs in the
input
option. (3f70b0c9)
- [connectivity] Support consumption of the XSUAA API via destinations. (010a46fa)
- [connectivity] Fix a breaking change of
serviceToken
introduced in 2.0, so it acceptsXsuaaServiceCredentials
again as an option. (3bff42e1)
API Docs: https://sap.github.io/cloud-sdk/api/2.8.0
- [eslint-config] Activated the eslint rule 'check-tag-names' to allowed jsdoc tags. If you use custom tags add them via the 'definedTags' in the eslint options. (15e9ef4b)
- [generator] Deprecated
generateNpmrc
cli option. This option was only used to configure the now defunct npm registry hosted by SAP. It now has no effect anymore and should be removed in all invocations of the generator cli. (15e9ef4b) - [generator, openapi-generator, generator-common] Description for package.json in a generated client has changed. (15e9ef4b)
- [mail-client] Support defining the strategy of sending emails. By default, the emails are sent "in parallel" and can be set to "in sequential". (15e9ef4b)
- [odata-common, generator] Allow function imports using GET http method in batch requests. (15e9ef4b)
- [connectivity] Reduce default logs for failing requests in @sap-cloud-sdk/http-client.
- @sap-cloud-sdk/[email protected] (15e9ef4b)
- [connectivity] Remove last explicit references to 'VCAP_SERVICES' and replace them with '@sap/xsenv'. (15e9ef4b)
- [connectivity] Fix that unparsable destinations in the subaccount prevent other destinations from beeing fetched. (15e9ef4b)
API Docs: https://sap.github.io/cloud-sdk/api/2.9.0
- [connectivity] Support fetching all subaccount- and service instance destinations from the destination service simultaneously. (24029503)
- [mail-client] Expose SMTP transport options of
nodemailer
. (d1bf2dee) - [util] Add method
setGlobalTransports
to support setting custom transport globally. (4c51d3dc)
- [odata-common] Make OderBy() set in ascending order by default. (f62eb0d3)
API Docs: https://sap.github.io/cloud-sdk/api/3.0.0
- [connectivity] The generic types of
JwtKeyMapping
is simplified so the second type argumentJwtKeysT
are always strings. (fde964e37) - [connectivity] The
Protocol
enum was replaced with a string literal union type. Now, instead of passingProtocol.HTTPS
pass 'https'. (fde964e37) - [connectivity, http-client, openapi, odata-common, odata-v2, resilience] Remove the options
timeout
andenableCircuitBreaker
from all BTP service interactions i.e. destination and token fetching. (fde964e37) - [connectivity, http-client, mail-client, openapi, odata-common, odata-v2, odata-v4, eslint-config, generator, test-util, util, openapi-generator, generator-common, temporal-de-serializers, resilience] Switch the compilerOptions.module to
Node16
instead ofCommonJS
for better interoperability with ES modules. See the TypeScript handbook for technical details if needed. (fde964e37) - [connectivity] The enum
IsolationStrategy
was replaced with a string literal union type of the same name. Use 'tenant' and 'tenant-user' instead ofIsolationStrategy.Tenant
andIsolationStrategy.Tenant_User
. (fde964e37) - [connectivity, http-client, odata-common] ] The
url
property inDestination
is now optional as destinations of typeMAIL
do not have a URL. (fde964e37) - [http-client, openapi, odata-common] Remove
timeout()
method from the request builders and thetimeout
options from theexecuteHttpRequest()
function. Visit the documentation portal to see how to add a timeout using middlewares. (fde964e37) - [http-client] Removed overload of executeHttpRequest
The overload, that accepted
HttpRequestConfigWithOrigin
as a parameter, is removed and replaced by the functionexecuteHttpRequestWithOrigin
. (fde964e37) - [odata-common, generator, util] By default, generation of OData clients fails if a service path cannot be determined. Either provide
servicePath
value in theoptions-per-service.json
or setskipValidation
to true, in which case,/
will be used. (fde964e37) - [odata-common] The constructor of
ODataRequestConfig
was changed so that the third parameter cannot be astring
anymore. Passing in a string which was then interpreted as the value for theContent-Type
HTTP header was deprecated. The type of the parameter is nowRecord<string, any>
, and if only want to set theContent-Type
HTTP header you can do so by passing{'content-type': 'some-value'}
to the constructor. (fde964e37) - [odata-common] The constructor of the entity API is private to avoid accidental usage. Use the service object to get a API instance. (fde964e37)
- [odata-common, generator, openapi-generator] The
serviceMapping
option of the OData generator has been renamed tooptionsPerService
. The mapping file,service-mapping.json
has also been renamed tooptions-per-service.json
. By default, an options file will not be generated. (fde964e37) - [odata-common] Setting custom fields in
fromJson
through the_customFields
property has been removed. Add custom properties to your JSON object instead. (fde964e37) - [generator] The options per service behavior is now the same as for the OpenApi generator. For details on how to migrate and what has change look at the migration guide. (fde964e37)
- [generator] The deprecated
forceOverwrite
option of the generator is removed. Use theoverwrite
option instead. [Compatibility Note] The deprecatedgeneratePackageJson
option of the generator is removed. Use thepackageJson
option instead. [Compatibility Note] The deprecatedwriteReadme
option of the generator is removed. Use thereadme
option instead. [Compatibility Note] The deprecatedprocessesJsGeneration
option of the generator is removed. Use thetranspilationProcesses
option instead. [Compatibility Note] The internal optionssdkAfterVersionScript
,s4HanaCloud
andpackageVersion
of the generator are removed. These were hidden options never meant for external usage and there is no replacement. [Compatibility Note] The deprecatedgenerateNpmrc
option of the generator is removed. Use theinclude
option to add a.npmrc
to the generated code if needed. (fde964e37) - [generator] Add
verbose
generator option. By default, only error and warning logs will be displayed. Ifverbose
is set totrue
, all logs will be displayed. (fde964e37) - [generator] The
generateJs
option has been replaced with thetranspile
option. Transpilation is not enabled by default. (fde964e37) - [generator] The command line argument
inputDir
of the OData generator is renamed toinput
. The newinput
options accepts now also file paths and glob patterns. (fde964e37) - [generator] The OData generator won't automatically rename identifiers to avoid name conflicts.
The generation process will fail if identifiers have conflicting names.
Switch on the
skipValidation
flag if you want to generate despite name conflicts and are okay with changed identifier names to avoid conflicts. (fde964e37) - [generator, openapi-generator, generator-common] Removed the option
versionInPackageJson
from the OData and OpenAPI generator. If the optionpackageJson
is enabled now apackage.json
with a default version1.0.0
is created. If necessary use theinclude
option to add apackage.json
with a custom value. [Compatibility Note] Removed the optionlicenseInPackageJson
from the OData and OpenAPI generator. If the optionpackageJson
is enabled now apackage.json
with a default licenseUNLICENSED
is created. If necessary use theinclude
option to add apackage.json
with a custom value. (fde964e37) - [generator, openapi-generator] Rename servicePath to basePath. (fde964e37)
- [generator] The option
generateCSN
is removed. There is no replacement. (fde964e37) - [generator] The type for paths in the
GeneratorOptions
is changed fromfs.PathLike
tostring
. In case you passed a buffer object please resolve it to a string before passing it to the SAP Cloud SDK. (fde964e37) - [generator, openapi-generator, generator-common] The two generators use the same CLI parsing code now, aligning the way paths are resolved.
In case you experience problems with the new logic, enable the
verbose
flag to investigate the new paths. (fde964e37) - [util] The function
variadicArgumentToArray
is replaced by the functiontransformVariadicArgumentToArray
. (fde964e37) - [util] The field
logger
on the interfaceLoggerOptions
was not used and is removed from the interface. (fde964e37) - [openapi-generator] The internal option
packageVersion
of the OpenAPI generator is removed. (fde964e37) - [openapi-generator]
tsConfig
option has been renamed totsconfig
. (fde964e37) - [generator-common] The generator does not create
d.ts.map
files per default anymore. If you need them include a customtsconfig.json
. [Compatibility Note] All SAP Cloud SDK packages ship withoutd.ts.map
files from now on. Modern IDEs don't require those files for code navigation, thus they are removed to decrease download size of the SDK. (fde964e37)
- [connectivity] Support
OAuth2RefreshToken
authentication type (fde964e37) - [connectivity] Add a
retry
option in theDestinationFetchOption
. Enable this options if the token exchange done by the destination service is unstable. (fde964e37) - [connectivity, resilience] Add
ResilienceOptions
andresilience()
function. The function returns an array of middlewares based on the provided options. (fde964e37) - [http-client, resilience] The request configuration used in the final request is now part of the middleware context.
User can implement middlewares to change request properties like
headers
using this reference in the middleware context. The request configuration contains theurl
,headers
and all other properties of the HTTP request. (fde964e37) - [http-client, openapi, odata-common] Introduce the middleware on the request builders and http-client. Visit the documentation portal to see how to use middlewares. (fde964e37)
- [generator, generator-common] Introduced options
transpile
andtsconfig
to configure transpilation for generated OData clients. (fde964e37)
- [connectivity] Replace
Protocol
enum with a string literal union type. (fde964e37) - [connectivity] Replace
IsolationStrategy
enum with union type. (fde964e37) - [generator] Align naming rules for operations and properties in OData clients by removing
_
prefix (fde964e37)
- [connectivity] Fix the combination of providing the
iss
together withOnPremise
basic destinations. (fde964e37) - [odata-v2] Allow to update OData v2 entities to
null
. Fixes 3204. (fde964e37) - [generator] Allow OData service to contain an entity name 'Service'. (fde964e37)
- [generator] Now links to the correct generator binary. (fde964e37)