When you create an API using the API Publisher, you can specify the endpoint of the API backend implementation of it in the Implement tab. Here, under the “show more options” link, you have an option the Implement tab as Production and Sandbox endpoints.
If this endpoint is secured, there is an option for you to set the auth type and credentials for the endpoint under Show More Options.
Here you can click the Show More Options link to select the endpoint security scheme. If you select it as “Secured”select Secured, you are prompted to select the authentication type for the endpoint and also to give its credentials. You need to
Then select the endpoint authentication type according to the authentication scheme that is supported by your endpoint. If your endpoint supports digest authentication, you can select the “Digest Auth” option the Digest Auth option from the drop down list .
Digest Authentication applies and give your credentials.
To give more context on the above scenario, a secured endpoint is where we have access-protected resourses. We have to specify the username and the password when a request is sent to a secured endpoint. The endpoint authentication mechanism can either be Basic Authentication or Digest Authentication. They differ only in how the credentials are commnicated with and how access is granted by the backend server.
The Endpoint Auth Type selected should match with the authentication mechanism supported by the secured endpoint.
Digest Authentication applies a hash function to the username and the password before sending them over the network. It It is basically a process of applying MD5 cryptographic hashing with the usage of nonce values to prevent replay attacks. It is a simple challenge-response authentication mechanism that may be used by a server to challenge a client request and by a client to provide authentication infromation for the secured endpoint.
This approach is safer than Basic Authentication, which uses unencrypted base64 encoding instead of a hashing mechanism.
The following is the sample fromat of the header that will be sent to the backend when Digest Auth is specified as the endpoint auth type. The attributes added to the authorization header depends on the challenge header sent from the backend server.
Authorization: Digest username="Admin", realm="[email protected]", nonce="dcd98b7102dd2f0e8b11d0f600bfb0c093", uri="/dir/index.html", qop=auth, nc=00000001, cnonce="0a4f113b",