PHP ActiveX
PHP ActiveX
Outlook -- Create Map of Folder Paths to IDs
See more Outlook Examples
Recursively descends folders and creates a hashtable of folder paths to IDs. This can be done once at the start of your program (or even less if the map is persisted to a file or database).The reason this is necessary is because folder ID's need to be passed to the Outlook API, and an application will typically be working with folder paths.
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 PHP ActiveX Downloads
<?php
$success = 0;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
$http = new COM("Chilkat.Http");
// Our folder path --> ID map will be stored in this hash table.
$folderMap = new COM("Chilkat.Hashtable");
// 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).
$http->AuthToken = 'MICROSOFT_GRAPH_ACCESS_TOKEN';
$sbResponse = new COM("Chilkat.StringBuilder");
// Begin by getting the top-level folders.
$http->ClearUrlVars();
$http->SetUrlVar('userPrincipalName','chilkatsoft@outlook.com');
$success = $http->QuickGetSb('https://graph.microsoft.com/v1.0/users/{$userPrincipalName}/mailFolders',$sbResponse);
if (($success != 1) and ($http->LastStatus == 0)) {
print $http->LastErrorText . "\n";
exit;
}
$json = new COM("Chilkat.JsonObject");
$json->LoadSb($sbResponse);
$json->EmitCompact = 0;
print 'Status code = ' . $http->LastStatus . "\n";
if ($http->LastStatus != 200) {
print $json->emit() . "\n";
print 'Failed.' . "\n";
}
// This is our queue/stack of unprocessed folder ID's
// The recursive nature of this example is that we get the
// child folders for each folder ID in the idQueue, which may
// cause additional ID's to be added. We continue until the idQueue
// is empty.
$idQueue = new COM("Chilkat.StringArray");
$sbFolderPath = new COM("Chilkat.StringBuilder");
$sbQueueEntry = new COM("Chilkat.StringBuilder");
// Prime the map and idQueue with the top-level folders.
$i = 0;
$numFolders = $json->SizeOfArray('value');
while ($i < $numFolders) {
$json->I = $i;
$folderName = $json->stringOf('value[i].displayName');
$folderId = $json->stringOf('value[i].id');
$sbFolderPath->SetString('/');
$sbFolderPath->Append($folderName);
$folderPath = $sbFolderPath->getAsString();
$folderMap->AddStr($folderPath,$folderId);
print $folderPath . ' --> ' . $folderId . "\n";
// Push the folder path + id onto the idQueue.
$sbQueueEntry->Clear();
$sbQueueEntry->SetNth(0,$folderPath,'|',0,0);
$sbQueueEntry->SetNth(1,$folderId,'|',0,0);
$idQueue->Append($sbQueueEntry->getAsString());
$i = $i + 1;
}
// Initial output:
// /Archive --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAG8XunwAAAA=
// /Deleted Items --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEKAAAA
// /Drafts --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEPAAAA
// /Inbox --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEMAAAA
// /Junk Email --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEiAAAA
// /Outbox --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgELAAAA
// /Sent Items --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEJAAAA
//
// Process the idQueue until it becomes empty. This is the recursive loop.
while ($idQueue->Length > 0) {
$sbQueueEntry->SetString($idQueue->getString(0));
$idQueue->RemoveAt(0);
$parentFolderPath = $sbQueueEntry->getNth(0,'|',0,0);
$parentFolderId = $sbQueueEntry->getNth(1,'|',0,0);
$http->SetUrlVar('id',$parentFolderId);
$success = $http->QuickGetSb('https://graph.microsoft.com/v1.0/users/{$userPrincipalName}/mailFolders/{$id}/childFolders',$sbResponse);
if (($success != 1) and ($http->LastStatus == 0)) {
print $http->LastErrorText . "\n";
exit;
}
$json->LoadSb($sbResponse);
if ($http->LastStatus != 200) {
print 'Status code = ' . $http->LastStatus . "\n";
print $json->emit() . "\n";
print 'Failed.' . "\n";
}
$i = 0;
$numFolders = $json->SizeOfArray('value');
while ($i < $numFolders) {
$json->I = $i;
$folderName = $json->stringOf('value[i].displayName');
$folderId = $json->stringOf('value[i].id');
$sbFolderPath->SetString($parentFolderPath);
$sbFolderPath->Append('/');
$sbFolderPath->Append($folderName);
$folderPath = $sbFolderPath->getAsString();
$folderMap->AddStr($folderPath,$folderId);
print $folderPath . ' --> ' . $folderId . "\n";
// Push the folder path + id onto the idQueue.
$sbQueueEntry->Clear();
$sbQueueEntry->SetNth(0,$folderPath,'|',0,0);
$sbQueueEntry->SetNth(1,$folderId,'|',0,0);
$idQueue->Append($sbQueueEntry->getAsString());
$i = $i + 1;
}
}
// The hash table of mail folder paths --> ID's can be persisted to XML and saved to a file or database (or anywhere..)
$sbFolderMapXml = new COM("Chilkat.StringBuilder");
$folderMap->ToXmlSb($sbFolderMapXml);
$sbFolderMapXml->WriteFile('qa_data/outlook/folderMap.xml','utf-8',0);
// The hash table can be restored from the serialized XML like this:
$ht2 = new COM("Chilkat.Hashtable");
$sb2 = new COM("Chilkat.StringBuilder");
$sb2->LoadFile('qa_data/outlook/folderMap.xml','utf-8');
$ht2->AddFromXmlSb($sb2);
// What's the ID for the folder "/Inbox/abc/subFolderA" ?
print 'id for /Inbox/abc/subFolderA = ' . $ht2->lookupStr('/Inbox/abc/subFolderA') . "\n";
// Final output:
// /Archive --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAG8XunwAAAA=
// /Deleted Items --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEKAAAA
// /Drafts --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEPAAAA
// /Inbox --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEMAAAA
// /Junk Email --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEiAAAA
// /Outbox --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgELAAAA
// /Sent Items --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAgEJAAAA
// /Inbox/abc --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAL8huv8AAAA=
// /Inbox/xyz --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAL8huwEAAAA=
// /Inbox/abc/subFolderA --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAL8huwAAAQ==
// /Inbox/abc/subFolderB --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAL8huwMAAAA=
// /Inbox/abc/subFolderA/a --> AQMkADAwATM0MDAAMS1iNTcwLWI2NTEtMDACLTAwCgAuAAADsVyfxjDU406Ic4X7ill8xAEA5_vF7TKKdE6bGCRqXyl2PQAAAL8huwIAAAA=
//
// ------------------------------------------------------------------------------------------------------
// 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.
?>