Source code of Windows XP (NT5)
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.

475 lines
21 KiB

  1. //-----------------------------------------------------------------------------
  2. //
  3. //
  4. // File: aqueue.idl
  5. //
  6. // Description: IDL source for aqueue.dll. Contains interface descriptions
  7. // for:
  8. // IAdvQueue
  9. // Exposes SubmitMessage via server event as well
  10. // as HandleFailedMessage.
  11. // IAdvQueueConfig
  12. // Allows SMTP service to configure AQ
  13. // IConnectionManager
  14. // Interface to SMTP for outbound connections
  15. // IAdvQueueDomainType
  16. // Interface passed to the default categorizer that
  17. // allows it to check if a domain is local or not.
  18. //
  19. // Author: mikeswa
  20. //
  21. // History:
  22. // 7/28/98 - MikeSwa Modified - added IAdvQueueDomainType and
  23. // HandleFailedMessage
  24. // 6/7/99 - MikeSwa Removed queue admin interface
  25. // Copyright (C) 1997 Microsoft Corporation
  26. //
  27. //-----------------------------------------------------------------------------
  28. import "oaidl.idl";
  29. import "ocidl.idl";
  30. import "mailmsg.idl";
  31. import "smtpevent.idl";
  32. import "perfcat.h";
  33. // Include aqdll.h to define the dll and function names and prototypes
  34. cpp_quote("#include \"aqdll.h\" ")
  35. //---[ eMessageStatus ]--------------------------------------------------------
  36. //
  37. //
  38. // Description: enum used to describe Message status on
  39. // ISMTPConnection::AckMessage
  40. //
  41. //-----------------------------------------------------------------------------
  42. typedef [v1_enum] enum
  43. {
  44. MESSAGE_STATUS_ALL_DELIVERED = 0x00000001, //everything succeed
  45. MESSAGE_STATUS_RETRY = 0x00000002, //need to retry message
  46. MESSAGE_STATUS_CHECK_RECIPS = 0x00000004, //send message through dsn code
  47. MESSAGE_STATUS_NDR_ALL = 0x00000008, //delivery failed -- NDR all recips
  48. MESSAGE_STATUS_DSN_NOT_SUPPORTED = 0x00000010, //remote system does not support DSN's
  49. MESSAGE_STATUS_EXTENDED_STATUS_CODES = 0x00000020, //Extended status codes returned
  50. MESSAGE_STATUS_RESERVED = 0xFF000000, //reserved for internal use
  51. } eMessageStatus ;
  52. cpp_quote("#define MESSAGE_STATUS_RETRY_ALL 0x00000002") //*** OBSOLETE ***
  53. //---[ eConnectionStatus ]-----------------------------------------------------
  54. //
  55. //
  56. // Description: enum used to describe connection status on
  57. // ISMTPConnection::AckConnection
  58. //
  59. //-----------------------------------------------------------------------------
  60. typedef [v1_enum] enum
  61. {
  62. CONNECTION_STATUS_OK = 0x00000000,
  63. CONNECTION_STATUS_FAILED = 0x00000001, //Initial Connection failed
  64. CONNECTION_STATUS_DROPPED = 0x00000002, //Initial Connection succeeded, but was later dropped
  65. CONNECTION_STATUS_FAILED_NDR_UNDELIVERED = 0x00000004, //NDR undelivered recipients
  66. CONNECTION_STATUS_FAILED_LOOPBACK = 0x00000010, //Connection configured as loop
  67. } eConnectionStatus ;
  68. //---[ eDomainInfoFlags ]------------------------------------------------------
  69. //
  70. // Description: Flags used to describe boolean per domain properties
  71. // See smtpevent.idl for the definition of the domain info flags.
  72. //
  73. //-----------------------------------------------------------------------------
  74. //---[ DomainInfo ]------------------------------------------------------------
  75. //
  76. //
  77. // Description: Struct passed back by ISMTPConnection::GetDomainInfo
  78. // (string size does not include '\0'). Also used to set per-domain
  79. // properties.
  80. //
  81. // String values that are returned in proc via GetDomainInfo will be
  82. // valid while the connection exists.
  83. //
  84. //-----------------------------------------------------------------------------
  85. typedef struct _DomainInfo
  86. {
  87. DWORD cbVersion; //version / size of info struct
  88. DWORD dwDomainInfoFlags; //OR'd eDomainInfoFlags
  89. DWORD cbDomainNameLength;
  90. LPSTR szDomainName; //Domain Name this info references
  91. DWORD cbETRNDomainNameLength;
  92. LPSTR szETRNDomainName; //Domain Name to send with ETRN
  93. DWORD cbSmartHostDomainNameLength;
  94. LPSTR szSmartHostDomainName; //Domain Name to connect as
  95. DWORD cbDropDirectoryLength;
  96. LPSTR szDropDirectory; //Directory to drop to
  97. DWORD cbAuthTypeLength;
  98. LPSTR szAuthType; //Arbitrary auth type string
  99. DWORD cbUserNameLength;
  100. LPSTR szUserName; //User name to authenticate with
  101. DWORD cbPasswordLength;
  102. LPSTR szPassword; //Password to authenticate with
  103. DWORD cEtrnDelayTime; //Delay between making connection and sending ETRN
  104. DWORD cbBlob;
  105. DWORD *pvBlob; //Blob associated with domain (used in relay restrictions)
  106. } DomainInfo ;
  107. //---[ eAQConfigInfoFlags ]----------------------------------------------------
  108. //
  109. //
  110. // Description: Flags describing which AQConfigInfo parameters to use (are
  111. // updated)
  112. //
  113. //-----------------------------------------------------------------------------
  114. typedef [v1_enum] enum
  115. {
  116. AQ_CONFIG_INFO_MAX_CON = 0x00000001, //Use cMaxConnections
  117. AQ_CONFIG_INFO_MAX_LINK = 0x00000002, //Use cMaxLinkConnections
  118. AQ_CONFIG_INFO_MIN_MSG = 0x00000004, //Use cMinMessagesPerConnection
  119. AQ_CONFIG_INFO_CON_WAIT = 0x00000008, //Use dwConnectionWaitMilliseconds
  120. AQ_CONFIG_INFO_CON_RETRY = 0x00000010, //Use dwConnectionWaitMilliseconds
  121. AQ_CONFIG_INFO_MSGCAT_DOMAIN = 0x00000020, //Use szMsgCatDomain
  122. AQ_CONFIG_INFO_MSGCAT_USER = 0x00000040, //Use szMsgCatUser
  123. AQ_CONFIG_INFO_MSGCAT_PASSWORD = 0x00000080, //Use szMsgCatPassword
  124. AQ_CONFIG_INFO_MSGCAT_BINDTYPE = 0x00000100, //Use szMsgCatBindType
  125. AQ_CONFIG_INFO_MSGCAT_SCHEMATYPE = 0x00000200, //Use szMsgCatSchemaType
  126. AQ_CONFIG_INFO_MSGCAT_HOST = 0x00000400, //Use szMsgCatHost
  127. AQ_CONFIG_INFO_MSGCAT_FLAGS = 0x00000800, //Use dwMsgCatFlags
  128. AQ_CONFIG_INFO_MSGCAT_NAMING_CONTEXT = 0x00001000, //Use szMsgCatNamingContext
  129. AQ_CONFIG_INFO_MSGCAT_TYPE = 0x00002000, //Use szMsgCatType
  130. AQ_CONFIG_INFO_MSGCAT_PORT = 0x00004000, //Use dwMsgCatPort
  131. AQ_CONFIG_INFO_EXPIRE_DELAY = 0x00008000, //Use dwDelayExpireMinutes
  132. AQ_CONFIG_INFO_EXPIRE_NDR = 0x00010000, //Use dwNDRExpireMinutes
  133. AQ_CONFIG_INFO_LOCAL_EXPIRE_DELAY = 0x00020000, //Use dwLocalDelayExpireMinutes
  134. AQ_CONFIG_INFO_LOCAL_EXPIRE_NDR = 0x00040000, //Use dwLocalNDRExpireMinutes
  135. AQ_CONFIG_INFO_DEFAULT_DOMAIN = 0x00080000, //Use szDefaultLocalDomain
  136. AQ_CONFIG_INFO_BADMAIL_DIR = 0x00100000, //Use szBadMailDir
  137. AQ_CONFIG_INFO_USE_DSN_OPTIONS = 0x00200000, //Use dwDSNOptions
  138. AQ_CONFIG_INFO_USE_DSN_LANGUAGE = 0x00400000, //Use dwDSNLanguageID
  139. AQ_CONFIG_INFO_MSGCAT_ENABLE = 0x00800000, //Use dwMsgCatEnable
  140. AQ_CONFIG_INFO_SEND_DSN_TO = 0x01000000, //Use send NDR to address
  141. AQ_CONFIG_INFO_MSGCAT_DEFAULT = 0x02000000, //Use defaults if params not set
  142. AQ_CONFIG_INFO_SERVER_FQDN = 0x04000000, //Use server FQDN
  143. AQ_CONFIG_INFO_ALL = 0x07FFFFFF, //Use all Fields
  144. } eAQConfigInfoFlags ;
  145. //---[ eDSNOptions ]-----------------------------------------------------------
  146. //
  147. //
  148. // Description:
  149. // Options flags for DSN options passed into AQueue.
  150. //
  151. //-----------------------------------------------------------------------------
  152. typedef [v1_enum] enum
  153. {
  154. DSN_OPTIONS_DEFAULT = 0x00000000,
  155. DSN_OPTIONS_DEFAULT_RET_HEADERS = 0x00000001,
  156. DSN_OPTIONS_DEFAULT_RET_FULL = 0x00000002,
  157. DSN_OPTIONS_IGNORE_MSG_RET = 0x00000004,
  158. DSN_OPTIONS_SEND_DELAY_DEFAULT = 0x00000008,
  159. DSN_OPTIONS_SEND_DELAY_UPON_REQUEST = 0x00000010,
  160. DSN_OPTIONS_SEND_DELAY_NEVER = 0x00000020,
  161. } eDSNOptions;
  162. //---[ AQConfigInfo ]----------------------------------------------------------
  163. //
  164. //
  165. // Description: Struct containing all dynamically set-able global AQ
  166. // properties
  167. //
  168. //-----------------------------------------------------------------------------
  169. typedef struct _AQConfigInfo
  170. {
  171. DWORD cbVersion; //version / size of into struct
  172. DWORD dwAQConfigInfoFlags; //Flags describing which info to update
  173. DWORD cMaxConnections; //Total maximum Connections
  174. DWORD cMaxLinkConnections; //Total number of connections per link
  175. DWORD cMinMessagesPerConnection; //Minimum # of message before creating
  176. //*additional* connection
  177. DWORD dwConnectionWaitMilliseconds; //# of milliseconds to in
  178. //GetNextConnection, before timing out and
  179. //retrying link objects
  180. DWORD dwConnectionRetryMilliseconds; //# of milliseconds wwait before
  181. //retrying failed connections
  182. DWORD dwRetryThreshold; //# of connections failures before we start
  183. DWORD dwFirstRetrySeconds; //Interval to hold when retrying for first time
  184. DWORD dwSecondRetrySeconds; //Interval to hold when retrying for second time
  185. DWORD dwThirdRetrySeconds; //Interval to hold when retrying for third time
  186. DWORD dwFourthRetrySeconds; //Interval to hold when retrying more than three times
  187. //credentials & config into used by MsgCat to athenticate against DS
  188. LPSTR szMsgCatDomain;
  189. LPSTR szMsgCatUser;
  190. LPSTR szMsgCatPassword;
  191. LPSTR szMsgCatBindType;
  192. LPSTR szMsgCatSchemaType;
  193. LPSTR szMsgCatHost;
  194. DWORD dwMsgCatPort;
  195. DWORD dwMsgCatFlags;
  196. DWORD dwMsgCatEnable;
  197. LPSTR szMsgCatNamingContext;
  198. LPSTR szMsgCatType;
  199. //Expiry information
  200. DWORD dwDelayExpireMinutes;
  201. DWORD dwNDRExpireMinutes;
  202. DWORD dwLocalDelayExpireMinutes;
  203. DWORD dwLocalNDRExpireMinutes;
  204. //Default local domain information
  205. LPSTR szDefaultLocalDomain;
  206. //Badmail handling
  207. LPSTR szBadMailDir;
  208. //DSN Configuration
  209. DWORD dwDSNOptions;
  210. DWORD dwDSNLanguageID;
  211. LPSTR szSendCopyOfNDRToAddress;
  212. LPSTR szServerFQDN;
  213. } AQConfigInfo;
  214. //---[ MessageAck ]------------------------------------------------------------
  215. //
  216. //
  217. // Description: Struct passed back with message acks.
  218. //
  219. //
  220. //-----------------------------------------------------------------------------
  221. typedef struct _MessageAck
  222. {
  223. IMailMsgProperties *pIMailMsgProperties; //IMailMsgProperties to Ack
  224. DWORD *pvMsgContext; //Context generated on GetNextMessage
  225. DWORD dwMsgStatus; //eMsgStatus flags
  226. DWORD dwStatusCode; //The DWORD version of the status code
  227. DWORD cbExtendedStatus; //size of extended status string
  228. LPSTR szExtendedStatus; //extended status -- valid only when
  229. //MESSAGE_STATUS_EXTENDED_STATUS_CODES is set
  230. } MessageAck ;
  231. //---[ eMessageFailureReasons ]------------------------------------------------
  232. //
  233. //
  234. // Description:
  235. // Enum describing the possible SMTP message failure reasons.
  236. //
  237. //-----------------------------------------------------------------------------
  238. typedef [v1_enum] enum
  239. {
  240. MESSAGE_FAILURE_GENERAL = 0x00000001,
  241. MESSAGE_FAILURE_HOP_COUNT_EXCEEDED = 0x00000002, //Hop count on message exceeds max
  242. MESSAGE_FAILURE_BAD_PICKUP_DIR_FILE = 0x00000003, //Unable to process pickup dir file
  243. } eMessageFailureReasons;
  244. //---[ ISMTPConnection ]-------------------------------------------------------
  245. //
  246. //
  247. // Description: Interface used by SMTP to represent a single outbound
  248. // connection.
  249. //
  250. //
  251. //-----------------------------------------------------------------------------
  252. [
  253. object,
  254. local,
  255. uuid(838258A5-4EEB-11D1-B2CD-00C04FC32984),
  256. helpstring("ISMTPConnection Interface"),
  257. pointer_default(unique)
  258. ]
  259. interface ISMTPConnection : IUnknown
  260. {
  261. [helpstring("method AckConnection")] HRESULT AckConnection(
  262. [in] DWORD dwConnectionStatus);
  263. [helpstring("method GetDomainInfo")] HRESULT GetDomainInfo(
  264. [in, out] DomainInfo *pDomainInfo);
  265. [helpstring("method GetNextMessage")] HRESULT GetNextMessage(
  266. [out] IMailMsgProperties **ppIMailMsgProperties,
  267. [out] DWORD **ppvMsgContext,
  268. [in, out] DWORD *pcIndexes,
  269. [out, size_is(*pcIndexes)] DWORD *prgdwRecipIndex[]);
  270. [helpstring("method AckMessage")] HRESULT AckMessage(
  271. [in] MessageAck *pMsgAck);
  272. [helpstring("method SetDiagnosticInfo")] HRESULT SetDiagnosticInfo(
  273. [in] HRESULT hrDiagnosticError,
  274. [in, string] LPCSTR szDiagnosticVerb,
  275. [in, string] LPCSTR szDiagnosticResponse);
  276. };
  277. //---[ IConnectionManager ]----------------------------------------------------
  278. //
  279. //
  280. // Description: Interface used by SMTP to Get outbound connections and
  281. // to handle TURN, ETRN, and ATRN requests
  282. //
  283. //
  284. //-----------------------------------------------------------------------------
  285. [
  286. object,
  287. local,
  288. uuid(B198B19B-C346-11d1-A67D-00C04FA3490A),
  289. helpstring("IConnectionManager Interface"),
  290. pointer_default(unique)
  291. ]
  292. interface IConnectionManager : IUnknown
  293. {
  294. //method that waits until an outbound connection can be created
  295. [helpstring("method GetNextConnection")] HRESULT GetNextConnection(
  296. [out, retval] ISMTPConnection **ppISMTPConnection);
  297. //Used to get a connection for TURN and ATRN. The domain must be
  298. //configured as TURN or ATRN.
  299. [helpstring("method GetNamedConnection")] HRESULT GetNamedConnection(
  300. [in] DWORD cbSMTPDomain,
  301. [in, size_is(cbSMTPDomain + 1)] CHAR szSMTPDomain[],
  302. [out] ISMTPConnection **ppISMTPConnection);
  303. //Used to release threads waiting in GetNextConnection for shutdown
  304. [helpstring("method ReleaseWaitingThreads")] HRESULT ReleaseWaitingThreads();
  305. //Used to request that a connection be created in GetNextConnection
  306. //for the given domain. The domain must be configured as an ETRN
  307. //domain.
  308. [helpstring("method ETRNDomain")] HRESULT ETRNDomain(
  309. [in] DWORD cbSMTPDomain,
  310. [in, size_is(cbSMTPDomain + 1)] CHAR szSMTPDomain[],
  311. [out] DWORD *pcMessages);
  312. };
  313. //---[ IAdvQueue ]-------------------------------------------------------------
  314. //
  315. //
  316. // Description: Public interface that exposes servier-wide SubmitMessage
  317. // (eventually through a server event). For MM1, both SMTP an the MAPI
  318. // driver will use this to queueu messages for delivery,
  319. //
  320. //
  321. //-----------------------------------------------------------------------------
  322. [
  323. object,
  324. uuid(838258A9-4EEB-11D1-B2CD-00C04FC32984),
  325. helpstring("IAdvQueue Interface"),
  326. pointer_default(unique)
  327. ]
  328. interface IAdvQueue : IUnknown
  329. {
  330. [helpstring("method SubmitMessage")] HRESULT SubmitMessage(
  331. [in] IMailMsgProperties *pIMailMsgProperties);
  332. [helpstring("method HandleFailedMessage")] HRESULT HandleFailedMessage(
  333. [in] IMailMsgProperties *pIMailMsgProperties,
  334. [in] BOOL fUseIMailMsgProperties,
  335. [in] LPSTR szFileName,
  336. [in] DWORD dwFailureDescription,
  337. [in] HRESULT hrFailureCode);
  338. };
  339. //---[ AQPerfCounters ]------------------------------------------------------------
  340. //
  341. //
  342. // Description: Struct containing A/Q perf counters
  343. //
  344. //
  345. //-----------------------------------------------------------------------------
  346. typedef struct _AQPerfCounters
  347. {
  348. DWORD cbVersion; //version / size of struct
  349. DWORD cMsgsDeliveredLocal;
  350. DWORD cCurrentMsgsPendingCat;
  351. DWORD cCurrentMsgsPendingRemoteDelivery;
  352. DWORD cCurrentMsgsPendingLocalDelivery;
  353. DWORD cCurrentMsgsPendingRemoteRetry;
  354. DWORD cCurrentMsgsPendingLocalRetry;
  355. DWORD cCurrentQueueMsgInstances;
  356. DWORD cTotalMsgRemoteSendRetries;
  357. DWORD cTotalMsgLocalRetries;
  358. DWORD cNDRsGenerated;
  359. DWORD cDelayedDSNsGenerated;
  360. DWORD cDeliveredDSNsGenerated;
  361. DWORD cRelayedDSNsGenerated;
  362. DWORD cExpandedDSNsGenerated;
  363. DWORD cCurrentRemoteDestQueues;
  364. DWORD cCurrentRemoteNextHopLinks;
  365. DWORD cCurrentRemoteNextHopLinksEnabled;
  366. DWORD cCurrentRemoteNextHopLinksPendingRetry;
  367. DWORD cCurrentRemoteNextHopLinksPendingScheduling;
  368. DWORD cCurrentRemoteNextHopLinksPendingTURNETRN;
  369. DWORD cCurrentRemoteNextHopLinksFrozenByAdmin;
  370. DWORD cTotalMsgsTURNETRN;
  371. DWORD cTotalMsgsBadmailNoRecipients;
  372. DWORD cTotalMsgsBadmailHopCountExceeded;
  373. DWORD cTotalMsgsBadmailFailureGeneral;
  374. DWORD cTotalMsgsBadmailBadPickupFile;
  375. DWORD cTotalMsgsBadmailEvent;
  376. DWORD cTotalMsgsBadmailNdrOfDsn;
  377. DWORD cCurrentMsgsPendingRouting;
  378. DWORD cCurrentMsgsPendingUnreachableLink;
  379. DWORD cTotalMsgsSubmitted;
  380. DWORD cTotalDSNFailures;
  381. DWORD cCurrentMsgsInLocalDelivery;
  382. } AQPerfCounters ;
  383. //---[ IAdvQueueConfig ]-------------------------------------------------------
  384. //
  385. //
  386. // Description: Configuration interface... used by SMTP to set global
  387. // and per-domain configuration info. GetDomainInfo will match the
  388. // closest configured wildcard domain if no exact match is found. For
  389. // example, dino.exchange.microsoft.com will match *.microsoft.com if
  390. // dino.exchange.microsoft.com and *.exchange.microsoft,com have no
  391. // specific config info.
  392. //
  393. //
  394. //-----------------------------------------------------------------------------
  395. [
  396. object,
  397. local,
  398. uuid(EABA472E-BE94-11d1-A678-00C04FA3490A),
  399. helpstring("IAdvQueueConfig Interface"),
  400. pointer_default(unique)
  401. ]
  402. interface IAdvQueueConfig : IUnknown
  403. {
  404. //set the global config info for this server instance
  405. [helpstring("method SetConfigInfo")] HRESULT SetConfigInfo(
  406. [in] AQConfigInfo *pAQConfigInfo);
  407. //set the domain configuration info for a specified domain
  408. [helpstring("method SetDomainInfo")] HRESULT SetDomainInfo(
  409. [in] DomainInfo *pDomainInfo);
  410. //get the domain config info... will handle wildcard matching
  411. [helpstring("method GetDomainInfo")] HRESULT GetDomainInfo(
  412. [in] DWORD cbDomainNameLength,
  413. [in, size_is(cbDomainNameLength+1)] CHAR szDomainName[],
  414. [in, out] DomainInfo *pDomainInfo,
  415. [out] DWORD **ppvDomainContext);
  416. //Releases references memory allocated in GetDomainInfo
  417. [helpstring("method ReleaseDomainInfo")] HRESULT ReleaseDomainInfo(
  418. [in] DWORD *pvDomainContext);
  419. //get A/Q perf counters
  420. [helpstring("method GetPerfCounters")] HRESULT GetPerfCounters(
  421. [out] AQPerfCounters *pAQPerfCounters,
  422. [out] PCATPERFBLOCK pCatPerfCounters);
  423. [helpstring("method ResetPerfCounters")] HRESULT ResetPerfCounters();
  424. //Used to start/finish an update
  425. [helpstring("method StartConfigUpdate")] HRESULT StartConfigUpdate();
  426. [helpstring("method FinishConfigUpdate")] HRESULT FinishConfigUpdate();
  427. };
  428. //---[ IAdvQueueDomainType ]---------------------------------------------------
  429. //
  430. //
  431. // Description:
  432. // Interface passed to the default categorizer that allows it to check if
  433. // a domain is local or not.
  434. // The methods are defined in ICategorizerDomainInfo/smtpevent.idl.
  435. //
  436. //-----------------------------------------------------------------------------
  437. [
  438. object,
  439. uuid(47EA42AD-2667-11d2-A68B-00C04FA3490A),
  440. helpstring("IAdvQueueDomainType Interface"),
  441. ]
  442. interface IAdvQueueDomainType : ICategorizerDomainInfo
  443. {
  444. }