Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(SQL Server) IMAP Copy Email from Selected Folder to Another FolderCopies an email from the selected mailbox (folder) to another mailbox (folder).
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int DECLARE @iTmp0 int DECLARE @iTmp1 int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) -- This example requires the Chilkat API to have been previously unlocked. -- See Global Unlock Sample for sample code. -- This example copies an email from one mailbox to another. DECLARE @imap int -- Use "Chilkat_9_5_0.Imap" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Imap', @imap OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END -- Turn on session logging for debugging. EXEC sp_OASetProperty @imap, 'KeepSessionLog', 1 -- Connect using TLS. EXEC sp_OASetProperty @imap, 'Ssl', 1 EXEC sp_OASetProperty @imap, 'Port', 993 DECLARE @success int EXEC sp_OAMethod @imap, 'Connect', @success OUT, 'imap.example.com' IF @success <> 1 BEGIN EXEC sp_OAGetProperty @imap, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @imap RETURN END -- Authenticate EXEC sp_OAMethod @imap, 'Login', @success OUT, 'email_account_login', 'email_account_password' IF @success <> 1 BEGIN EXEC sp_OAGetProperty @imap, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @imap RETURN END -- Select an IMAP mailbox EXEC sp_OAMethod @imap, 'SelectMailbox', @success OUT, 'Inbox' IF @success <> 1 BEGIN EXEC sp_OAGetProperty @imap, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @imap RETURN END -- Search for messages having "Test email" in the subject. DECLARE @fetchUids int SELECT @fetchUids = 1 DECLARE @messageSet int EXEC sp_OAMethod @imap, 'Search', @messageSet OUT, 'SUBJECT "Test email"', @fetchUids EXEC sp_OAGetProperty @imap, 'LastMethodSuccess', @iTmp0 OUT IF @iTmp0 <> 1 BEGIN EXEC sp_OAGetProperty @imap, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 EXEC @hr = sp_OADestroy @imap RETURN END -- Assuming we have 1 or more messages in the set, copy the 1st one to the folder "Inbox.testFolder" EXEC sp_OAGetProperty @messageSet, 'Count', @iTmp0 OUT IF @iTmp0 > 0 BEGIN EXEC sp_OAMethod @messageSet, 'GetId', @iTmp0 OUT, 0 EXEC sp_OAGetProperty @messageSet, 'HasUids', @iTmp1 OUT EXEC sp_OAMethod @imap, 'Copy', @success OUT, @iTmp0, @iTmp1, 'Inbox/testFolder' IF @success <> 1 BEGIN EXEC sp_OAGetProperty @imap, 'LastErrorText', @sTmp0 OUT PRINT @sTmp0 END END EXEC @hr = sp_OADestroy @messageSet EXEC sp_OAGetProperty @imap, 'SessionLog', @sTmp0 OUT PRINT @sTmp0 PRINT 'OK' -- Sample sessiong log: -- ----INFO---- -- Connecting to IMAP server at outlook.office365.com:993 -- ----IMAP RESPONSE---- -- * OK The Microsoft Exchange IMAP4 service is ready. [QgBMADAAUABSADAAMQAwADIAQwBBADAAMAA3ADAALgBwAHIAbwBkAC4AZQB4AGMAaABhAG4AZwBlAGwAYQBiAHMALgBjAG8AbQA=] -- ----IMAP REQUEST---- -- aaab LOGIN "chilkat@live.com" -- ----IMAP RESPONSE---- -- aaab OK LOGIN completed. -- ----IMAP REQUEST---- -- aaac SELECT "Inbox" -- ----IMAP RESPONSE---- -- * 28 EXISTS -- * 0 RECENT -- * FLAGS (\Seen \Answered \Flagged \Deleted \Draft $MDNSent) -- * OK [PERMANENTFLAGS (\Seen \Answered \Flagged \Deleted \Draft $MDNSent)] Permanent flags -- * OK [UNSEEN 23] Is the first unseen message -- * OK [UIDVALIDITY 14] UIDVALIDITY value -- * OK [UIDNEXT 6416] The next unique identifier value -- aaac OK [READ-WRITE] SELECT completed. -- ----IMAP REQUEST---- -- aaad UID SEARCH SUBJECT "Test email" -- ----IMAP RESPONSE---- -- * SEARCH 6414 -- aaad OK SEARCH completed. -- ----IMAP REQUEST---- -- aaae UID COPY 6414 "Inbox/testFolder" -- ----IMAP RESPONSE---- -- aaae OK [COPYUID 180 6414 1] COPY completed. -- -- OK EXEC @hr = sp_OADestroy @imap END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.