876 lines
21 KiB
C
Raw Normal View History

2001-01-01 00:00:00 +01:00
/*++
Copyright (c) 1997-1999 Microsoft Corporation.
All rights reserved.
MODULE NAME:
ismapi.h
ABSTRACT:
Service-to-ISM (Intersite Messaging) service API and
ISM-to-plug-in-transport API.
DETAILS:
CREATED:
97/11/26 Jeff Parham (jeffparh)
REVISION HISTORY:
--*/
#ifndef __ISMAPI_H__
#define __ISMAPI_H__
#if _MSC_VER > 1000
#pragma once
#endif
// User-defined control
#define ISM_SERVICE_CONTROL_REMOVE_STOP 0x00000080
#ifndef ISM_STRUCTS_DEFINED
#define ISM_STRUCTS_DEFINED
//==============================================================================
//
// ISM_MSG structure contains the message data (as a byte blob).
//
// Note: pszSubject is permitted to be NULL
typedef struct _ISM_MSG {
DWORD cbData;
#ifdef MIDL_PASS
[ref,size_is(cbData)] BYTE * pbData;
[string] LPWSTR pszSubject;
#else
BYTE * pbData;
LPWSTR pszSubject;
#endif
} ISM_MSG, *PISM_MSG;
typedef ISM_MSG ISM_MSG_V1, *PISM_MSG_V1;
////////////////////////////////////////////////////////////////////////////////
//
// ISM_SITE_CONNECTIVITY structure describes how sites are interconnected via
// a specific transport.
//
// The pulCosts element should be interpreted as a multidimensional array.
// pLinkValues[i*cNumSites + j].ulCost is the cost of communication from site
// pSiteDNs[i] to site pSiteDNs[j].
//
typedef struct _ISM_LINK {
ULONG ulCost;
ULONG ulReplicationInterval;
ULONG ulOptions;
} ISM_LINK, *PISM_LINK;
typedef struct _ISM_CONNECTIVITY {
ULONG cNumSites;
#ifdef MIDL_PASS
[ref, string, size_is(cNumSites)] LPWSTR * ppSiteDNs;
[ref, size_is(cNumSites * cNumSites)] ISM_LINK * pLinkValues;
#else
LPWSTR * ppSiteDNs;
ISM_LINK * pLinkValues;
#endif
} ISM_CONNECTIVITY, *PISM_CONNECTIVITY;
////////////////////////////////////////////////////////////////////////////////
//
// ISM_SERVER_LIST structure describes a set of servers, identified by DN.
//
typedef struct _ISM_SERVER_LIST {
DWORD cNumServers;
#ifdef MIDL_PASS
[ref, string, size_is(cNumServers)]
LPWSTR * ppServerDNs;
#else
LPWSTR * ppServerDNs;
#endif
} ISM_SERVER_LIST, *PISM_SERVER_LIST;
////////////////////////////////////////////////////////////////////////////////
//
// ISM_SCHEDULE structure describes a schedule on which two sites are
// connected. The byte stream should be interpreted as a SCHEDULE structure,
// as defined in \nt\public\sdk\inc\schedule.h.
//
typedef struct _ISM_SCHEDULE {
DWORD cbSchedule;
#ifdef MIDL_PASS
[ref, size_is(cbSchedule)] BYTE * pbSchedule;
#else
BYTE * pbSchedule;
#endif
} ISM_SCHEDULE, *PISM_SCHEDULE;
////////////////////////////////////////////////////////////////////////////////
//
// ISM_SITE_COST_INFO structure gives the cost between two sites and an error
// code. If the error code is non-zero, the cost should be considered invalid.
//
// ISM_SITE_COST_INFO_ARRAY is a simple wrapper for an array of
// ISM_SITE_COST_INFO structures which includes the length.
//
typedef struct _ISM_SITE_COST_INFO {
DWORD dwErrorCode;
DWORD dwCost;
} ISM_SITE_COST_INFO, *PISM_SITE_COST_INFO;
typedef struct _ISM_SITE_COST_INFO_ARRAY {
DWORD cToSites;
#ifdef MIDL_PASS
[ref,size_is(cToSites)] ISM_SITE_COST_INFO* rgCostInfo;
#else
ISM_SITE_COST_INFO* rgCostInfo;
#endif
DWORD dwFlags;
} ISM_SITE_COST_INFO_ARRAY, *PISM_SITE_COST_INFO_ARRAY;
////////////////////////////////////////////////////////////////////////////////
// Refresh reason codes
typedef enum _ISM_REFRESH_REASON_CODE {
ISM_REFRESH_REASON_RESERVED = 0,
ISM_REFRESH_REASON_TRANSPORT,
ISM_REFRESH_REASON_SITE,
ISM_REFRESH_REASON_MAX // always last
} ISM_REFRESH_REASON_CODE;
// Shutdown reason codes
typedef enum _ISM_SHUTDOWN_REASON_CODE {
ISM_SHUTDOWN_REASON_RESERVED = 0,
ISM_SHUTDOWN_REASON_NORMAL,
ISM_SHUTDOWN_REASON_REMOVAL,
ISM_SHUTDOWN_REASON_MAX // always last
} ISM_SHUTDOWN_REASON_CODE;
#endif // #ifndef ISM_STRUCTS_DEFINED
#ifdef __cplusplus
extern "C" {
#endif
#ifndef MIDL_PASS
//==============================================================================
//
// Service-to-ISM (Intersite Messaging) service API.
//
DWORD
I_ISMSend(
IN const ISM_MSG * pMsg,
IN LPCWSTR pszServiceName,
IN LPCWSTR pszTransportDN,
IN LPCWSTR pszTransportAddress
);
/*++
Routine Description:
Sends a message to a service on a remote machine. If the client specifies a
NULL transport, the lowest cost transport will be used.
Arguments:
pMsg (IN) - The data to send.
pszServiceName (IN) - Service to which to send the message.
pszTransportDN (IN) - The DN of the Inter-Site-Transport object
corresponding to the transport by which the message should be sent.
pszTransportAddress (IN) - The transport-specific address to which to send
the message.
Return Values:
NO_ERROR - Message successfully queued for send.
other - Failure.
--*/
DWORD
I_ISMReceive(
IN LPCWSTR pszServiceName,
IN DWORD dwMsecToWait,
OUT ISM_MSG ** ppMsg
);
/*++
Routine Description:
Receives a message addressed to the given service on the local machine.
If successful and no message is waiting, immediately returns a NULL message.
If a non-NULL message is returned, the caller is responsible for eventually
calling I_ISMFree()'ing the returned message.
Arguments:
pszServiceName (IN) - Service for which to receive the message.
dwMsecToWait (IN) - Milliseconds to wait for message if none is immediately
available; in the range [0, INFINITE].
ppMsg (OUT) - On successful return, holds a pointer to the received message
or NULL.
Return Values:
NO_ERROR - Message successfully returned (or NULL was returned,
indicating no message is waiting).
other - Failure.
--*/
void
I_ISMFree(
IN VOID * pv
);
/*++
Routine Description:
Frees memory allocated on the behalf of the client by I_ISM* APIs.
Arguments:
pv (IN) - Memory to free.
Return Values:
None.
--*/
DWORD
I_ISMGetConnectivity(
IN LPCWSTR pszTransportDN,
OUT ISM_CONNECTIVITY ** ppConnectivity
);
/*++
Routine Description:
Compute the costs associated with transferring data amongst sites via a
specific transport.
On successful return, it is the client's responsibility to eventually call
I_ISMFree(*ppConnectivity);
Arguments:
pszTransportDN (IN) - The transport for which to query costs.
ppConnectivity (OUT) - On successful return, holds a pointer to the
ISM_CONNECTIVITY structure describing the interconnection of sites
along the given transport.
Return Values:
NO_ERROR - Success.
ERROR_* - Failure.
--*/
DWORD
I_ISMGetTransportServers(
IN LPCWSTR pszTransportDN,
IN LPCWSTR pszSiteDN,
OUT ISM_SERVER_LIST ** ppServerList
);
/*++
Routine Description:
Retrieve the DNs of servers in a given site that are capable of sending and
receiving data via a specific transport.
On successful return, it is the client's responsibility to eventually call
I_ISMFree(*ppServerList);
Arguments:
pszTransportDN (IN) - Transport to query.
pszSiteDN (IN) - Site to query.
ppServerList - On successful return, holds a pointer to a structure
containing the DNs of the appropriate servers or NULL. If NULL, any
server with a value for the transport address type attribute can be
used.
Return Values:
NO_ERROR - Success.
ERROR_* - Failure.
--*/
DWORD
I_ISMGetConnectionSchedule(
LPCWSTR pszTransportDN,
LPCWSTR pszSite1DN,
LPCWSTR pszSite2DN,
ISM_SCHEDULE ** ppSchedule
);
/*++
Routine Description:
Retrieve the schedule by which two given sites are connected via a specific
transport.
On successful return, it is the client's responsibility to eventually call
I_ISMFree(*ppSchedule);
Arguments:
pszTransportDN (IN) - Transport to query.
pszSite1DN, pszSite2DN (IN) - Sites to query.
ppSchedule - On successful return, holds a pointer to a structure
describing the schedule by which the two given sites are connected via
the transport, or NULL if the sites are always connected.
Return Values:
NO_ERROR - Success.
ERROR_* - Failure.
--*/
DWORD
I_ISMQuerySitesByCost(
LPCWSTR pszTransportDN, // in
LPCWSTR pszFromSite, // in
DWORD cToSites, // in
LPCWSTR* rgszToSites, // in
DWORD dwFlags, // in
ISM_SITE_COST_INFO_ARRAY** prgSiteInfo // out
);
/*++
Routine Description:
Determine the individual costs between the From site and the To sites.
On successful return, it is the client's responsibility to eventually call
I_ISMFree(*prgSiteInfo);
Arguments:
pszTransportDN (IN) - Transport to query.
pszFromSite (IN) - The distinguished name of the From site.
rgszToSites (IN) - An array containing the distinguished names of the To sites.
cToSites (IN) - The number of entries in the rgszToSites array.
dwFlags (IN) - Unused.
prgSiteInfo (IN) - On successful return, holds a pointer to a structure
containing the costs between the From site and the To sites.
Return Values:
NO_ERROR - Success.
ERROR_* - Failure.
--*/
//==============================================================================
//
// ISM-to-plug-in-transport API.
//
typedef void ISM_NOTIFY(
IN HANDLE hNotify,
IN LPCWSTR pszServiceName
);
/*++
Routine Description:
Called by the plug-in to notify the ISM service that a message has been
received for the given service.
Arguments:
hNotify (IN) - Notification handle, as passed to the plug-in in the
IsmStartup() call.
pszServiceName (IN) - Service for which a message was received.
Return Values:
None.
--*/
typedef DWORD ISM_STARTUP(
IN LPCWSTR pszTransportDN,
IN ISM_NOTIFY * pNotifyFunction,
IN HANDLE hNotify,
OUT HANDLE *phIsm
);
ISM_STARTUP IsmStartup;
/*++
Routine Description:
Initialize the plug-in.
Arguments:
pszTransportDN (IN) - The DN of the Inter-Site-Transport that named this
DLL as its plug-in. The DS object may contain additional configuration
information for the transport (e.g., the name of an SMTP server for
an SMTP transport).
pNotifyFunction (IN) - Function to call to notify the ISM service of pending
messages.
hNotify (IN) - Parameter to supply to the notify function.
phIsm (OUT) - On successful return, holds a handle to be used in
future calls to the plug-in for the named Inter-Site-Transport. Note
that it is possible for more than one Inter-Site-Transport object to
name a given DLL as its plug-in, in which case IsmStartup() will be
called for each such object.
Return Values:
NO_ERROR - Successfully initialized.
other - Failure.
--*/
typedef DWORD ISM_REFRESH(
IN HANDLE hIsm,
IN ISM_REFRESH_REASON_CODE eReason,
IN LPCWSTR pszObjectDN OPTIONAL
);
ISM_REFRESH IsmRefresh;
/*++
Routine Description:
Called whenever changes occur according to the reason code.
One reason is to the Inter-Site-Transport object specified in the
IsmStartup() call.
Another is a change to a site in the sites container.
Arguments:
hIsm (IN) - Handle returned by a prior call to IsmStartup().
dwReason (IN) - Dword indicating the reason we were called
pszObjectDN (IN) - Object DN relating to the reason
(Current) DN of the Inter-Site-Transport object that
named this DLL as its plug-in. Note that this DN will differ from that
specified in IsmStartup() if the transport DN has been renamed.
Site DN of site that was added, renamed or deleted
Return Values:
NO_ERROR - Successfully updated.
other - Failure. A failure return implies the plug-in has shut down (i.e.,
no further calls will be made on hIsm, including an
IsmShutdown()).
--*/
typedef DWORD ISM_SEND(
IN HANDLE hIsm,
IN LPCWSTR pszRemoteTransportAddress,
IN LPCWSTR pszServiceName,
IN const ISM_MSG * pMsg
);
ISM_SEND IsmSend;
/*++
Routine Description:
Send a message over this transport.
Arguments:
hIsm (IN) - Handle returned by a prior call to IsmStartup().
pszRemoteTransportAddress (IN) - Transport address of the destination
server.
pszServiceName (IN) - Name of the service on the remote machine that is the
intended receiver of the message.
pMsg (IN) - Message to send.
Return Values:
NO_ERROR - Message successfully queued for send.
other - Failure.
--*/
typedef DWORD ISM_RECEIVE(
IN HANDLE hIsm,
IN LPCWSTR pszServiceName,
OUT ISM_MSG ** ppMsg
);
ISM_RECEIVE IsmReceive;
/*++
Routine Description:
Return the next waiting message (if any). If no message is waiting, a NULL
message is returned. If a non-NULL message is returned, the ISM service
is responsible for calling IsmFreeMsg(hIsm, *ppMsg) when the message is no
longer needed.
If a non-NULL message is returned, it is immediately dequeued. (I.e., once
a message is returned through IsmReceive(), the transport is free to destroy
it.)
Arguments:
hIsm (IN) - Handle returned by a prior call to IsmStartup().
ppMsg (OUT) - On successful return, holds a pointer to the received message
or NULL.
Return Values:
NO_ERROR - Message successfully returned (or NULL was returned,
indicating no message is waiting).
other - Failure.
--*/
typedef void ISM_FREE_MSG(
IN HANDLE hIsm,
IN ISM_MSG * pMsg
);
ISM_FREE_MSG IsmFreeMsg;
/*++
Routine Description:
Frees a message returned by IsmReceive().
Arguments:
hIsm (IN) - Handle returned by a prior call to IsmStartup().
pMsg (IN) - Message to free.
Return Values:
None.
--*/
typedef DWORD ISM_GET_CONNECTIVITY(
IN HANDLE hIsm,
OUT ISM_CONNECTIVITY ** ppConnectivity
);
ISM_GET_CONNECTIVITY IsmGetConnectivity;
/*++
Routine Description:
Compute the costs associated with transferring data amongst sites.
On successful return, the ISM service will eventually call
IsmFreeConnectivity(hIsm, *ppConnectivity);
Arguments:
hIsm (IN) - Handle returned by a prior call to IsmStartup().
ppConnectivity (OUT) - On successful return, holds a pointer to the
ISM_CONNECTIVITY structure describing the interconnection of sites
along this transport.
Return Values:
NO_ERROR - Success.
ERROR_* - Failure.
--*/
typedef void ISM_FREE_CONNECTIVITY(
IN HANDLE hIsm,
IN ISM_CONNECTIVITY * pConnectivity
);
ISM_FREE_CONNECTIVITY IsmFreeConnectivity;
/*++
Routine Description:
Frees the structure returned by IsmGetConnectivity().
Arguments:
hIsm (IN) - Handle returned by a prior call to IsmStartup().
pSiteConnectivity (IN) - Structure to free.
Return Values:
None.
--*/
typedef DWORD ISM_GET_TRANSPORT_SERVERS(
IN HANDLE hIsm,
IN LPCWSTR pszSiteDN,
OUT ISM_SERVER_LIST ** ppServerList
);
ISM_GET_TRANSPORT_SERVERS IsmGetTransportServers;
/*++
Routine Description:
Retrieve the DNs of servers in a given site that are capable of sending and
receiving data via this transport.
On successful return of a non-NULL list, the ISM service will eventually call
IsmFreeTransportServers(hIsm, *ppServerList);
Arguments:
hIsm (IN) - Handle returned by a prior call to IsmStartup().
pszSiteDN (IN) - Site to query.
ppServerList - On successful return, holds a pointer to a structure
containing the DNs of the appropriate servers or NULL. If NULL, any
server with a value for the transport address type attribute can be
used.
Return Values:
NO_ERROR - Success.
ERROR_* - Failure.
--*/
typedef void ISM_FREE_TRANSPORT_SERVERS(
IN HANDLE hIsm,
IN ISM_SERVER_LIST * pServerList
);
ISM_FREE_TRANSPORT_SERVERS IsmFreeTransportServers;
/*++
Routine Description:
Frees the structure returned by IsmGetTransportServers().
Arguments:
hIsm (IN) - Handle returned by a prior call to IsmStartup().
pServerList (IN) - Structure to free.
Return Values:
None.
--*/
typedef DWORD ISM_GET_CONNECTION_SCHEDULE(
IN HANDLE hIsm,
IN LPCWSTR pszSite1DN,
IN LPCWSTR pszSite2DN,
OUT ISM_SCHEDULE ** ppSchedule
);
ISM_GET_CONNECTION_SCHEDULE IsmGetConnectionSchedule;
/*++
Routine Description:
Retrieve the schedule by which two given sites are connected via this
transport.
On successful return, it is the ISM service's responsibility to eventually
call IsmFreeSchedule(*ppSchedule);
Arguments:
hIsm (IN) - Handle returned by a prior call to IsmStartup().
pszSite1DN, pszSite2DN (IN) - Sites to query.
ppSchedule - On successful return, holds a pointer to a structure
describing the schedule by which the two given sites are connected via
the transport, or NULL if the sites are always connected.
Return Values:
NO_ERROR - Success.
ERROR_* - Failure.
--*/
typedef void ISM_FREE_CONNECTION_SCHEDULE(
IN HANDLE hIsm,
IN ISM_SCHEDULE * pSchedule
);
ISM_FREE_CONNECTION_SCHEDULE IsmFreeConnectionSchedule;
/*++
Routine Description:
Frees the structure returned by IsmGetTransportServers().
Arguments:
hIsm (IN) - Handle returned by a prior call to IsmStartup().
pSchedule (IN) - Structure to free.
Return Values:
None.
--*/
typedef void ISM_SHUTDOWN(
IN HANDLE hIsm,
IN ISM_SHUTDOWN_REASON_CODE eReason
);
ISM_SHUTDOWN IsmShutdown;
/*++
Routine Description:
Uninitialize transport plug-in.
Arguments:
hIsm (IN) - Handle returned by a prior call to IsmStartup().
Return Values:
None.
--*/
typedef DWORD ISM_QUERY_SITES_BY_COST(
IN HANDLE hIsm,
IN LPCWSTR pszFromSite,
IN DWORD cToSites,
IN LPCWSTR* rgszToSites,
IN DWORD dwFlags,
OUT ISM_SITE_COST_INFO_ARRAY** prgSiteInfo
);
/*++
Routine Description:
Determine the individual costs between the From site and the To sites.
Arguments:
pszFromSite (IN) - The distinguished name of the From site.
rgszToSites (IN) - An array containing the distinguished names of the To sites.
cToSites (IN) - The number of entries in the rgszToSites array.
dwFlags (IN) - Unused.
prgSiteInfo (IN) - On successful return, holds a pointer to a structure
containing the costs between the From site and the To sites.
Return Values:
NO_ERROR - Success.
ERROR_* - Failure.
--*/
typedef void ISM_FREE_SITE_COST_INFO(
IN HANDLE hIsm,
IN ISM_SITE_COST_INFO_ARRAY *rgSiteCostInfo
);
/*++
Routine Description:
Frees the structure returned by ISM_QUERY_SITES_BY_COST().
Arguments:
hIsm (IN) - Handle returned by a prior call to IsmStartup().
rgSiteCostInfo (IN) - Structure to free.
Return Values:
None.
--*/
#endif // #ifndef MIDL_PASS
#ifdef __cplusplus
}
#endif
#endif // __ISMAPI_H__