Authentication Types in Connected System

Certified Lead Developer

We have a requirement to call web API which uses Bearer Token authentication type and it requires client id and secret in the Header.

Before calling this API we need to get the access token using oAuth endpoint, this endpoint has authentication type as Basic Auth and it requires same client id and secret in the Header.

1. For OAuth endpoint, we have created a connected system (A) with the Basic Authentication using username and password. - Works fine.

2. For the primary API, we have created another connected system (B) with the following information.

a. Base URL: <Base URL>.

b. Authentication: None

3. Created an Integration object which uses connected system B and has following parameters in the Headers.

a. Authorization: <Token received in step #1, passed as rule input>

b. X-IBM-Client-Id: <client id, passed as constant >

c. X-IBM-Client-Secret: <client secret, passed as constant>

The above setup works fine however as per our security compliance we cannot have a secret in the constant which is non-masked.

Is there a way for us to use connected system which supports the masked password and secret to achieve above scenario?

  Discussion posts and replies are publicly visible

Parents Reply
  • If we provide the id and secret in the Header

    Isn't the header passed over as plaintext anyway - the way you phrase it (and pardon me being slightly less familiar with this auth method) but it sounds as if your setup itself is what's violating your security requirements (i.e. the secret is being passed as header, which is plaintext, which is not allowed - this would still be true whether you figure out a way to mask the value in the configuration dialog, no?  Or do I have something confused here?)

Children