Chilkat Online Tools

Objective-C / Salesforce Platform APIs / Update Credential

Back to Collection Items

#import <CkoHttp.h>
#import <CkoJsonObject.h>
#import <CkoStringBuilder.h>
#import <CkoHttpResponse.h>

// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

CkoHttp *http = [[CkoHttp alloc] init];
BOOL success;

// Use this online tool to generate code from sample JSON: Generate Code to Create JSON

// The following JSON is sent in the request body.

// {
//   "externalCredential": "test",
//   "authenticationProtocol": "Custom",
//   "principalName": "test",
//   "principalType": "NamedPrincipal",
//   "credentials": {
//     "testCredential": {
//       "value": "000000",
//       "encrypted": true
//     }
//   }
// }

CkoJsonObject *json = [[CkoJsonObject alloc] init];
[json UpdateString: @"externalCredential" value: @"test"];
[json UpdateString: @"authenticationProtocol" value: @"Custom"];
[json UpdateString: @"principalName" value: @"test"];
[json UpdateString: @"principalType" value: @"NamedPrincipal"];
[json UpdateString: @"credentials.testCredential.value" value: @"000000"];
[json UpdateBool: @"credentials.testCredential.encrypted" value: YES];

// Adds the "Authorization: Bearer <access_token>" header.
http.AuthToken = @"<access_token>";

CkoStringBuilder *sbRequestBody = [[CkoStringBuilder alloc] init];
[json EmitSb: sbRequestBody];

CkoHttpResponse *resp = [http PTextSb: @"PUT" url: @"https://domain.com/services/data/v{{version}}/named-credentials/credential" textData: sbRequestBody charset: @"utf-8" contentType: @"application/json" md5: NO gzip: NO];
if (http.LastMethodSuccess == NO) {
    NSLog(@"%@",http.LastErrorText);
    return;
}

NSLog(@"%d",[resp.StatusCode intValue]);
NSLog(@"%@",resp.BodyStr);

Curl Command

curl -X PUT
	-H "Authorization: Bearer <access_token>"
	-d '{
    "externalCredential": "test",
    "authenticationProtocol": "Custom",
    "principalName": "test",
    "principalType": "NamedPrincipal",
    "credentials": {
        "testCredential": {
            "value": "000000",
            "encrypted": true
        }
    }
}'
https://domain.com/services/data/v{{version}}/named-credentials/credential

Postman Collection Item JSON

{
  "name": "Update Credential",
  "request": {
    "method": "PUT",
    "header": [
    ],
    "body": {
      "mode": "raw",
      "raw": "{\n    \"externalCredential\": \"test\",\n    \"authenticationProtocol\": \"Custom\",\n    \"principalName\": \"test\",\n    \"principalType\": \"NamedPrincipal\",\n    \"credentials\": {\n        \"testCredential\": {\n            \"value\": \"000000\",\n            \"encrypted\": true\n        }\n    }\n}",
      "options": {
        "raw": {
          "language": "json"
        }
      }
    },
    "url": {
      "raw": "{{_endpoint}}/services/data/v{{version}}/named-credentials/credential",
      "host": [
        "{{_endpoint}}"
      ],
      "path": [
        "services",
        "data",
        "v{{version}}",
        "named-credentials",
        "credential"
      ]
    },
    "description": "Update a credential."
  },
  "response": [
  ]
}