SQL Server
SQL Server
Scan for Emails with Attachments and Save Attachments to Files
Scan for emails with attachments and save attachments.Chilkat SQL Server Downloads
-- 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
-- Important: Do not use nvarchar(max). See the warning about using nvarchar(max).
DECLARE @sTmp0 nvarchar(4000)
DECLARE @success int
SELECT @success = 0
-- This example requires the Chilkat API to have been previously unlocked.
-- See Global Unlock Sample for sample code.
DECLARE @imap int
EXEC @hr = sp_OACreate 'Chilkat.Imap', @imap OUT
IF @hr <> 0
BEGIN
PRINT 'Failed to create ActiveX component'
RETURN
END
-- Connect to an IMAP server.
-- Use TLS
EXEC sp_OASetProperty @imap, 'Ssl', 1
EXEC sp_OASetProperty @imap, 'Port', 993
EXEC sp_OAMethod @imap, 'Connect', @success OUT, 'imap.example.com'
IF @success = 0
BEGIN
EXEC sp_OAGetProperty @imap, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @imap
RETURN
END
-- Login
EXEC sp_OAMethod @imap, 'Login', @success OUT, 'myLogin', 'myPassword'
IF @success = 0
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 = 0
BEGIN
EXEC sp_OAGetProperty @imap, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @imap
RETURN
END
-- We can choose to fetch UIDs or sequence numbers.
DECLARE @fetchUids int
SELECT @fetchUids = 1
-- Get the message IDs of all the emails in the mailbox
DECLARE @messageSet int
EXEC @hr = sp_OACreate 'Chilkat.MessageSet', @messageSet OUT
EXEC sp_OAMethod @imap, 'QueryMbx', @success OUT, 'ALL', @fetchUids, @messageSet
IF @success = 0
BEGIN
EXEC sp_OAGetProperty @imap, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @imap
EXEC @hr = sp_OADestroy @messageSet
RETURN
END
-- Fetch the email headers into a bundle object:
DECLARE @bundle int
EXEC @hr = sp_OACreate 'Chilkat.EmailBundle', @bundle OUT
DECLARE @headersOnly int
SELECT @headersOnly = 1
EXEC sp_OAMethod @imap, 'FetchMsgSet', @success OUT, @headersOnly, @messageSet, @bundle
IF @success = 0
BEGIN
EXEC sp_OAGetProperty @imap, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @imap
EXEC @hr = sp_OADestroy @messageSet
EXEC @hr = sp_OADestroy @bundle
RETURN
END
-- Scan for emails with attachments, and save the attachments
-- to a sub-directory.
DECLARE @fullEmail int
EXEC @hr = sp_OACreate 'Chilkat.Email', @fullEmail OUT
DECLARE @emailHeader int
EXEC @hr = sp_OACreate 'Chilkat.Email', @emailHeader OUT
DECLARE @i int
SELECT @i = 0
EXEC sp_OAGetProperty @bundle, 'MessageCount', @iTmp0 OUT
WHILE @i < @iTmp0
BEGIN
-- The bundle contains email headers..
EXEC sp_OAMethod @bundle, 'EmailAt', @success OUT, @i, @emailHeader
-- Does this email have attachments?
-- Use GetMailNumAttach because the attachments
-- are not actually in the email object because
-- we only downloaded headers.
DECLARE @numAttach int
EXEC sp_OAMethod @imap, 'GetMailNumAttach', @numAttach OUT, @emailHeader
IF @numAttach > 0
BEGIN
-- Download the entire email and save the
-- attachments. (Remember, we
-- need to download the entire email because
-- only the headers were previously downloaded.
-- The ckx-imap-uid header field is added when
-- headers are downloaded. This makes it possible
-- to get the UID from the email object.
DECLARE @uidStr nvarchar(4000)
EXEC sp_OAMethod @emailHeader, 'GetHeaderField', @uidStr OUT, 'ckx-imap-uid'
DECLARE @uid int
SELECT @uid = @
EXEC sp_OAMethod @imap, 'FetchEmail', @success OUT, 0, @uid, 1, @fullEmail
IF @success = 0
BEGIN
EXEC sp_OAGetProperty @imap, 'LastErrorText', @sTmp0 OUT
PRINT @sTmp0
EXEC @hr = sp_OADestroy @imap
EXEC @hr = sp_OADestroy @messageSet
EXEC @hr = sp_OADestroy @bundle
EXEC @hr = sp_OADestroy @fullEmail
EXEC @hr = sp_OADestroy @emailHeader
RETURN
END
EXEC sp_OAMethod @fullEmail, 'SaveAllAttachments', @success OUT, 'attachmentsDir'
DECLARE @j int
SELECT @j = 0
WHILE @j <= @numAttach - 1
BEGIN
DECLARE @filename nvarchar(4000)
EXEC sp_OAMethod @imap, 'GetMailAttachFilename', @filename OUT, @emailHeader, @j
PRINT @filename
SELECT @j = @j + 1
END
END
SELECT @i = @i + 1
END
-- Disconnect from the IMAP server.
EXEC sp_OAMethod @imap, 'Disconnect', @success OUT
EXEC @hr = sp_OADestroy @imap
EXEC @hr = sp_OADestroy @messageSet
EXEC @hr = sp_OADestroy @bundle
EXEC @hr = sp_OADestroy @fullEmail
EXEC @hr = sp_OADestroy @emailHeader
END
GO