Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Node.js) Fetch Full Email Given Email HeaderWhen email headers are fetched using UIDs (not sequence numbers), then the resultant email object (containing only the header) will include auto-generated ckx-imap-* header fields to record information about the uid, attachments, etc. The IMAP UID of the email will be available in the "ckx-imap-uid" header. There will also be a "ckx-imap-isUid" header field having the value "YES" or "NO". If the email header was downloaded by UID, then "ckx-imap-isUID" will contain the value "YES" and the value of the "ckx-imap-uid" header field is the IMAP UID. If the "ckx-imap-isUID" header has a value of "NO", then the "ckx-imap-uid" header field represents the sequence number. (Sequence numbers of emails on the server can change over time, depending on whether emails are deleted. UIDs must be used to ensure that the correct full email is downloaded.) The Chilkat Email object provides a GetImapUid method to return the UID from the ckx-imap-uid header. This can then be used to download the full email using the FetchSingle method. Assuming the UID is known, download a single email by UID from an IMAP mail server.
var os = require('os'); if (os.platform() == 'win32') { if (os.arch() == 'ia32') { var chilkat = require('@chilkat/ck-node21-win-ia32'); } else { var chilkat = require('@chilkat/ck-node21-win64'); } } else if (os.platform() == 'linux') { if (os.arch() == 'arm') { var chilkat = require('@chilkat/ck-node21-arm'); } else if (os.arch() == 'x86') { var chilkat = require('@chilkat/ck-node21-linux32'); } else { var chilkat = require('@chilkat/ck-node21-linux64'); } } else if (os.platform() == 'darwin') { if (os.arch() == 'arm64') { var chilkat = require('@chilkat/ck-node21-mac-m1'); } else { var chilkat = require('@chilkat/ck-node21-macosx'); } } function chilkatExample() { // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. var imap = new chilkat.Imap(); // Connect to an IMAP server. // Use TLS imap.Ssl = true; imap.Port = 993; var success = imap.Connect("imap.someMailServer.com"); if (success !== true) { console.log(imap.LastErrorText); return; } // Login success = imap.Login("***","***"); if (success !== true) { console.log(imap.LastErrorText); return; } // Select an IMAP mailbox success = imap.SelectMailbox("Inbox"); if (success !== true) { console.log(imap.LastErrorText); return; } // emailHeader: Email var emailHeader; // emailFull: Email var emailFull; var uid = 2014; var isUid = true; // Fetch only the email header emailHeader = imap.FetchSingleHeader(uid,isUid); if (imap.LastMethodSuccess == true) { // Now fetch the full email var uidFromCkxHeader = emailHeader.GetImapUid(); if (uidFromCkxHeader < 0) { // Failed. console.log("No ckx-imap-uid header was found."); return; } emailFull = imap.FetchSingle(uidFromCkxHeader,true); if (imap.LastMethodSuccess == true) { // OK, we have the full email, do whatever we want... } } // Disconnect from the IMAP server. success = imap.Disconnect(); } chilkatExample(); |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.