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.
 
 
 
 
 
 

179 lines
6.4 KiB

/****************************************************************************/
// itssd.idl
//
// Terminal Server Session Directory Interface (ITSSessionDirectory) COM IDL.
//
// Copyright (C) 2000 Microsoft Corporation
/****************************************************************************/
import "basetsd.h";
import "oaidl.idl";
// Max number of disconnected sessions allowed from a disc session query.
#define TSSD_MaxDisconnectedSessions 10
/****************************************************************************/
// TSSD_CreateSessionInfo
//
// Data block passed to session directory that completely identifies a
// new TS session on the local machine. Combined with the local server address
// this information corresponds to a session record in the session directory.
/****************************************************************************/
typedef struct _TSSD_CreateSessionInfo
{
WCHAR UserName[256];
WCHAR Domain[128];
DWORD SessionID;
DWORD TSProtocol;
WCHAR ApplicationType[256];
DWORD ResolutionWidth;
DWORD ResolutionHeight;
DWORD ColorDepth;
FILETIME CreateTime;
} TSSD_CreateSessionInfo, *PTSSD_CreateSessionInfo;
/****************************************************************************/
// TSSD_DisconnectedSessionInfo
//
// Data block that contains required information about disconnected
// sessions.
/****************************************************************************/
typedef struct _TSSD_DisconnectedSessionInfo
{
WCHAR ServerAddress[128];
DWORD SessionID;
DWORD TSProtocol;
WCHAR ApplicationType[256];
DWORD ResolutionWidth;
DWORD ResolutionHeight;
DWORD ColorDepth;
FILETIME CreateTime;
FILETIME DisconnectionTime;
} TSSD_DisconnectedSessionInfo;
/****************************************************************************/
// TSSD_RepopulateSessionInfo
//
// Data block that contains required information about a session of any type.
/****************************************************************************/
typedef struct _TSSD_RepopulateSessionInfo
{
WCHAR *UserName;
WCHAR *Domain;
DWORD SessionID;
DWORD TSProtocol;
WCHAR *ApplicationType;
DWORD ResolutionWidth;
DWORD ResolutionHeight;
DWORD ColorDepth;
DWORD CreateTimeLow;
DWORD CreateTimeHigh;
DWORD DisconnectionTimeLow;
DWORD DisconnectionTimeHigh;
DWORD State;
} TSSD_RepopulateSessionInfo;
/****************************************************************************/
// TSSD_ReconnectSessionInfo
//
// Data block that contains information that changes on session reconnection,
// used to update the session directory record for that session.
/****************************************************************************/
typedef struct _TSSD_ReconnectSessionInfo
{
DWORD SessionID;
DWORD TSProtocol;
DWORD ResolutionWidth;
DWORD ResolutionHeight;
DWORD ColorDepth;
} TSSD_ReconnectSessionInfo;
/****************************************************************************/
// ITSSessionDirectoryEx
/****************************************************************************/
[
local,
object,
uuid(012b47b7-2f06-4154-ad0c-c64bcdf0d512),
helpstring("ITSSessionDirectoryEx"),
pointer_default(unique)
]
interface ITSSessionDirectoryEx : IUnknown
{
[ helpstring("Queries load balance info using server address.") ]
HRESULT GetLoadBalanceInfo(
[in, string] LPWSTR LocalServerAddress,
[out, retval] BSTR* pLBInfo);
};
/****************************************************************************/
// ITSSessionDirectory
/****************************************************************************/
[
local,
object,
uuid(0241e043-1cb6-4716-aa50-6a492049c3f3),
helpstring("ITSSessionDirectory"),
pointer_default(unique)
]
interface ITSSessionDirectory : IUnknown
{
[ helpstring("Initializes the object post-creation.") ]
HRESULT Initialize(
[in, string] LPWSTR LocalServerAddress,
[in, string] LPWSTR StoreServerName, // Max 64 chars incl. null.
[in, string] LPWSTR ClusterName, // Max 64 incl null
[in, string] LPWSTR OpaqueSettings, // Max 256 incl null
DWORD Flags,
DWORD (*repopfn)(), // pointer to repopulation function
DWORD (*updatesd)(DWORD) ); // pointer to updatesd function
[ helpstring("Updates the object with new configuration information.") ]
HRESULT Update(
[in, string] LPWSTR LocalServerAddress,
[in, string] LPWSTR StoreServerName, // Max 64 chars incl. null.
[in, string] LPWSTR ClusterName, // Max 64 incl null
[in, string] LPWSTR OpaqueSettings,
DWORD Flags, // Max 256 incl null
BOOL ForceRejoin);
[ helpstring("Queries disconnected sessions for a given user.") ]
HRESULT GetUserDisconnectedSessions(
[in, string] LPWSTR UserName,
[in, string] LPWSTR Domain,
[out] DWORD *pNumSessionsReturned,
[out, length_is(*pNumSessionsReturned)]
TSSD_DisconnectedSessionInfo SessionBuf[
TSSD_MaxDisconnectedSessions]);
[ helpstring("Called on a local-machine session creation.") ]
HRESULT NotifyCreateLocalSession(TSSD_CreateSessionInfo *pCreateInfo);
[ helpstring("Called on a local-machine session destruction.") ]
HRESULT NotifyDestroyLocalSession(DWORD SessionID);
[ helpstring("Called on a local-machine session disconnection.") ]
HRESULT NotifyDisconnectLocalSession(DWORD SessionID, FILETIME DiscTime);
[ helpstring("Called on a local-machine session reconnection.") ]
HRESULT NotifyReconnectLocalSession(TSSD_ReconnectSessionInfo *pReconnInfo);
[ helpstring("Called immediately after revectoring client.") ]
HRESULT NotifyReconnectPending(WCHAR *);
[ helpstring("Called when repopulating all sessions in the session directory.") ]
HRESULT Repopulate(DWORD WinStationCount, TSSD_RepopulateSessionInfo *rsi);
[ helpstring("Ping Session Directory server to see if it will accept RPC call or not") ]
HRESULT PingSD(WCHAR *pszServerName);
[ helpstring("Wait for repopulate to complete") ]
HRESULT WaitForRepopulate(DWORD dwTimeOut);
};