Reputation: 14705
I'm trying to figure out the correct syntax for EWS to be able to store a mail that is sent in a specific folder, not just in the 'Sent Items' folder.
Mailbox structure:
[email protected]
- Inbox
- ----- PowerShell
- ----- ---------- Mail OUT
How can I have EWS save the sent mail in Inbox\PowerShell\Mail OUT
?
I've tried the following without success:
$Message.SendAndSaveCopy('WellKnownFolderName.Inbox.PowerShell.Mail OUT')
$Message.SendAndSaveCopy('WellKnownFolderName.Inbox\PowerShell\Mail OUT')
$Message.Send()
$Message.Save([Microsoft.Exchange.WebServices.Data.WellKnownFolderName]::'Inbox\PowerShell\Mail OUT')
The examples on MSDN are only valid for C#.
Thank you for your help.
Upvotes: 0
Views: 846
Reputation: 14705
First, as arco444 pointed out, we need to retrieve the FolderId
number. After that a simle Send
and Save
will do the trick.
For anyone interested:
Function Find-FolderID {
Param (
[Parameter(Mandatory)]
[String]$Path,
[Parameter(Mandatory)]
[String]$Mailbox,
[Parameter(Mandatory)]
[Object]$Service
)
$FolderId = New-Object Microsoft.Exchange.WebServices.Data.FolderId([Microsoft.Exchange.WebServices.Data.WellKnownFolderName]::MsgFolderRoot,$Mailbox)
$TargetFolder = [Microsoft.Exchange.WebServices.Data.Folder]::Bind($Service,$FolderId)
$Array = $Path.Split('\')
for ($i=1; $i -lt $Array.Length; $i++) {
$FolderView = New-Object Microsoft.Exchange.WebServices.Data.FolderView(1)
$SearchFilter = New-Object Microsoft.Exchange.WebServices.Data.SearchFilter+IsEqualTo([Microsoft.Exchange.WebServices.Data.FolderSchema]::DisplayName,$Array[$i])
$Results = $service.FindFolders($TargetFolder.Id,$SearchFilter,$FolderView)
if ($Results.TotalCount -gt 0) {
foreach($R in $Results.Folders) {
$TargetFolder = $R
}
}
else {
throw "Folder '$Path' not found in mailbox '$Mailbox'"
}
}
$TargetFolder.Id
}
Find-FolderId -Path '\Inbox\PowerShell\Expiring users OUT' -Mailbox '[email protected]' -Service $EWS
$Message.Send()
$Message.Save($FolderID)
Upvotes: 0