/* @doc MAILMSG PROPERTIES @module mailmsgprops.h | MailMsg Properties for SMTP and NNTP */ /*++ Copyright (c) 1999 Microsoft Corporation Module Name: mailmsgprops.h Abstract: This module contains the definitions for the MailMsg Object property ID's. --*/ #ifndef __MAILMSGPROPS_H__ #define __MAILMSGPROPS_H__ /*=======================================================================*/ // These macros are used to define the tables of property ID's. #define IMMPID_START_LIST(name,start,guid) struct __declspec(uuid(guid)) tagIMMPID_##name##_STRUCT;\ typedef enum tagIMMPID_##name##_ENUM {\ IMMPID_##name##_BEFORE__ = (start)-1, #define IMMPID_END_LIST(name) IMMPID_##name##_AFTER__\ } IMMPID_##name##_ENUM; /*=======================================================================*/ // These are the per-message properties. IMMPID_START_LIST(MP,0x1000,"13384CF0-B3C4-11d1-AA92-00AA006BC80B") // @const IMMPID | IMMPID_MP_RECIPIENT_LIST | // *** OBSOLETE *** IMMPID_MP_RECIPIENT_LIST, // @const IMMPID | IMMPID_MP_CONTENT_FILE_NAME | // *** OBSOLETE *** IMMPID_MP_CONTENT_FILE_NAME, // @const IMMPID | IMMPID_MP_SENDER_ADDRESS_SMTP | // ANSI String - SMTP Address of sender IMMPID_MP_SENDER_ADDRESS_SMTP, // @const IMMPID | IMMPID_MP_SENDER_ADDRESS_X500 | // ANSI String - X500 Address of sender IMMPID_MP_SENDER_ADDRESS_X500, // @const IMMPID | IMMPID_MP_SENDER_ADDRESS_X400 | // String - X400 Address of sender IMMPID_MP_SENDER_ADDRESS_X400, // @const IMMPID | IMMPID_MP_SENDER_ADDRESS_LEGACY_EX_DN | // String - Legacy DN Address of sender IMMPID_MP_SENDER_ADDRESS_LEGACY_EX_DN, // @const IMMPID | IMMPID_MP_DOMAIN_LIST | // *** OBSOLETE *** IMMPID_MP_DOMAIN_LIST, // @const IMMPID | IMMPID_MP_PICKUP_FILE_NAME | // ANSI String - Filename of msg file in pickup directory IMMPID_MP_PICKUP_FILE_NAME, // @const IMMPID | IMMPID_MP_AUTHENTICATED_USER_NAME | // *** OBSOLETE *** IMMPID_MP_AUTHENTICATED_USER_NAME, // @const IMMPID | IMMPID_MP_CONNECTION_IP_ADDRESS | // ANSI String - IP address of MTA or client that submitted this message IMMPID_MP_CONNECTION_IP_ADDRESS, // @const IMMPID | IMMPID_MP_HELO_DOMAIN | // ANSI String - Domain name used in HELO/EHLO when message was submitted IMMPID_MP_HELO_DOMAIN, // @const IMMPID | IMMPID_MP_EIGHTBIT_MIME_OPTION | // BOOL - TRUE if message body is 8-bit MIME IMMPID_MP_EIGHTBIT_MIME_OPTION, // @const IMMPID | IMMPID_MP_CHUNKING_OPTION | // *** OBSOLETE *** IMMPID_MP_CHUNKING_OPTION, // @const IMMPID | IMMPID_MP_BINARYMIME_OPTION | // BOOL - TRUE if message body is binary MIME IMMPID_MP_BINARYMIME_OPTION, // @const IMMPID | IMMPID_MP_REMOTE_AUTHENTICATION_TYPE | // *** OBSOLETE *** IMMPID_MP_REMOTE_AUTHENTICATION_TYPE, // @const IMMPID | IMMPID_MP_ERROR_CODE | // *** OBSOLETE *** IMMPID_MP_ERROR_CODE, // @const IMMPID | IMMPID_MP_DSN_ENVID_VALUE | // Value of RFC1891 ENVID of submitted message IMMPID_MP_DSN_ENVID_VALUE, // @const IMMPID | IMMPID_MP_DSN_RET_VALUE | // ANSI String of what follows ESMTP RET IMMPID_MP_DSN_RET_VALUE, // @const IMMPID | IMMPID_MP_REMOTE_SERVER_DSN_CAPABLE | // *** OBSOLETE *** IMMPID_MP_REMOTE_SERVER_DSN_CAPABLE, // @const IMMPID | IMMPID_MP_ARRIVAL_TIME | // FILETIME that message arrived in system IMMPID_MP_ARRIVAL_TIME, // @const IMMPID | IMMPID_MP_MESSAGE_STATUS | // MP_STATUS_* value describing status of message system IMMPID_MP_MESSAGE_STATUS, // @const IMMPID | IMMPID_MP_EXPIRE_DELAY | // FILETIME of Delay DSN Expiration IMMPID_MP_EXPIRE_DELAY, // @const IMMPID | IMMPID_MP_EXPIRE_NDR | // FILETIME of NDR DSN Expiration IMMPID_MP_EXPIRE_NDR, // @const IMMPID | IMMPID_MP_LOCAL_EXPIRE_DELAY | // FILETIME of Delay DSN Expiration for local recips IMMPID_MP_LOCAL_EXPIRE_DELAY, // @const IMMPID | IMMPID_MP_LOCAL_EXPIRE_NDR | // FILETIME of NDR DSN Expiration for local recips IMMPID_MP_LOCAL_EXPIRE_NDR, // @const IMMPID | IMMPID_MP_ARRIVAL_FILETIME | // FILETIME when message was submitted to queue IMMPID_MP_ARRIVAL_FILETIME, // @const IMMPID | IMMPID_MP_HR_CAT_STATUS | // HRESULT MsgCat status (ie CAT_W_SOME_UNDELIVERABLE_MSGS) IMMPID_MP_HR_CAT_STATUS, // @const IMMPID | IMMPID_MP_MSG_GUID | // String GUID ID which is only used if you want need to be able to replace // this message with another newer version. This property is only // effective when used for a small amount of mail on the server, and is // best suited for versioned mail (like DS replication). IMMPID_MP_MSG_GUID, // @const IMMPID | IMMPID_MP_SUPERSEDES_MSG_GUID | // String GUID ID which this message superscedes. If a message with with a // IMMPID_MP_MSG_GUID equal to this property is still on the server, then // that message will not be sent out. IMMPID_MP_SUPERSEDES_MSG_GUID, // @const IMMPID | IMMPID_MP_SCANNED_FOR_CRLF_DOT_CRLF | // Boolean which tells if the input was scanned for . in the msg // body IMMPID_MP_SCANNED_FOR_CRLF_DOT_CRLF, // @const IMMPID | IMMPID_MP_FOUND_EMBEDDED_CRLF_DOT_CRLF | // Boolean which tells if the input had any . // IMMPID_MP_FOUND_EMBEDDED_CRLF_DOT_CRLF, // @const IMMPID | IMMPID_MP_MSG_SIZE_HINT | // Provides an approximate size of the message content. Does not convert // message, or guarantee accuracy. For an accurate message size (but at // a higher performance cost) use IMailMsgProperties::GetContentSize. // IMMPID_MP_MSG_SIZE_HINT, // @const IMMPID | IMMPID_MP_RFC822_MSG_ID | // String -- RFC 822 Message Id header. IMMPID_MP_RFC822_MSG_ID, // @const IMMPID | IMMPID_MP_RFC822_MSG_SUBJECT | // String -- RFC822 subject header IMMPID_MP_RFC822_MSG_SUBJECT, // @const IMMPID | IMMPID_MP_RFC822_FROM_ADDRESS | // String -- RFC822 from address IMMPID_MP_RFC822_FROM_ADDRESS, // @const IMMPID | IMMPID_MP_RFC822_TO_ADDRESS | // String -- RFC822 To address IMMPID_MP_RFC822_TO_ADDRESS, // @const IMMPID | IMMPID_MP_RFC822_CC_ADDRESS | // String -- RFC822 Cc address IMMPID_MP_RFC822_CC_ADDRESS, // @const IMMPID | IMMPID_MP_RFC822_BCC_ADDRESS | // String -- RFC822 Bcc address IMMPID_MP_RFC822_BCC_ADDRESS, // @const IMMPID | IMMPID_MP_CONNECTION_SERVER_IP_ADDRESS | // String -- server IP Address IMMPID_MP_CONNECTION_SERVER_IP_ADDRESS, // @const IMMPID | IMMPID_MP_SERVER_NAME | // String -- server name IMMPID_MP_SERVER_NAME, // @const IMMPID | IMMPID_MP_SERVER_VERSION | // String -- server version IMMPID_MP_SERVER_VERSION, // @const IMMPID | IMMPID_MP_NUM_RECIPIENTS | // DWORD -- number of recipients IMMPID_MP_NUM_RECIPIENTS, // @const IMMPID | IMMPID_MP_X_PRIORITY | // DWORD -- the priority of message IMMPID_MP_X_PRIORITY, // @const IMMPID | IMMPID_MP_FROM_ADDRESS | // String -- From: address, in form format:address // (ie, smtp:foo@microsoft.com). RFC822 address comments are stripped IMMPID_MP_FROM_ADDRESS, // @const IMMPID | IMMPID_MP_SENDER_ADDRESS | // String -- Sender: address, in form format:address // (ie, smtp:foo@microsoft.com). RFC822 address comments are stripped IMMPID_MP_SENDER_ADDRESS, // @const IMMPID | IMMPID_MP_DEFERRED_DELIVERY_FILETIME | // FILETIME -- Universal time to wait until before allowing // message to be delivered. IMMPID_MP_DEFERRED_DELIVERY_FILETIME, // @const IMMPID | IMMPID_MP_SENDER_ADDRESS_OTHER | // ANSI String - with the format "type:address" IMMPID_MP_SENDER_ADDRESS_OTHER, // @const IMMPID | IMMPID_MP_ORIGINAL_ARRIVAL_TIME | // FILETIME that message arrived in first exchange system IMMPID_MP_ORIGINAL_ARRIVAL_TIME, // @const IMMPID | IMMPID_MP_MSG_CLASS | // The Message class of the mail, e.g. syste, replication, etc... IMMPID_MP_MSGCLASS, // @const IMMPID | IMMPID_MP_CONTENT_TYPE | // The content type of message. // ANSI STRING. IMMPID_MP_CONTENT_TYPE, //@const IMMPID | IMMPID_MP_ENCRYPTION_TYPE | // DWORD - 0, no encryption // 1, signed only // 2, encrypted IMMPID_MP_ENCRYPTION_TYPE, //@const IMMPID | IMMPID_MP_CONNECTION_SERVER_PORT | // DOWRD - Port (if any) that this message was submitted on IMMPID_MP_CONNECTION_SERVER_PORT, //@const IMMPID | IMMPID_MP_CLIENT_AUTH_USER | // ASCII STRING - Name of authenticated user IMMPID_MP_CLIENT_AUTH_USER, //@const IMMPID | IMMPID_MP_CLIENT_AUTH_TYPE | // ASCII STRING - Type of authentication used (AUTH keyword) IMMPID_MP_CLIENT_AUTH_TYPE, // Add new per-message properties above this line. IMMPID_END_LIST(MP) // Message classes // @const DWORD | MP_MSGCLASS_SYSTEM // for msgs of type -- system #define MP_MSGCLASS_SYSTEM 1 // @const DWORD | MP_MSGCLASS_REPLICATION // for msgs of type -- replication #define MP_MSGCLASS_REPLICATION 2 // @const DWORD | MP_MSGCLASS_DELIVERY_REPORT // for msgs of type -- delivery report #define MP_MSGCLASS_DELIVERY_REPORT 3 // @const DWORD | MP_MSGCLASS_DELIVERY_REPORT // for msgs of type -- non-delivery report #define MP_MSGCLASS_NONDELIVERY_REPORT 4 // Message status property values defined: // @const DWORD | MP_STATUS_SUCCESS | // Initial status of message #define MP_STATUS_SUCCESS 0 // @const DWORD | MP_STATUS_RETRY | // Status indicating retry. #define MP_STATUS_RETRY 1 // @const DWORD | MP_STATUS_ABORT_DELIVERY | // Delivery of this message should be aborted and the message deleted. #define MP_STATUS_ABORT_DELIVERY 2 // @const DWORD | MP_STATUS_BAD_MAIL | // This message should be moved to badmail. #define MP_STATUS_BAD_MAIL 3 // @const DWORD | MP_STATUS_SUBMITTED | // Message has been submitted for delivery. #define MP_STATUS_SUBMITTED 4 // @const DWORD | MP_STATUS_CATEGORIZED | // Message has been categorized. #define MP_STATUS_CATEGORIZED 5 // @const DWORD | MP_STATUS_ABANDON_DELIVERY | // Delivery of this message should be abandoned until the service restarts #define MP_STATUS_ABANDON_DELIVERY 6 //Per recipient flags for IMMPID_RP_RECIPIENT_FLAGS // @const DWORD | RP_RECIP_FLAGS_RESERVED | // You should not modify / use these bits #define RP_RECIP_FLAGS_RESERVED 0x0000000F // @const DWORD | RP_DSN_NOTIFY_SUCCESS | // Notify on success - set if RFC1891 NOTIFY=SUCCESS is used #define RP_DSN_NOTIFY_SUCCESS 0x01000000 // @const DWORD | RP_DSN_NOTIFY_FAILURE | // Notify on failure - set if RFC1891 NOTIFY=FAILURE is used #define RP_DSN_NOTIFY_FAILURE 0x02000000 // @const DWORD | RP_DSN_NOTIFY_DELAY | // Notify on delay - set if RFC1891 NOTIFY=DELAY is used #define RP_DSN_NOTIFY_DELAY 0x04000000 // @const DWORD | RP_DSN_NOTIFY_NEVER | // Never notify - set if RFC1891 NOTIFY=NEVER is used #define RP_DSN_NOTIFY_NEVER 0x08000000 // @const DWORD | RP_DSN_NOTIFY_MASK | // Mask of all notify parameters #define RP_DSN_NOTIFY_MASK 0x0F000000 //The following flags can be used in searches, but should not be set directly // @const DWORD | RP_HANDLED | // Recipient has either been delivered or should not be delivered // (this flag is provided to check status of recipient... it should never be used // directly) #define RP_HANDLED 0x00000010 // @const DWORD | RP_GENERAL_FAILURE | // some form of hard failure happend // (this flag is provided to check status of recipient... it should never be used // directly) #define RP_GENERAL_FAILURE 0x00000020 // @const DWORD | RP_DSN_HANDLED | // Final DSN has been sent (or no DSN needs to be sent) // (this flag is provided to check status of recipient... it should never be used // directly) #define RP_DSN_HANDLED 0x00000040 //The following constants define how a message can be RP_HANDLED // @const DWORD | RP_DELIVERED | // The recipient has been delivered successfully #define RP_DELIVERED 0x00000110 // @const DWORD | RP_DSN_SENT_NDR | // NDR (FAILED DSN) for this recipient has been sent #define RP_DSN_SENT_NDR 0x00000450 // @const DWORD | RP_FAILED | // Recipient has a hard failure #define RP_FAILED 0x00000830 // @const DWORD | RP_UNRESOLVED | // This recipient was not resolved by categorization #define RP_UNRESOLVED 0x00001030 // @const DWORD | RP_ENPANDED | // ***OBSOLETE*** (replaced by RP_EXPANDED) #define RP_ENPANDED 0x00002010 // @const DWORD | RP_EXPANDED | // This recipient is an expanded DL #define RP_EXPANDED 0x00002010 // @const DWORD | RP_DSN_SENT_DELAYED | // At least one Delay DSN sent #define RP_DSN_SENT_DELAYED 0x00004000 // @const DWORD | RP_DSN_SENT_EXPANDED | // Expanded DSN has been sent #define RP_DSN_SENT_EXPANDED 0x00008040 // @const DWORD | RP_DSN_SENT_RELAYED | // Relayed DSN has been sent #define RP_DSN_SENT_RELAYED 0x00010040 // @const DWORD | RP_DSN_SENT_DELIVERED | // Delivered DSN has been sent #define RP_DSN_SENT_DELIVERED 0x00020040 // @const DWORD | RP_REMOTE_MTA_NO_DSN | // Remote MTA does not advertise DSN support (relay might be needed) #define RP_REMOTE_MTA_NO_DSN 0x00080000 // @const DWORD | RP_ERROR_CONTEXT_STORE | // Error happened in store driver #define RP_ERROR_CONTEXT_STORE 0x00100000 // @const DWORD | RP_ERROR_CONTEXT_CAT | // Error happened during categorization #define RP_ERROR_CONTEXT_CAT 0x00200000 // @const DWORD | RP_ERROR_CONTEXT_MTA | // Error happened in a MTA (eg SMTP stack) #define RP_ERROR_CONTEXT_MTA 0x00400000 // @const DWORD | RP_VOLATILE_FLAGS_MASK | // Flags that can be used for temp storage #define RP_VOLATILE_FLAGS_MASK 0xF0000000 //while a component has access to recipients //Once control of recipients is passed, value //is un-defined. // @const DWORD | RP_DSN_NOTIFY_INVALID | // *** OBSOLETE *** #define RP_DSN_NOTIFY_INVALID 0x00000000 /*=======================================================================*/ // These are the per-recipient properties. IMMPID_START_LIST(RP,0x2000,"79E82048-D320-11d1-9FF4-00C04FA37348") // @const IMMPID | IMMPID_RP_DSN_NOTIFY_SUCCESS | // *** OBSOLETE *** IMMPID_RP_DSN_NOTIFY_SUCCESS, // @const IMMPID | IMMPID_RP_DSN_NOTIFY_INVALID | // *** OBSOLETE *** IMMPID_RP_DSN_NOTIFY_INVALID, // @const IMMPID | IMMPID_RP_ADDRESS_TYPE | // *** OBSOLETE *** IMMPID_RP_ADDRESS_TYPE, // @const IMMPID | IMMPID_RP_ADDRESS | // *** OBSOLETE *** IMMPID_RP_ADDRESS, // @const IMMPID | IMMPID_RP_ADDRESS_TYPE_SMTP | // *** OBSOLETE *** IMMPID_RP_ADDRESS_TYPE_SMTP, // @const IMMPID | IMMPID_RP_ERROR_CODE | // HRESULT status code IMMPID_RP_ERROR_CODE, // @const IMMPID | IMMPID_RP_ERROR_STRING | // *** OBSOLETE *** IMMPID_RP_ERROR_STRING, // @const IMMPID | IMMPID_RP_DSN_NOTIFY_VALUE | // *** OBSOLETE *** IMMPID_RP_DSN_NOTIFY_VALUE, // @const IMMPID | IMMPID_RP_DSN_ORCPT_VALUE | // ANSI string - \
;\ IMMPID_RP_DSN_ORCPT_VALUE, // @const IMMPID | IMMPID_RP_ADDRESS_SMTP | // ANSI string - SMTP address IMMPID_RP_ADDRESS_SMTP, // @const IMMPID | IMMPID_RP_ADDRESS_X400 | // ANSI string - X.400 address IMMPID_RP_ADDRESS_X400, // @const IMMPID | IMMPID_RP_ADDRESS_X500 | // ANSI string - X.500 address IMMPID_RP_ADDRESS_X500, // @const IMMPID | IMMPID_RP_LEGACY_EX_DN | // ANSI string - DN for Exchange 5.5 and prev IMMPID_RP_LEGACY_EX_DN, // @const IMMPID | IMMPID_RP_RECIPIENT_FLAGS | // Per-recipient DSN/delivery flags. Flag constansts start with RP_. IMMPID_RP_RECIPIENT_FLAGS, // @const IMMPID | IMMPID_RP_SMTP_STATUS_STRING | // ANSI string - SMTP status string... if defined IMMPID_RP_SMTP_STATUS_STRING, // *must* start with 3-digit status code // @const IMMPID | IMMPID_RP_DSN_PRE_CAT_ADDRESS | // Original address as received by MTA in IMMPID_RP_DSN_PRE_CAT_ADDRESS, // IMMPID_RP_DSN_ORCPT_VALUE format // @const IMMPID | IMMPID_RP_MDB_GUID | // Categorizer stamps the MDB guid IMMPID_RP_MDB_GUID, // for this recipient here // @const IMMPID | IMMPID_RP_USER_GUID | // Categorizer stamps the IMMPID_RP_USER_GUID, // objectGUID of the user object here // @const IMMPID | IMMPID_RP_DOMAIN | // Alternate SMTP domain for categorization IMMPID_RP_DOMAIN, // @const IMMPID | IMMPID_RP_ADDRESS_OTHER | // ANSI string - other address type IMMPID_RP_ADDRESS_OTHER, // @const IMMPID | IMMPID_RP_DISPLAY_NAME | // Unicode string - recipient display name IMMPID_RP_DISPLAY_NAME, // Add new per-recipient properties above this line. IMMPID_END_LIST(RP) /*=======================================================================*/ // These are per-message volatile properties - they are not persisted to // the property stream. IMMPID_START_LIST(MPV,0x3000,"CBE69706-C9BD-11d1-9FF2-00C04FA37348") // @const IMMPID | IMMPID_MPV_STORE_DRIVER_HANDLE | // Store driver context for this message. IMMPID_MPV_STORE_DRIVER_HANDLE, // @const IMMPID | IMMPID_MPV_MESSAGE_CREATION_FLAGS | // Flags set at creation of mailmsg. IMMPID_MPV_MESSAGE_CREATION_FLAGS, // @const IMMPID | IMMPID_MPV_MESSAGE_OPEN_HANDLES | // The number of handles (property and content) open for this message. // 0 means no handles open. // 1 means property or content open. // 2 means both property and content open. IMMPID_MPV_MESSAGE_OPEN_HANDLES, // @const IMMPID | IMMPID_MPV_TOTAL_OPEN_HANDLES | // The current total number of open message handles (of any type) // on this server. IMMPID_MPV_TOTAL_OPEN_HANDLES, // @const IMMPID | IMMPID_MPV_TOTAL_OPEN_PROPERTY_STREAM_HANDLES | // The current total number of open property streams on this server. IMMPID_MPV_TOTAL_OPEN_PROPERTY_STREAM_HANDLES, // @const IMMPID | IMMPID_MPV_TOTAL_OPEN_CONTENT_HANDLES | // The current total number of open content handles on this server. IMMPID_MPV_TOTAL_OPEN_CONTENT_HANDLES, // Add new per-message volatile properties above this line. IMMPID_END_LIST(MPV) // This is the structure for the IMMPID_MPV_STORE_DRIVER_HANDLE property. typedef struct tagIMMP_MPV_STORE_DRIVER_HANDLE { GUID guidSignature; // signature of the store driver whose handle this is } IMMP_MPV_STORE_DRIVER_HANDLE; // Define message object creation flags // @const DWORD | MPV_INBOUND_CUTOFF_EXCEEDED | // Mailmsg configured cutoff has been exceeded... if this is an external // delivery attempt, we should indicate that we do not have sufficient // resources to accept the mail. #define MPV_INBOUND_CUTOFF_EXCEEDED 0x00000001 // @const DWORD | MPV_WRITE_CONTENT | // Indicates that the content of this message can be modified. #define MPV_WRITE_CONTENT 0x00000002 /*=======================================================================*/ // These are per-recipient volatile properties - they are not persisted to // the property stream. IMMPID_START_LIST(RPV,0x4000,"79E82049-D320-11d1-9FF4-00C04FA37348") // @const IMMPID | IMMPID_RPV_DONT_DELIVER | // IMMPID_RPV_DONT_DELIVER is a boolean. If set to TRUE, mailmsg // ignores this recipient when doing WriteList() (the recipient will // not exist in the new list). IMMPID_RPV_DONT_DELIVER, // @const IMMPID | IMMPID_RPV_NO_NAME_COLLISIONS | // IMMPID_RPV_NO_NAME_COLLISIONS is a boolean. If set to TRUE, mailmsg // does not detect duplicates with this recipient on future calls to // AddSecondary(). IMMPID_RPV_NO_NAME_COLLISIONS, // Add new per-recipient volatile properties above this line. IMMPID_END_LIST(RPV) // These are defined for backwards-compatability. They will be removed // ASAP... // @const DWORD | IMMPID_RP_DONT_DELIVER | // *** OBSOLETE *** #define IMMPID_RP_DONT_DELIVER IMMPID_RPV_DONT_DELIVER // @const DWORD | IMMPID_RP_NO_NAME_COLLISIONS | // *** OBSOLETE *** #define IMMPID_RP_NO_NAME_COLLISIONS IMMPID_RPV_NO_NAME_COLLISIONS /*=======================================================================*/ // These are the per-message properties for NNTP IMMPID_START_LIST(NMP,0x6000,"7433a9aa-20e2-11d2-94d6-00c04fa379f1") // @const IMMPID | IMMPID_NMP_SECONDARY_GROUPS | // An array of pointers to INNTPPropertyBag objects for each of // the newsgroups that the article is being posted into for the // current driver. IMMPID_NMP_SECONDARY_GROUPS, // @const IMMPID | IMMPID_NMP_SECONDARY_ARTNUM | // An array of article numbers for each of the newsgroups that // the article is being posted into for the current driver. IMMPID_NMP_SECONDARY_ARTNUM, // @const IMMPID | IMMPID_NMP_PRIMARY_GROUP | // A pointer to the INNTPPropertyBag object which represents the // primary group for the current driver. IMMPID_NMP_PRIMARY_GROUP, // @const IMMPID | IMMPID_NMP_PRIMARY_ARTID | // The primary article number for the primary group. IMMPID_NMP_PRIMARY_ARTID, // @const IMMPID | IMMPID_NMP_POST_TOKEN | // The HTOKEN representing the client context. IMMPID_NMP_POST_TOKEN, // @const IMMPID | IMMPID_NMP_NEWSGROUP_LIST | // The string of newsgroups which this article is being stored in. IMMPID_NMP_NEWSGROUP_LIST, // @const IMMPID | IMMPID_NMP_HEADERS | // A string containing the headers of the message. IMMPID_NMP_HEADERS, // @const IMMPID | IMMPID_NMP_NNTP_PROCESSING | // Flags which describe how the message should be processed. The // possible values are: NMP_PROCESS_POST, NMP_PROCESS_CONTROL, // and NMP_PROCESS_MODERATOR. IMMPID_NMP_NNTP_PROCESSING, // @const IMMPID | IMMPID_NMP_NNTP_APPROVED_HEADER | // A string containing the Approved: header of the message IMMPID_NMP_NNTP_APPROVED_HEADER, // Add new per-message properties above this line. IMMPID_END_LIST(NMP) // flags for IMMPID_NMP_NNTP_PROCESSING // @const DWORD | NMP_PROCESS_POST | // Set this flag to allow the NNTP server to post this message. #define NMP_PROCESS_POST 0x00000001 // @const DWORD | NMP_PROCESS_CONTROL | // Set this flag to allow the NNTP server to process control headers in this // message. #define NMP_PROCESS_CONTROL 0x00000002 // @const DWORD | NMP_PROCESS_MODERATOR | // Set this flag to allow the NNTP server to run this message through the // default moderated posting path. #define NMP_PROCESS_MODERATOR 0x00000004 /*=======================================================================*/ // This is the starting range for user-reserved properties IMMPID_START_LIST(CPV,0x8000,"A2A76B2A-E52D-11d1-AA64-00C04FA35B82") // @const IMMPID | IMMPID_CP_START | // Start of range IMMPID_CP_START, IMMPID_END_LIST(CPV) /*=======================================================================*/ // This table collects the data about the properties so that range- // checking can be performed. If any new property ranges are // defined, they must be added to this structure. #define IMMPID_DECLARE_ENTRY(name) {&_uuidof(tagIMMPID_##name##_STRUCT),\ IMMPID_##name##_BEFORE__+1,\ IMMPID_##name##_AFTER__-1} extern const __declspec(selectany) struct tagIMMPID_GUIDLIST_ITEM { const GUID *pguid; DWORD dwStart; DWORD dwLast; } IMMPID_GUIDS[] = {IMMPID_DECLARE_ENTRY(MP), IMMPID_DECLARE_ENTRY(RP), IMMPID_DECLARE_ENTRY(MPV), IMMPID_DECLARE_ENTRY(RPV), {&GUID_NULL,0,0}}; #endif // _MAILMSGPROPS_H_