You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
477 lines
18 KiB
477 lines
18 KiB
/*
|
|
* M A P I . H
|
|
*
|
|
* Messaging Applications Programming Interface.
|
|
*
|
|
* Copyright 1993-1995 Microsoft Corporation. All Rights Reserved.
|
|
*
|
|
* Purpose:
|
|
*
|
|
* This file defines the structures and constants used by that
|
|
* subset of the Messaging Applications Programming Interface
|
|
* which is supported under Windows by Microsoft Mail for PC
|
|
* Networks version 3.x.
|
|
*/
|
|
|
|
|
|
#ifndef MAPI_H
|
|
#define MAPI_H
|
|
|
|
|
|
/*
|
|
* Types.
|
|
*/
|
|
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
typedef unsigned long FAR * LPULONG;
|
|
typedef unsigned long FLAGS;
|
|
|
|
#ifndef __LHANDLE
|
|
#define __LHANDLE
|
|
typedef unsigned long LHANDLE, FAR * LPLHANDLE;
|
|
#endif
|
|
|
|
typedef unsigned char FAR * LPBYTE;
|
|
|
|
#define lhSessionNull ((LHANDLE)0)
|
|
|
|
typedef struct
|
|
{
|
|
ULONG ulReserved; /* Reserved for future use (must be 0) */
|
|
ULONG flFlags; /* Flags */
|
|
ULONG nPosition; /* character in text to be replaced by attachment */
|
|
LPSTR lpszPathName; /* Full path name of attachment file */
|
|
LPSTR lpszFileName; /* Original file name (optional) */
|
|
LPVOID lpFileType; /* Attachment file type (can be lpMapiFileTagExt) */
|
|
} MapiFileDescA, FAR * lpMapiFileDescA;
|
|
|
|
#ifdef WIN32
|
|
typedef struct
|
|
{
|
|
ULONG ulReserved; /* Reserved for future use (must be 0) */
|
|
ULONG flFlags; /* Flags */
|
|
ULONG nPosition; /* character in text to be replaced by attachment */
|
|
LPWSTR lpszPathName; /* Full path name of attachment file */
|
|
LPWSTR lpszFileName; /* Original file name (optional) */
|
|
LPVOID lpFileType; /* Attachment file type (can be lpMapiFileTagExt) */
|
|
} MapiFileDescW, FAR * lpMapiFileDescW;
|
|
#endif /* WIN32 */
|
|
|
|
#ifdef UNICODE
|
|
#define MapiFileDesc MapiFileDescW
|
|
#define lpMapiFileDesc lpMapiFileDescW
|
|
#else
|
|
#define MapiFileDesc MapiFileDescA
|
|
#define lpMapiFileDesc lpMapiFileDescA
|
|
#endif
|
|
|
|
#define MAPI_OLE 0x00000001
|
|
#define MAPI_OLE_STATIC 0x00000002
|
|
|
|
|
|
typedef struct
|
|
{
|
|
ULONG ulReserved; /* Reserved, must be zero. */
|
|
ULONG cbTag; /* Size (in bytes) of */
|
|
LPBYTE lpTag; /* X.400 OID for this attachment type */
|
|
ULONG cbEncoding; /* Size (in bytes) of */
|
|
LPBYTE lpEncoding; /* X.400 OID for this attachment's encoding */
|
|
} MapiFileTagExt, FAR *lpMapiFileTagExt;
|
|
|
|
|
|
typedef struct
|
|
{
|
|
ULONG ulReserved; /* Reserved for future use */
|
|
ULONG ulRecipClass; /* Recipient class */
|
|
/* MAPI_TO, MAPI_CC, MAPI_BCC, MAPI_ORIG */
|
|
LPSTR lpszName; /* Recipient name */
|
|
LPSTR lpszAddress; /* Recipient address (optional) */
|
|
ULONG ulEIDSize; /* Count in bytes of size of pEntryID */
|
|
LPVOID lpEntryID; /* System-specific recipient reference */
|
|
} MapiRecipDescA, FAR * lpMapiRecipDescA;
|
|
|
|
#ifdef WIN32
|
|
typedef struct
|
|
{
|
|
ULONG ulReserved; /* Reserved for future use */
|
|
ULONG ulRecipClass; /* Recipient class */
|
|
/* MAPI_TO, MAPI_CC, MAPI_BCC, MAPI_ORIG */
|
|
LPWSTR lpszName; /* Recipient name */
|
|
LPWSTR lpszAddress; /* Recipient address (optional) */
|
|
ULONG ulEIDSize; /* Count in bytes of size of pEntryID */
|
|
LPVOID lpEntryID; /* System-specific recipient reference */
|
|
} MapiRecipDescW, FAR * lpMapiRecipDescW;
|
|
#endif /* WIN32 */
|
|
|
|
#ifdef UNICODE
|
|
#define MapiRecipDesc MapiRecipDescW
|
|
#define lpMapiRecipDesc lpMapiRecipDescW
|
|
#else
|
|
#define MapiRecipDesc MapiRecipDescA
|
|
#define lpMapiRecipDesc lpMapiRecipDescA
|
|
#endif
|
|
|
|
#ifndef MAPI_ORIG /* also defined in mapix.h */
|
|
#define MAPI_ORIG 0 /* Recipient is message originator */
|
|
#define MAPI_TO 1 /* Recipient is a primary recipient */
|
|
#define MAPI_CC 2 /* Recipient is a copy recipient */
|
|
#define MAPI_BCC 3 /* Recipient is blind copy recipient */
|
|
#define MAPI_DISCRETE 0x10000000/* Recipient is a P1 resend recipient */
|
|
#endif
|
|
|
|
typedef struct
|
|
{
|
|
ULONG ulReserved; /* Reserved for future use (M.B. 0) */
|
|
LPSTR lpszSubject; /* Message Subject */
|
|
LPSTR lpszNoteText; /* Message Text */
|
|
LPSTR lpszMessageType; /* Message Class */
|
|
LPSTR lpszDateReceived; /* in YYYY/MM/DD HH:MM format */
|
|
LPSTR lpszConversationID; /* conversation thread ID */
|
|
FLAGS flFlags; /* unread,return receipt */
|
|
lpMapiRecipDesc lpOriginator; /* Originator descriptor */
|
|
ULONG nRecipCount; /* Number of recipients */
|
|
lpMapiRecipDesc lpRecips; /* Recipient descriptors */
|
|
ULONG nFileCount; /* # of file attachments */
|
|
lpMapiFileDesc lpFiles; /* Attachment descriptors */
|
|
} MapiMessageA, FAR * lpMapiMessageA;
|
|
|
|
#ifdef WIN32
|
|
typedef struct
|
|
{
|
|
ULONG ulReserved; /* Reserved for future use (M.B. 0) */
|
|
LPWSTR lpszSubject; /* Message Subject */
|
|
LPWSTR lpszNoteText; /* Message Text */
|
|
LPWSTR lpszMessageType; /* Message Class */
|
|
LPWSTR lpszDateReceived; /* in YYYY/MM/DD HH:MM format */
|
|
LPWSTR lpszConversationID; /* conversation thread ID */
|
|
FLAGS flFlags; /* unread,return receipt */
|
|
lpMapiRecipDesc lpOriginator; /* Originator descriptor */
|
|
ULONG nRecipCount; /* Number of recipients */
|
|
lpMapiRecipDesc lpRecips; /* Recipient descriptors */
|
|
ULONG nFileCount; /* # of file attachments */
|
|
lpMapiFileDesc lpFiles; /* Attachment descriptors */
|
|
} MapiMessageW, FAR * lpMapiMessageW;
|
|
#endif /* WIN32 */
|
|
|
|
#ifdef UNICODE
|
|
#define MapiMessage MapiMessageW
|
|
#define lpMapiMessage lpMapiMessageW
|
|
#else
|
|
#define MapiMessage MapiMessageA
|
|
#define lpMapiMessage lpMapiMessageA
|
|
#endif
|
|
|
|
#define MAPI_UNREAD 0x00000001
|
|
#define MAPI_RECEIPT_REQUESTED 0x00000002
|
|
#define MAPI_SENT 0x00000004
|
|
|
|
|
|
/*
|
|
* Entry points.
|
|
*/
|
|
|
|
/*
|
|
* flFlags values for Simple MAPI entry points. All documented flags are
|
|
* shown for each call. Duplicates are commented out but remain present
|
|
* for every call.
|
|
*/
|
|
|
|
/* MAPILogon() flags. */
|
|
|
|
#define MAPI_LOGON_UI 0x00000001 /* Display logon UI */
|
|
#ifndef MAPI_PASSWORD_UI
|
|
#define MAPI_PASSWORD_UI 0x00020000 /* prompt for password only */
|
|
#endif
|
|
#define MAPI_NEW_SESSION 0x00000002 /* Don't use shared session */
|
|
#define MAPI_FORCE_DOWNLOAD 0x00001000 /* Get new mail before return */
|
|
#define MAPI_ALLOW_OTHERS 0x00000008 /* Make this a shared session */
|
|
#define MAPI_EXPLICIT_PROFILE 0x00000010 /* Don't use default profile */
|
|
#define MAPI_EXTENDED 0x00000020 /* Extended MAPI Logon */
|
|
#define MAPI_USE_DEFAULT 0x00000040 /* Use default profile in logon */
|
|
|
|
#define MAPI_SIMPLE_DEFAULT (MAPI_LOGON_UI | MAPI_FORCE_DOWNLOAD | MAPI_ALLOW_OTHERS)
|
|
#define MAPI_SIMPLE_EXPLICIT (MAPI_NEW_SESSION | MAPI_FORCE_DOWNLOAD | MAPI_EXPLICIT_PROFILE)
|
|
|
|
/* MAPILogoff() flags. */
|
|
|
|
#define MAPI_LOGOFF_SHARED 0x00000001 /* Close all shared sessions */
|
|
#define MAPI_LOGOFF_UI 0x00000002 /* It's OK to present UI */
|
|
|
|
/* MAPISendMail() flags. */
|
|
|
|
/* #define MAPI_LOGON_UI 0x00000001 Display logon UI */
|
|
/* #define MAPI_NEW_SESSION 0x00000002 Don't use shared session */
|
|
|
|
#ifndef MAPI_DIALOG /* also defined in property.h */
|
|
#define MAPI_DIALOG 0x00000008 /* Display a send note UI */
|
|
#endif
|
|
/*# define MAPI_USE_DEFAULT 0x00000040 Use default profile in logon */
|
|
|
|
/* MAPIFindNext() flags. */
|
|
|
|
#define MAPI_UNREAD_ONLY 0x00000020 /* Only unread messages */
|
|
#define MAPI_GUARANTEE_FIFO 0x00000100 /* use date order */
|
|
#define MAPI_LONG_MSGID 0x00004000 /* allow 512 char returned ID */
|
|
|
|
/* MAPIReadMail() flags. */
|
|
|
|
#define MAPI_PEEK 0x00000080 /* Do not mark as read. */
|
|
#define MAPI_SUPPRESS_ATTACH 0x00000800 /* header + body, no files */
|
|
#define MAPI_ENVELOPE_ONLY 0x00000040 /* Only header information */
|
|
#define MAPI_BODY_AS_FILE 0x00000200
|
|
|
|
/* MAPISaveMail() flags. */
|
|
|
|
/* #define MAPI_LOGON_UI 0x00000001 Display logon UI */
|
|
/* #define MAPI_NEW_SESSION 0x00000002 Don't use shared session */
|
|
/* #define MAPI_LONG_MSGID 0x00004000 /* allow 512 char returned ID */
|
|
|
|
/* MAPIAddress() flags. */
|
|
|
|
/* #define MAPI_LOGON_UI 0x00000001 Display logon UI */
|
|
/* #define MAPI_NEW_SESSION 0x00000002 Don't use shared session */
|
|
|
|
/* MAPIDetails() flags. */
|
|
|
|
/* #define MAPI_LOGON_UI 0x00000001 Display logon UI */
|
|
/* #define MAPI_NEW_SESSION 0x00000002 Don't use shared session */
|
|
#define MAPI_AB_NOMODIFY 0x00000400 /* Don't allow mods of AB entries */
|
|
|
|
/* MAPIResolveName() flags. */
|
|
|
|
/* #define MAPI_LOGON_UI 0x00000001 Display logon UI */
|
|
/* #define MAPI_NEW_SESSION 0x00000002 Don't use shared session */
|
|
/* #define MAPI_DIALOG 0x00000008 Prompt for choices if ambiguous */
|
|
/* #define MAPI_AB_NOMODIFY 0x00000400 Don't allow mods of AB entries */
|
|
|
|
#ifndef MAPILogon
|
|
|
|
typedef ULONG (FAR PASCAL MAPILOGONA)(
|
|
ULONG ulUIParam,
|
|
LPSTR lpszProfileName,
|
|
LPSTR lpszPassword,
|
|
FLAGS flFlags,
|
|
ULONG ulReserved,
|
|
LPLHANDLE lplhSession
|
|
);
|
|
typedef MAPILOGONA FAR *LPMAPILOGONA;
|
|
|
|
MAPILOGONA MAPILogonA;
|
|
|
|
#ifdef WIN32
|
|
typedef ULONG (FAR PASCAL MAPILOGONW)(
|
|
ULONG ulUIParam,
|
|
LPWSTR lpszProfileName,
|
|
LPWSTR lpszPassword,
|
|
FLAGS flFlags,
|
|
ULONG ulReserved,
|
|
LPLHANDLE lplhSession
|
|
);
|
|
typedef MAPILOGONW FAR *LPMAPILOGONW;
|
|
|
|
MAPILOGONW MAPILogonW;
|
|
#endif
|
|
|
|
#ifdef UNICODE
|
|
#define MAPILogon MAPILogonW
|
|
#else
|
|
#define MAPILogon MAPILogonA
|
|
#endif
|
|
|
|
#endif /* MAPILogon */
|
|
|
|
ULONG FAR PASCAL MAPILogoff(LHANDLE lhSession, ULONG ulUIParam, FLAGS flFlags,
|
|
ULONG ulReserved);
|
|
|
|
ULONG FAR PASCAL MAPISendMailA(LHANDLE lhSession, ULONG ulUIParam,
|
|
lpMapiMessageA lpMessage, FLAGS flFlags,
|
|
ULONG ulReserved);
|
|
|
|
#ifdef WIN32
|
|
ULONG FAR PASCAL MAPISendMailW(LHANDLE lhSession, ULONG ulUIParam,
|
|
lpMapiMessageW lpMessage, FLAGS flFlags,
|
|
ULONG ulReserved);
|
|
#endif
|
|
|
|
#ifdef UNICODE
|
|
#define MAPISendMail MAPISendMailW
|
|
#else
|
|
#define MAPISendMail MAPISendMailA
|
|
#endif
|
|
|
|
ULONG FAR PASCAL MAPISendDocumentsA(ULONG ulUIParam, LPSTR lpszDelimChar,
|
|
LPSTR lpszFilePaths, LPSTR lpszFileNames,
|
|
ULONG ulReserved);
|
|
|
|
#ifdef WIN32
|
|
ULONG FAR PASCAL MAPISendDocumentsW(ULONG ulUIParam, LPWSTR lpszDelimChar,
|
|
LPWSTR lpszFilePaths, LPWSTR lpszFileNames,
|
|
ULONG ulReserved);
|
|
#endif
|
|
|
|
#ifdef UNICODE
|
|
#define MAPISendDocuments MAPISendDocumentsW
|
|
#else
|
|
#define MAPISendDocuments MAPISendDocumentsA
|
|
#endif
|
|
|
|
ULONG FAR PASCAL MAPIFindNextA(LHANDLE lhSession, ULONG ulUIParam,
|
|
LPSTR lpszMessageType, LPSTR lpszSeedMessageID,
|
|
FLAGS flFlags, ULONG ulReserved,
|
|
LPSTR lpszMessageID);
|
|
|
|
#ifdef WIN32
|
|
ULONG FAR PASCAL MAPIFindNextW(LHANDLE lhSession, ULONG ulUIParam,
|
|
LPWSTR lpszMessageType, LPWSTR lpszSeedMessageID,
|
|
FLAGS flFlags, ULONG ulReserved,
|
|
LPWSTR lpszMessageID);
|
|
#endif
|
|
|
|
#ifdef UNICODE
|
|
#define MAPIFindNext MAPIFindNextW
|
|
#else
|
|
#define MAPIFindNext MAPIFindNextA
|
|
#endif
|
|
|
|
ULONG FAR PASCAL MAPIReadMailA(LHANDLE lhSession, ULONG ulUIParam,
|
|
LPSTR lpszMessageID, FLAGS flFlags,
|
|
ULONG ulReserved, lpMapiMessageA FAR *lppMessage);
|
|
|
|
#ifdef WIN32
|
|
ULONG FAR PASCAL MAPIReadMailW(LHANDLE lhSession, ULONG ulUIParam,
|
|
LPWSTR lpszMessageID, FLAGS flFlags,
|
|
ULONG ulReserved, lpMapiMessageW FAR *lppMessage);
|
|
#endif
|
|
|
|
#ifdef UNICODE
|
|
#define MAPIReadMail MAPIReadMailW
|
|
#else
|
|
#define MAPIReadMail MAPIReadMailA
|
|
#endif
|
|
|
|
ULONG FAR PASCAL MAPISaveMailA(LHANDLE lhSession, ULONG ulUIParam,
|
|
lpMapiMessageA lpMessage, FLAGS flFlags,
|
|
ULONG ulReserved, LPSTR lpszMessageID);
|
|
|
|
#ifdef WIN32
|
|
ULONG FAR PASCAL MAPISaveMailW(LHANDLE lhSession, ULONG ulUIParam,
|
|
lpMapiMessageW lpMessage, FLAGS flFlags,
|
|
ULONG ulReserved, LPWSTR lpszMessageID);
|
|
#endif
|
|
|
|
#ifdef UNICODE
|
|
#define MAPISaveMail MAPISaveMailW
|
|
#else
|
|
#define MAPISaveMail MAPISaveMailA
|
|
#endif
|
|
|
|
ULONG FAR PASCAL MAPIDeleteMailA(LHANDLE lhSession, ULONG ulUIParam,
|
|
LPSTR lpszMessageID, FLAGS flFlags,
|
|
ULONG ulReserved);
|
|
|
|
#ifdef WIN32
|
|
ULONG FAR PASCAL MAPIDeleteMailW(LHANDLE lhSession, ULONG ulUIParam,
|
|
LPWSTR lpszMessageID, FLAGS flFlags,
|
|
ULONG ulReserved);
|
|
#endif
|
|
|
|
#ifdef UNICODE
|
|
#define MAPIDeleteMail MAPIDeleteMailW
|
|
#else
|
|
#define MAPIDeleteMail MAPIDeleteMailA
|
|
#endif
|
|
|
|
ULONG FAR PASCAL MAPIFreeBuffer(LPVOID pv);
|
|
|
|
ULONG FAR PASCAL MAPIAddressA(LHANDLE lhSession, ULONG ulUIParam,
|
|
LPSTR lpszCaption, ULONG nEditFields,
|
|
LPSTR lpszLabels, ULONG nRecips,
|
|
lpMapiRecipDescA lpRecips, FLAGS flFlags, ULONG ulReserved,
|
|
LPULONG lpnNewRecips, lpMapiRecipDescA FAR *lppNewRecips);
|
|
|
|
#ifdef WIN32
|
|
ULONG FAR PASCAL MAPIAddressW(LHANDLE lhSession, ULONG ulUIParam,
|
|
LPWSTR lpszCaption, ULONG nEditFields,
|
|
LPWSTR lpszLabels, ULONG nRecips,
|
|
lpMapiRecipDescW lpRecips, FLAGS flFlags, ULONG ulReserved,
|
|
LPULONG lpnNewRecips, lpMapiRecipDescW FAR *lppNewRecips);
|
|
#endif
|
|
|
|
#ifdef UNICODE
|
|
#define MAPIAddress MAPIAddressW
|
|
#else
|
|
#define MAPIAddress MAPIAddressA
|
|
#endif
|
|
|
|
ULONG FAR PASCAL MAPIDetailsA(LHANDLE lhSession, ULONG ulUIParam,
|
|
lpMapiRecipDescA lpRecip, FLAGS flFlags, ULONG ulReserved);
|
|
|
|
#ifdef WIN32
|
|
ULONG FAR PASCAL MAPIDetailsW(LHANDLE lhSession, ULONG ulUIParam,
|
|
lpMapiRecipDescW lpRecip, FLAGS flFlags, ULONG ulReserved);
|
|
#endif
|
|
|
|
#ifdef UNICODE
|
|
#define MAPIDetails MAPIDetailsW
|
|
#else
|
|
#define MAPIDetails MAPIDetailsA
|
|
#endif
|
|
|
|
ULONG FAR PASCAL MAPIResolveNameA(LHANDLE lhSession, ULONG ulUIParam,
|
|
LPSTR lpszName, FLAGS flFlags,
|
|
ULONG ulReserved, lpMapiRecipDescA FAR *lppRecip);
|
|
|
|
#ifdef WIN32
|
|
ULONG FAR PASCAL MAPIResolveNameW(LHANDLE lhSession, ULONG ulUIParam,
|
|
LPWSTR lpszName, FLAGS flFlags,
|
|
ULONG ulReserved, lpMapiRecipDescW FAR *lppRecip);
|
|
#endif
|
|
|
|
#ifdef UNICODE
|
|
#define MAPIResolveName MAPIResolveNameW
|
|
#else
|
|
#define MAPIResolveName MAPIResolveNameA
|
|
#endif
|
|
|
|
|
|
#ifndef SUCCESS_SUCCESS
|
|
#define SUCCESS_SUCCESS 0
|
|
#endif
|
|
#define MAPI_USER_ABORT 1
|
|
#define MAPI_E_USER_ABORT MAPI_USER_ABORT
|
|
#define MAPI_E_FAILURE 2
|
|
#define MAPI_E_LOGON_FAILURE 3
|
|
#define MAPI_E_LOGIN_FAILURE MAPI_E_LOGON_FAILURE
|
|
#define MAPI_E_DISK_FULL 4
|
|
#define MAPI_E_INSUFFICIENT_MEMORY 5
|
|
#define MAPI_E_ACCESS_DENIED 6
|
|
#define MAPI_E_TOO_MANY_SESSIONS 8
|
|
#define MAPI_E_TOO_MANY_FILES 9
|
|
#define MAPI_E_TOO_MANY_RECIPIENTS 10
|
|
#define MAPI_E_ATTACHMENT_NOT_FOUND 11
|
|
#define MAPI_E_ATTACHMENT_OPEN_FAILURE 12
|
|
#define MAPI_E_ATTACHMENT_WRITE_FAILURE 13
|
|
#define MAPI_E_UNKNOWN_RECIPIENT 14
|
|
#define MAPI_E_BAD_RECIPTYPE 15
|
|
#define MAPI_E_NO_MESSAGES 16
|
|
#define MAPI_E_INVALID_MESSAGE 17
|
|
#define MAPI_E_TEXT_TOO_LARGE 18
|
|
#define MAPI_E_INVALID_SESSION 19
|
|
#define MAPI_E_TYPE_NOT_SUPPORTED 20
|
|
#define MAPI_E_AMBIGUOUS_RECIPIENT 21
|
|
#define MAPI_E_AMBIG_RECIP MAPI_E_AMBIGUOUS_RECIPIENT
|
|
#define MAPI_E_MESSAGE_IN_USE 22
|
|
#define MAPI_E_NETWORK_FAILURE 23
|
|
#define MAPI_E_INVALID_EDITFIELDS 24
|
|
#define MAPI_E_INVALID_RECIPS 25
|
|
#define MAPI_E_NOT_SUPPORTED 26
|
|
|
|
#ifdef __cplusplus
|
|
} /* extern "C" */
|
|
#endif
|
|
|
|
#endif /* MAPI_H */
|