Chilkat Online Tools

C++ / Microsoft Graph / Get list items titled "Contoso Home"

Back to Collection Items

#include <CkHttp.h>
#include <CkJsonObject.h>
#include <CkHttpResponse.h>

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

    CkHttp http;
    bool success;

    CkJsonObject queryParams;
    queryParams.UpdateString("$filter","fields/Title eq 'Contoso Home'");

    http.SetRequestHeader("Content-Type","application/json");
    http.SetRequestHeader("Prefer","HonorNonIndexedQueriesWarningMayFailRandomly");
    // Adds the "Authorization: Bearer <access_token>" header.
    http.put_AuthToken("<access_token>");

    CkHttpResponse *resp = http.QuickRequestParams("GET","https://graph.microsoft.com/v1.0/sites/root/lists/{{ListId}}/items",queryParams);
    if (http.get_LastMethodSuccess() == false) {
        std::cout << http.lastErrorText() << "\r\n";
        return;
    }

    std::cout << resp->get_StatusCode() << "\r\n";
    std::cout << resp->bodyStr() << "\r\n";
    delete resp;
    }

Curl Command

curl -G -d "$filter=fields%2FTitle%20eq%20%27Contoso%20Home%27"
	-H "Authorization: Bearer <access_token>"
	-H "Content-Type: application/json"
	-H "Prefer: HonorNonIndexedQueriesWarningMayFailRandomly"
https://graph.microsoft.com/v1.0/sites/root/lists/{{ListId}}/items

Postman Collection Item JSON

{
  "name": "Get list items titled \"Contoso Home\"",
  "event": [
    {
      "listen": "test",
      "script": {
        "exec": [
          "try {\r",
          "    if (responseBody.indexOf(\"InvalidAuthenticationToken\") !== -1)\r",
          "    {\r",
          "        console.log(\"You need to run *On behalf of a User | Get User Access Token* request first.\");\r",
          "    }\r",
          "    else\r",
          "    {\r",
          "        if (pm.response.status === \"Forbidden\")\r",
          "        {\r",
          "            console.log(\"You need to add user delegated permissions in your application to at least *Sites.Read.All* in portal.azure.com and then consent as user or Grant admin consent in portal. And re-run *On behalf of a User | Get User Access Token* request to update access token. \");\r",
          "        }\r",
          "    }\r",
          "}\r",
          "catch (e) {\r",
          "    console.log(e);\r",
          "}\r",
          ""
        ],
        "type": "text/javascript"
      }
    }
  ],
  "request": {
    "method": "GET",
    "header": [
      {
        "key": "Content-Type",
        "type": "text",
        "value": "application/json"
      },
      {
        "key": "Prefer",
        "value": "HonorNonIndexedQueriesWarningMayFailRandomly",
        "type": "text"
      }
    ],
    "url": {
      "raw": "https://graph.microsoft.com/v1.0/sites/root/lists/{{ListId}}/items?$filter=fields/Title eq 'Contoso Home'",
      "protocol": "https",
      "host": [
        "graph",
        "microsoft",
        "com"
      ],
      "path": [
        "v1.0",
        "sites",
        "root",
        "lists",
        "{{ListId}}",
        "items"
      ],
      "query": [
        {
          "key": "$filter",
          "value": "fields/Title eq 'Contoso Home'"
        }
      ]
    }
  },
  "response": [
  ]
}