Chilkat Online Tools

unicodeC / Zoho CRM REST APIs / Revoking Tokens

Back to Collection Items

#include <C_CkHttpW.h>
#include <C_CkHttpRequestW.h>
#include <C_CkJsonObjectW.h>
#include <C_CkHttpResponseW.h>

void ChilkatSample(void)
    {
    HCkHttpW http;
    BOOL success;
    HCkHttpRequestW req;
    HCkJsonObjectW jsonFormData1;
    HCkHttpResponseW resp;

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

    http = CkHttpW_Create();

    req = CkHttpRequestW_Create();
    CkHttpRequestW_putHttpVerb(req,L"POST");
    CkHttpRequestW_putPath(req,L"/oauth/v2/token/revoke");
    CkHttpRequestW_putContentType(req,L"multipart/form-data");

    jsonFormData1 = CkJsonObjectW_Create();
    CkHttpRequestW_AddStringForUpload2(req,L"token",L"",jsonFormData1,L"utf-8",L"application/json");

    resp = CkHttpResponseW_Create();
    success = CkHttpW_HttpSReq(http,L"domain.com",443,TRUE,req,resp);
    if (success == FALSE) {
        wprintf(L"%s\n",CkHttpW_lastErrorText(http));
        CkHttpW_Dispose(http);
        CkHttpRequestW_Dispose(req);
        CkJsonObjectW_Dispose(jsonFormData1);
        CkHttpResponseW_Dispose(resp);
        return;
    }

    wprintf(L"%d\n",CkHttpResponseW_getStatusCode(resp));
    wprintf(L"%s\n",CkHttpResponseW_bodyStr(resp));


    CkHttpW_Dispose(http);
    CkHttpRequestW_Dispose(req);
    CkJsonObjectW_Dispose(jsonFormData1);
    CkHttpResponseW_Dispose(resp);

    }

Curl Command

curl -X POST
	--form 'token={{refresh-token}}'
https://domain.com/oauth/v2/token/revoke

Postman Collection Item JSON

{
  "name": "Revoking Tokens",
  "event": [
    {
      "listen": "test",
      "script": {
        "exec": [
          "if (responseCode.code === 200)",
          "{",
          "    var jsonData = JSON.parse(responseBody);",
          "    ",
          "    if (jsonData.status == \"sucess\")",
          "    {",
          "        pm.environment.set(\"refresh-token\", \"\");",
          "        pm.environment.set(\"access-token\", \"\");",
          "        pm.environment.set(\"expiry-time\", \"\");",
          "    }",
          "}"
        ],
        "type": "text/javascript"
      }
    }
  ],
  "request": {
    "auth": {
      "type": "noauth"
    },
    "method": "POST",
    "header": [
    ],
    "body": {
      "mode": "formdata",
      "formdata": [
        {
          "key": "token",
          "value": "{{refresh-token}}",
          "type": "text"
        }
      ]
    },
    "url": {
      "raw": "{{accounts-domain}}/oauth/v2/token/revoke",
      "host": [
        "{{accounts-domain}}"
      ],
      "path": [
        "oauth",
        "v2",
        "token",
        "revoke"
      ]
    },
    "description": "### Step 5: Revoking Tokens\n\nIn case if you wish to revoke the refresh_token, use the below approach."
  },
  "response": [
  ]
}