OneSDK interprets the map to fulfill the required usecase. This often requires making HTTP requests with authorization. Thus the user needs to provide Superface with the right secrets to access the capability exposed by the API.
The only purpose of user secrets within Superface is to authorize the user against the API. Superface does not use the secrets in any other way.
Secrets are provided to the OneSDK through options
argument of the perform
function.
OneSDK applies secrets according to security requirements specified in the relevant map. These secrets are applied to the request body right before the request is executed.
Once the request is executed no secrets are accessed until another request is to be prepared.
Another aspect to consider is logging. Logging is disabled by default. When enabled, logging may leak user secrets, so an appropriate logging level should be selected to only expose as much information as is secure in given context.