Chilkat Online Tools

C / ForgeRock Identity Cloud Collection / Step 1: Create or update assetlinks.json

Back to Collection Items

#include <C_CkHttp.h>
#include <C_CkJsonArray.h>
#include <C_CkJsonObject.h>
#include <C_CkStringBuilder.h>
#include <C_CkHttpResponse.h>

void ChilkatSample(void)
    {
    HCkHttp http;
    BOOL success;
    HCkJsonArray jarr;
    HCkJsonObject jsonObj_1;
    HCkStringBuilder sbRequestBody;
    HCkHttpResponse resp;

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

    http = CkHttp_Create();

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

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

    // [
    //   {
    //     "relation": [
    //       "delegate_permission/common.handle_all_urls",
    //       "delegate_permission/common.get_login_creds"
    //     ],
    //     "target": {
    //       "namespace": "web",
    //       "site": "https://id.mycompany.com"
    //     }
    //   }
    // ]

    jarr = CkJsonArray_Create();

    CkJsonArray_AddObjectAt(jarr,-1);
    jsonObj_1 = CkJsonArray_ObjectAt(jarr,CkJsonArray_getSize(jarr) - 1);
    CkJsonObject_UpdateString(jsonObj_1,"relation[0]","delegate_permission/common.handle_all_urls");
    CkJsonObject_UpdateString(jsonObj_1,"relation[1]","delegate_permission/common.get_login_creds");
    CkJsonObject_UpdateString(jsonObj_1,"target.namespace","web");
    CkJsonObject_UpdateString(jsonObj_1,"target.site","https://id.mycompany.com");
    CkJsonObject_Dispose(jsonObj_1);

    // Adds the "Authorization: Bearer <access_token>" header.
    CkHttp_putAuthToken(http,"<access_token>");

    sbRequestBody = CkStringBuilder_Create();
    CkJsonArray_EmitSb(jarr,sbRequestBody);

    resp = CkHttp_PTextSb(http,"PUT","https://id.mycompany.com/.well-known/assetlinks.json",sbRequestBody,"utf-8","application/json",FALSE,FALSE);
    if (CkHttp_getLastMethodSuccess(http) == FALSE) {
        printf("%s\n",CkHttp_lastErrorText(http));
        CkHttp_Dispose(http);
        CkJsonArray_Dispose(jarr);
        CkStringBuilder_Dispose(sbRequestBody);
        return;
    }

    printf("%d\n",CkHttpResponse_getStatusCode(resp));
    printf("%s\n",CkHttpResponse_bodyStr(resp));
    CkHttpResponse_Dispose(resp);


    CkHttp_Dispose(http);
    CkJsonArray_Dispose(jarr);
    CkStringBuilder_Dispose(sbRequestBody);

    }

Curl Command

curl -X PUT
	-H "Authorization: Bearer <access_token>"
	-d '[
  {
    "relation": [
      "delegate_permission/common.handle_all_urls",
      "delegate_permission/common.get_login_creds"
    ],
    "target": {
      "namespace": "web",
      "site": "https://id.mycompany.com"
    }
  }
]'
https://id.mycompany.com/.well-known/assetlinks.json

Postman Collection Item JSON

{
  "name": "Step 1: Create or update assetlinks.json",
  "request": {
    "method": "PUT",
    "header": [
    ],
    "body": {
      "mode": "raw",
      "raw": "[\n  {\n    \"relation\": [\n      \"delegate_permission/common.handle_all_urls\",\n      \"delegate_permission/common.get_login_creds\"\n    ],\n    \"target\": {\n      \"namespace\": \"web\",\n      \"site\": \"https://id.mycompany.com\"\n    }\n  }\n]",
      "options": {
        "raw": {
          "language": "json"
        }
      }
    },
    "url": {
      "raw": "{{customDomainUrl}}/.well-known/assetlinks.json",
      "host": [
        "{{customDomainUrl}}"
      ],
      "path": [
        ".well-known",
        "assetlinks.json"
      ]
    }
  },
  "response": [
  ]
}