Leaked source code of windows server 2003
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.
 
 
 
 
 
 

495 lines
18 KiB

cpp_quote("/*******************************************************************************/" )
cpp_quote("/* */" )
cpp_quote("/* Copyright © Microsoft Corporation. All rights reserved. */" )
cpp_quote("/* */" )
cpp_quote("/*******************************************************************************/" )
import "unknwn.idl";
import "transact.idl";
import "wbemcli.idl";
#define OPT
/********************************************************************
IWmiMessageSendReceive
This is the interface to send or receive messages. Anyone wishing to
receive messages implements this interfaces and passes it to a Wmi
Message Receiver instance. Anyone wishing to send messages obtains a
Wmi Message Sender instance which implements this interface.
The FlagsStatus parameter is used to specify flags when sending and
is used to specify a status when receiving.
Auxiliary Data can be sent with the message. Some implementations
may treat this data differently than the message data.
*********************************************************************/
[restricted, object, local, uuid(5BD9DF3C-6A1C-43c3-91C6-1CDDC0298083)]
interface IWmiMessageSendReceive : IUnknown
{
HRESULT SendReceive( [in,size_is(cData)] BYTE* pData,
[in] ULONG cData,
[in,size_is(cAuxData)] BYTE* pAuxData,
[in] ULONG cAuxData,
[in] DWORD dwFlagsStatus,
[in] OPT IUnknown* pContext );
};
/********************************************************************
IWmiMessageMultiSendReceive
This interface allows the one to send/receive messages to/from multiple
SendReceive instances using a single call to SendReceive on this interface.
Users build up the destination list using the Add() method.
*********************************************************************/
[restricted, object, local, uuid(0D1EE0A9-A096-43a0-ACF9-CED3D29EDC25)]
interface IWmiMessageMultiSendReceive : IWmiMessageSendReceive
{
HRESULT Add( [in] DWORD dwFlags, // currently specify 0.
[in] IWmiMessageSendReceive* pSndRcv );
};
/********************************************************************
IWmiMessageTraceSink
*********************************************************************/
[restricted, object, local, uuid(A4A01B0C-8B4A-4fcd-91CA-338548A61949)]
interface IWmiMessageTraceSink : IUnknown
{
HRESULT Notify( [in] HRESULT hr,
[in] GUID guidSource,
[in] OPT LPCWSTR wszTrace,
[in] OPT IUnknown* pContext );
};
/********************************************************************
IWmiMessageSender
This interface allows users to obtain an IWmiMessageSendReceive
interface that can be used to send messages. This interface is not
stateful, so multiple Open() calls can be made using the same or
different parameters without affecting instances obtained through
previous calls. Once an send interface is obtained, this interface
can also be released without affecting instances from previous calls.
*********************************************************************/
typedef struct tagWMIMSG_SNDR_AUTH_INFO
{
LPCWSTR wszTargetPrincipal;
LPCWSTR wszIdentity;
LPCWSTR wszDomain;
LPCWSTR wszPasswd;
} WMIMSG_SNDR_AUTH_INFO, *WMIMSG_SNDR_AUTH_INFOP;
[restricted, object, local, uuid(3049205F-47FC-4f17-9136-D843AEE1206F)]
interface IWmiMessageSender : IUnknown
{
HRESULT Open( [in] LPCWSTR wszTarget,
[in] DWORD dwFlags,
[in] WMIMSG_SNDR_AUTH_INFOP pAuthInfo,
[in] OPT LPCWSTR wszResponse,
[in] OPT IWmiMessageTraceSink* pTraceSink,
[out] IWmiMessageSendReceive** ppSend );
};
/********************************************************************
IWmiMessageReceiver
This interface allows users to specify an IWmiMessageSendReceive
interface that will be used to receive messages asynchronously.
Once the Open() method is called, the receiver will start listening and
servicing messages from the specified endpoint. The user must be prepared
for calls to be made to the SendReceive method during the Open() call.
To stop the servicing process, the user calls the Close() method.
Implementations will implicitly call this method when the last reference is
released and just before each Open() call. The Close() method is idempotent.
Only when Close() has returned, either from an implicit or explicit call,
can the user assume that no calls will be made to the callback interface.
The SendReceive instance can also implement the IWmiMessageTraceSink
interface to receive trace notifications. This interface will be used
only for errors occurring asynchronously, such as asynchronous receiving
errors. Any error returned from the methods of this interface will NOT
be reported to the error sink.
*********************************************************************/
typedef struct tagWMIMSG_RCVR_AUTH_INFO
{
LPCWSTR* awszPrincipal;
ULONG cwszPrincipal;
} WMIMSG_RCVR_AUTH_INFO, *WMIMSG_RCVR_AUTH_INFOP;
[restricted, object, local, uuid(B0CFB756-C5D8-4b04-BB64-3AF723166F53)]
interface IWmiMessageReceiver : IUnknown
{
HRESULT Open( [in] LPCWSTR wszEndpoint,
[in] DWORD dwFlags,
[in] WMIMSG_RCVR_AUTH_INFOP pAuthInfo,
[in] IWmiMessageSendReceive* pRecv );
HRESULT Close();
};
/****************************************************************************
IWmiMessageReceiverContext
****************************************************************************/
[restricted, object, local, uuid(42D36328-BBFF-4f0e-849B-BD520CF161B6)]
interface IWmiMessageReceiverContext : IUnknown
{
HRESULT GetTimeSent( [out] SYSTEMTIME* pTime );
HRESULT GetSendingMachine( [out,size_is(cMachine)] WCHAR* awchMachine,
[in] ULONG cMachine,
[out] ULONG* pcMachine );
HRESULT GetTarget( [out,size_is(cTarget)] WCHAR* awchTarget,
[in] ULONG cTarget,
[out] ULONG* pcTarget );
HRESULT GetSenderId( [out,size_is(cSenderId)] BYTE* achSenderId,
[in] ULONG cSenderId,
[out] ULONG* pcSenderId );
HRESULT IsSenderAuthenticated();
HRESULT ImpersonateSender();
HRESULT RevertToSelf();
};
/****************************************************************************
IWmiMessageQueueReceiver - receiver interface specific to Queues.
Implementations of this interface do not handle asynchronous receiving -
this is a syncrhonous interface. However, the callback approach is used
for received messages so that we can avoid unnecesary copying of messages.
This interface is not multithread safe since it implies that the message
is saved as state.
*****************************************************************************/
[restricted, object, local, uuid(4FB36328-BBFF-4f0e-849B-BD520CF161B6)]
interface IWmiMessageQueueReceiver : IUnknown
{
HRESULT ReceiveMessage( DWORD dwTimeout,
PVOID pCursor,
DWORD dwAction,
ITransaction* pTxn );
HRESULT CreateCursor( [out] PVOID* ppvCursor );
HRESULT DestroyCursor( [in] PVOID pvCursor );
};
/****************************************************************************
IWmiMessageQueue - interface for opening queues for receiving.
*****************************************************************************/
[restricted, object, local, uuid(E169E1E3-CC16-4dc2-A5B7-6C165C6B17F8)]
interface IWmiMessageQueue : IUnknown
{
HRESULT Open( [in] LPCWSTR wszEndpoint,
[in] DWORD dwFlags,
[in] OPT IWmiMessageSendReceive* pRecv,
[out] IWmiMessageQueueReceiver** ppRecvr );
};
/****************************************************************************
IWmiMessageQueueManager
*****************************************************************************/
[restricted, object, local, uuid(35F36F0E-9FD6-483f-94F9-CE0367863376)]
interface IWmiMessageQueueManager : IUnknown
{
HRESULT Create( [in] LPCWSTR wszPathName,
[in] GUID guidType,
[in] BOOL bAuth,
[in] DWORD dwQos,
[in] DWORD dwQuota,
[in] OPT PVOID pSecurityDescriptor );
HRESULT Destroy( [in] LPCWSTR wszName );
HRESULT GetAllNames( [in] GUID guidTypeFilter,
[in] BOOL bPrivateOnly,
[out] LPWSTR** ppwszNames,
[out] ULONG* pcNames );
};
/*************************************************************************
IWmiObjectMarshal - Interface for efficiently marshaling/unmarshaling
groups of wbem objects. Implementations of this interface can be stateful.
It will only marshal class information once. To release the state held
within the object, use Flush().
**************************************************************************/
[restricted, object, local, uuid(31C80872-1221-4907-BCB1-9BA58BE7847A)]
interface IWmiObjectMarshal : IUnknown
{
HRESULT Pack( [in] IWbemClassObject* pObj,
[in] LPCWSTR wszNamespace, // for undecorated objs
[in] DWORD dwFlags,
[in] ULONG cBuff,
[out,size_is(cBuff)] BYTE* pBuff,
[out] ULONG* pcUsed );
HRESULT Unpack( [in] ULONG cBuff,
[in,size_is(cBuff)] BYTE* pBuff,
[in] DWORD dwFlags,
[out] IWbemClassObject** ppObj,
[out] ULONG* pcUsed );
HRESULT Flush();
};
[restricted, object, local, uuid(5BD3213C-6A1C-43c3-91C6-1CDDC0298083)]
interface IWmiObjectAccess : IUnknown
{
HRESULT GetProp( LPVOID pHdl, DWORD dwFlags, VARIANT* pvar, CIMTYPE* pct );
HRESULT PutProp( LPVOID pHdl, DWORD dwFlags, VARIANT* pvar, CIMTYPE ct );
HRESULT SetObject( IWbemClassObject* pObj );
HRESULT GetObject( IWbemClassObject** ppObj );
HRESULT CommitChanges();
};
[restricted, object, local, uuid(5BD1233C-6A1C-43c3-91C6-1CDDC0298083)]
interface IWmiObjectAccessFactory : IUnknown
{
//
// optional call. is used to help optimize the accessors even more
//
HRESULT SetObjectTemplate( IWbemClassObject* pTemplate );
HRESULT GetObjectAccess( IWmiObjectAccess** ppAccess );
HRESULT GetPropHandle( LPCWSTR wszProp, DWORD dwFlags, LPVOID* ppHdl );
};
/***********************************************************************
IWmiMessageReceiverSink - INTERNAL ONLY
This interfaces encapsulates the logic of actually receiving and
handling incoming messages from a queue, network connection, etc..
The interface methods allow the receiving and handling to be broken
into two distinct tasks. This separation allows an overlapped i/o
receiving model to be supported.
This interface is implemented by Receivers. When they are activated,
through their Open() method, they hand their associated receiver sink
to a message service through the IWmiMessageService interface.
This is a stateful interface. It implies that there is a single
receive buffer associated with the sink.
Receiver Sinks that handle overlapped i/o pass the pOverlapped structure
to the actual receive operation.
************************************************************************/
[restricted, object, local, uuid(80CF2156-C5D8-4b04-BB64-3AF723166F53)]
interface IWmiMessageReceiverSink : IUnknown
{
HRESULT Receive( OPT void* pOverlapped );
HRESULT Notify( OPT void* pOverlapped );
};
/***********************************************************************
IWmiMessageService - INTERNAL ONLY
The message service interface encapsulates the logic of thread pooling
and overlapped i/o.
When receivers become active, they pass their IWmiMessageReceiverSink
implementation to the service using the Add() method. When receivers
become inactive, they remove themselves from the service using Remove().
It is important to note that a receiver is responsible for cancelling any
pending receive calls before calling remove. Failing to do this will
cause the Remove() method to hang. A receiver most often can do this by
closing their file handle.
Receivers that can handle overlapped i/o pass their file handle to the
service. This allows N receivers to be shared across M threads.
Receivers that do not handle overlapped i/o do not pass their file handle.
They will have their own dedicated thread.
************************************************************************/
[restricted, object, local, uuid(DAFB73A1-6E9E-483a-982A-0E51C039E18E)]
interface IWmiMessageService : IUnknown
{
HRESULT Add( [in] IWmiMessageReceiverSink* pSink,
[in] OPT HANDLE* phOverlappedFile,
[in] DWORD dwFlags,
[out] void** ppHdl );
HRESULT Remove( [in] void* pHdl );
};
[uuid(90B3BB2E-EAE8-40e9-A1D8-3A4CD7CDB648)]
library WmiMessage_v1
{
typedef enum tag_WMIMSG_MARSHAL_FLAG
{
WMIMSG_FLAG_MRSH_FULL = 0x00,
WMIMSG_FLAG_MRSH_PARTIAL = 0x01,
WMIMSG_FLAG_MRSH_FULL_ONCE = 0x02,
} WMIMSG_MARSHAL_FLAG;
typedef enum tag_WMIMSG_QOS_FLAG
{
WMIMSG_FLAG_QOS_SYNCHRONOUS = 0x00,
WMIMSG_FLAG_QOS_EXPRESS = 0x01,
WMIMSG_FLAG_QOS_GUARANTEED = 0x02,
WMIMSG_FLAG_QOS_XACT = 0x03
} WMIMSG_QOS_FLAG;
typedef enum tag_WMIMSG_SND_FLAG
{
WMIMSG_FLAG_SNDR_AUTHENTICATE = 0x10,
WMIMSG_FLAG_SNDR_ENCRYPT = 0x20,
WMIMSG_FLAG_SNDR_LAZY_INIT = 0x40,
WMIMSG_FLAG_SNDR_ACK = 0x80,
WMIMSG_FLAG_SNDR_NACK_ONLY = 0x100,
WMIMSG_FLAG_SNDR_PRIV_SIGN = 0x200
} WMIMSG_SND_FLAG;
typedef enum tag_WMIMSG_RCV_FLAG
{
WMIMSG_FLAG_RCVR_IMPERSONATE = 0x10,
WMIMSG_FLAG_RCVR_PRIV_VERIFY = 0x20,
WMIMSG_FLAG_RCVR_SECURE_ONLY = 0x30,
WMIMSG_FLAG_RCVR_ACK = 0x40
} WMIMSG_RCV_FLAG;
typedef enum tag_WMIMSG_FLAG_MASK
{
WMIMSG_MASK_QOS = 0x0f,
WMIMSG_MASK_SNDRRCVR = 0xfff0
} WMIMSG_FLAG_MASK;
typedef enum tag_WMIMSG_MULTISEND_FLAG
{
WMIMSG_FLAG_MULTISEND_RETURN_IMMEDIATELY = 0x1, // specified on Send
WMIMSG_FLAG_MULTISEND_TERMINATING_SENDER = 0x1, // specified on Add
} WMIMSG_MULTISEND_FLAG;
typedef enum tag_WMIMSG_STATUS
{
WMIMSG_E_MSGTOOLARGE = 0x80042100,
WMIMSG_E_AUTHFAILURE = 0x80042101,
WMIMSG_E_ENCRYPTFAILURE = 0x80042102,
WMIMSG_E_QOSFAILURE = 0x80042103,
WMIMSG_E_XACTFAILURE = 0x80042104,
WMIMSG_E_INVALIDADDRESS = 0x80042105,
WMIMSG_E_TARGETNOTFOUND = 0x80042106,
WMIMSG_E_INVALIDMESSAGE = 0x80042108,
WMIMSG_E_REQSVCNOTAVAIL = 0x80042109,
WMIMSG_E_TIMEDOUT = 0x80042110,
WMIMSG_E_EXCEEDEDQUOTA = 0x80042111,
WMIMSG_E_QUEUEPURGED = 0x80042112,
WMIMSG_E_TARGETNOTLISTENING = 0x80042113
} WMIMSG_STATUS;
typedef enum tag_WMIMSG_QRCV_ACTION
{
WMIMSG_ACTION_QRCV_PEEK_CURRENT = 0x1,
WMIMSG_ACTION_QRCV_PEEK_NEXT = 0x2,
WMIMSG_ACTION_QRCV_RECEIVE = 0x3,
WMIMSG_ACTION_QRCV_REMOVE = 0x4
} WMIMSG_QRCV_ACTION;
[restricted, uuid(122D47A6-CEEC-4de1-8056-B6D16F29BC97)]
coclass WmiMessageMsmqSender
{
interface IWmiMessageSender;
};
[restricted, uuid(9E007F18-9C24-4630-8B3E-61F96280C593)]
coclass WmiMessageMsmqReceiver
{
interface IWmiMessageReceiver;
};
[restricted, uuid(622D47B6-CEEC-4de1-8056-B6D16F29BC97)]
coclass WmiMessageRpcSender
{
interface IWmiMessageSender;
};
[restricted, uuid(9F007F18-9C24-4630-8B3E-61F96280C593)]
coclass WmiMessageRpcReceiver
{
interface IWmiMessageReceiver;
};
[restricted, uuid(89F9F7B0-8DE3-4ae0-8B41-109ABAB32151)]
coclass WmiMessageMultiSendReceive
{
interface IWmiMessageMultiSendReceive;
};
[restricted, uuid(C89DBDC4-5491-409a-8D00-E34538211FED)]
coclass WmiMessageQueue
{
interface IWmiMessageQueue;
};
[restricted, uuid(FF10E656-2B7C-421e-B145-7AB337FB865F)]
coclass WmiMessageQueueManager
{
interface IWmiMessageQueueManager;
};
[restricted, uuid(CE69CC1E-1EC0-4847-9C0D-D2F2D80D07CF)]
coclass WmiMessageService
{
// singleton
interface IWmiMessageService;
};
[restricted, uuid(C169CC11-1EC1-4847-9C0D-D2F2D80D07CF)]
coclass WmiSmartObjectMarshal
{
interface IWmiObjectMarshal;
};
[restricted, uuid(958c59a0-3670-4fe0-b893-6998bb494402)]
coclass WmiSmartObjectUnmarshal
{
interface IWmiObjectMarshal;
};
[restricted, uuid(C1692211-1EC1-4847-9C0D-D2F2D80D07CF)]
coclass WmiSmartObjectAccessFactory
{
interface IWmiObjectAccessFactory;
};
};