Sample code for 30+ languages & platforms
Unicode C

Outlook -- List Mail Folders

See more Outlook Examples

Uses the Microsoft Graph API to list Outlook mail folders.

Note: This example requires Chilkat v9.5.0.67 or greater.

This example applies to: Exchange Online | Office 365 | Hotmail.com | Live.com | MSN.com | Outlook.com | Passport.com

Chilkat Unicode C Downloads

Unicode C
#include <C_CkHttpW.h>
#include <C_CkStringBuilderW.h>
#include <C_CkJsonObjectW.h>

void ChilkatSample(void)
    {
    BOOL success;
    HCkHttpW http;
    HCkStringBuilderW sbResponse;
    HCkJsonObjectW json;
    int i;
    int numFolders;

    success = FALSE;

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

    http = CkHttpW_Create();

    // Use your previously obtained access token here:
    // See the following examples for getting an access token:
    //    Get Microsoft Graph OAuth2 Access Token (Azure AD v2.0 Endpoint).
    //    Get Microsoft Graph OAuth2 Access Token (Azure AD Endpoint).
    //    Refresh Access Token (Azure AD v2.0 Endpoint).
    //    Refresh Access Token (Azure AD Endpoint).

    CkHttpW_putAuthToken(http,L"MICROSOFT_GRAPH_ACCESS_TOKEN");

    sbResponse = CkStringBuilderW_Create();

    // Sends:  GET /users/{id | userPrincipalName}/mailFolders
    // Note: It is also possible to use the literal string "me" for the current logged-on user.
    // For example: GET /me/mailFolders
    CkHttpW_ClearUrlVars(http);
    CkHttpW_SetUrlVar(http,L"userPrincipalName",L"chilkatsoft@outlook.com");
    success = CkHttpW_QuickGetSb(http,L"https://graph.microsoft.com/v1.0/users/{$userPrincipalName}/mailFolders",sbResponse);
    if ((success != TRUE) && (CkHttpW_getLastStatus(http) == 0)) {
        wprintf(L"%s\n",CkHttpW_lastErrorText(http));
        CkHttpW_Dispose(http);
        CkStringBuilderW_Dispose(sbResponse);
        return;
    }

    json = CkJsonObjectW_Create();
    CkJsonObjectW_LoadSb(json,sbResponse);
    CkJsonObjectW_putEmitCompact(json,FALSE);

    wprintf(L"Status code = %d\n",CkHttpW_getLastStatus(http));
    if (CkHttpW_getLastStatus(http) != 200) {
        wprintf(L"%s\n",CkJsonObjectW_emit(json));
        wprintf(L"Failed.\n");
    }

    wprintf(L"%s\n",CkJsonObjectW_emit(json));
    wprintf(L"----\n");

    // In my test case, this is the result (see below)
    // Apparently, this lists folders without listing subfolders (aka child folders)
    // There's another REST API call to list child folders.

    // To iterate over the folders:
    i = 0;
    numFolders = CkJsonObjectW_SizeOfArray(json,L"value");
    while (i < numFolders) {
        CkJsonObjectW_putI(json,i);
        wprintf(L"%s\n",CkJsonObjectW_stringOf(json,L"value[i].displayName"));
        i = i + 1;
    }

    // The output from the above loop:

    // 	Archive
    // 	Deleted Items
    // 	Drafts
    // 	Inbox
    // 	Junk Email
    // 	Outbox
    // 	Sent Items

    // ------------------------------------------------------------------------------------
    // The raw JSON response: 

    // {
    //   "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('chilkatsoft%40outlook.com')/mailFolders",
    //   "value": [
    //     {
    //       "id": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAG8XunwAAAA=",
    //       "displayName": "Archive",
    //       "parentFolderId": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEIAAAA",
    //       "childFolderCount": 0,
    //       "unreadItemCount": 0,
    //       "totalItemCount": 0
    //     },
    //     {
    //       "id": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEKAAAA",
    //       "displayName": "Deleted Items",
    //       "parentFolderId": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEIAAAA",
    //       "childFolderCount": 0,
    //       "unreadItemCount": 0,
    //       "totalItemCount": 0
    //     },
    //     {
    //       "id": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEPAAAA",
    //       "displayName": "Drafts",
    //       "parentFolderId": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEIAAAA",
    //       "childFolderCount": 0,
    //       "unreadItemCount": 0,
    //       "totalItemCount": 0
    //     },
    //     {
    //       "id": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEMAAAA",
    //       "displayName": "Inbox",
    //       "parentFolderId": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEIAAAA",
    //       "childFolderCount": 2,
    //       "unreadItemCount": 0,
    //       "totalItemCount": 4
    //     },
    //     {
    //       "id": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEiAAAA",
    //       "displayName": "Junk Email",
    //       "parentFolderId": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEIAAAA",
    //       "childFolderCount": 0,
    //       "unreadItemCount": 0,
    //       "totalItemCount": 0
    //     },
    //     {
    //       "id": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgELAAAA",
    //       "displayName": "Outbox",
    //       "parentFolderId": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEIAAAA",
    //       "childFolderCount": 0,
    //       "unreadItemCount": 0,
    //       "totalItemCount": 0
    //     },
    //     {
    //       "id": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEJAAAA",
    //       "displayName": "Sent Items",
    //       "parentFolderId": "AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEIAAAA",
    //       "childFolderCount": 0,
    //       "unreadItemCount": 0,
    //       "totalItemCount": 14
    //     }
    //   ]
    // }
    // 

    // ------------------------------------------------------------------------------------------------------
    // This example applies to: Exchange Online | Office 365 | Hotmail.com | Live.com | MSN.com | Outlook.com | Passport.com
    // 
    // The Microsoft Graph Outlook Mail API lets you read, create, and send messages and attachments, 
    // view and respond to event messages, and manage folders that are secured by Azure Active Directory 
    // in Office 365. It also provides the same functionality in Microsoft accounts specifically 
    // in these domains: Hotmail.com, Live.com, MSN.com, Outlook.com, and Passport.com.


    CkHttpW_Dispose(http);
    CkStringBuilderW_Dispose(sbResponse);
    CkJsonObjectW_Dispose(json);

    }