/************************************************************************* * * wstmsg.h * * Session Manager Window Station API Messages * * copyright notice: Copyright 1998, Microsoft Corporation * * *************************************************************************/ #ifndef WINAPI #define WINAPI __stdcall #endif #define CITRIX_WINSTATIONAPI_VERSION 1 #define WINSTATIONAPI_PORT_MEMORY_SIZE 0x2000 // 8K will hold everything /* * Define WinStation control port name */ #define WINSTATION_CTRL_PORT_NAME L"\\WinStationCtrlPort" #define DR_RECONNECT_DEVICE_NAMEW L"\\Device\\Video0" #define DR_RECONNECT_DEVICE_NAMEA "\\Device\\Video0" // // This is the ConnectInfo structure passed at NtConnectPort() time // so that the server can verify our access rights. // typedef struct _WINSTATIONAPI_CONNECT_INFO { ULONG Version; ULONG RequestedAccess; NTSTATUS AcceptStatus; } WINSTATIONAPI_CONNECT_INFO, *PWINSTATIONAPI_CONNECT_INFO; /* * WinStation APIs * The following APIs are processed by ICASRV or WIN32 * depending on the API. If you make any changes to this * table, be sure to update the corresponding API dispatch table * in both ICASRV and in Win32. */ typedef enum _WINSTATION_APINUMBER { SMWinStationCreate, SMWinStationReset, SMWinStationDisconnect, SMWinStationWCharLog, SMWinStationGetSMCommand, SMWinStationBrokenConnection, SMWinStationIcaReplyMessage, SMWinStationIcaShadowHotkey, SMWinStationDoConnect, SMWinStationDoDisconnect, SMWinStationDoReconnect, SMWinStationExitWindows, SMWinStationTerminate, SMWinStationNtSecurity, SMWinStationDoMessage, SMWinStationDoBreakPoint, SMWinStationThinwireStats, SMWinStationShadowSetup, SMWinStationShadowStart, SMWinStationShadowStop, SMWinStationShadowCleanup, SMWinStationPassthruEnable, SMWinStationPassthruDisable, SMWinStationSetTimeZone, SMWinStationInitialProgram, SMWinStationNtsdDebug, SMWinStationBroadcastSystemMessage, // API for using Window's BroadcastSystemMessage() SMWinStationSendWindowMessage, // API for using WIndows's SendMessage() SMWinStationNotify, SMWinStationWindowInvalid, SMWinStationMaxApiNumber } WINSTATION_APINUMBER; /* * API function specific messages for WinStations */ typedef struct _WINSTATIONCREATEMSG { WINSTATIONNAME WinStationName; ULONG LogonId; } WINSTATIONCREATEMSG; typedef struct _WINSTATIONRESETMSG { ULONG LogonId; } WINSTATIONRESETMSG; typedef struct _WINSTATIONDISCONNECTMSG { ULONG LogonId; } WINSTATIONDISCONNECTMSG; typedef struct _WINSTATIONDODISCONNECTMSG { BOOLEAN ConsoleShadowFlag; ULONG NotUsed; } WINSTATIONDODISCONNECTMSG; typedef struct _WINSTATIONDOCONNECTMSG { BOOLEAN ConsoleShadowFlag; BOOLEAN fMouse; BOOLEAN fINetClient; BOOLEAN fInitialProgram; BOOLEAN fHideTitleBar; BOOLEAN fMaximize; HANDLE hIcaVideoChannel; HANDLE hIcaMouseChannel; HANDLE hIcaKeyboardChannel; HANDLE hIcaBeepChannel; HANDLE hIcaCommandChannel; HANDLE hIcaThinwireChannel; HANDLE hDisplayChangeEvent; WINSTATIONNAME WinStationName; WCHAR DisplayDriverName[9]; WCHAR ProtocolName[9]; WCHAR AudioDriverName[9]; USHORT HRes; // are for dynamically changing USHORT VRes; // display resolution at reconnection. USHORT ColorDepth; USHORT ProtocolType; // PROTOCOL_ICA or PROTOCOL_RDP BOOLEAN fClientDoubleClickSupport; BOOLEAN fEnableWindowsKey; ULONG KeyboardType; ULONG KeyboardSubType; ULONG KeyboardFunctionKey; } WINSTATIONDOCONNECTMSG; typedef struct _WINSTATIONDORECONNECTMSG { BOOLEAN fMouse; BOOLEAN fINetClient; BOOLEAN fClientDoubleClickSupport; BOOLEAN fEnableWindowsKey; BOOLEAN fDynamicReconnect; // Session can resize Display at reconnect WINSTATIONNAME WinStationName; WCHAR AudioDriverName[9]; WCHAR DisplayDriverName[9]; WCHAR ProtocolName[9]; USHORT HRes; // are for dynamically changing USHORT VRes; // display resolution at reconnection. USHORT ColorDepth; USHORT ProtocolType; // PROTOCOL_ICA or PROTOCOL_RDP ULONG KeyboardType; ULONG KeyboardSubType; ULONG KeyboardFunctionKey; } WINSTATIONDORECONNECTMSG; typedef enum _WINSTATIONNOTIFYEVENT { WinStation_Notify_Disconnect, WinStation_Notify_Reconnect, WinStation_Notify_PreReconnect, WinStation_Notify_SyncDisconnect, WinStation_Notify_DisableScrnSaver, WinStation_Notify_EnableScrnSaver, WinStation_Notify_PreReconnectDesktopSwitch, WinStation_Notify_HelpAssistantShadowStart, WinStation_Notify_HelpAssistantShadowFinish, WinStation_Notify_DisconnectPipe } WINSTATIONNOTIFYEVENT; typedef struct _WINSTATIONWINDOWINVALIDMSG { ULONG hWnd; ULONG SessionId; } WINSTATIONWINDOWINVALIDMSG; typedef struct _WINSTATIONDONOTIFYMSG { WINSTATIONNOTIFYEVENT NotifyEvent; } WINSTATIONDONOTIFYMSG; typedef struct _WINSTATIONTHINWIRESTATSMSG { CACHE_STATISTICS Stats; } WINSTATIONTHINWIRESTATSMSG; typedef struct _WINSTATIONEXITWINDOWSMSG { ULONG Flags; } WINSTATIONEXITWINDOWSMSG; typedef struct _WINSTATIONSENDMESSAGEMSG { LPWSTR pTitle; ULONG TitleLength; LPWSTR pMessage; ULONG MessageLength; ULONG Style; ULONG Timeout; ULONG Response; PULONG pResponse; BOOLEAN DoNotWait; HANDLE hEvent; } WINSTATIONSENDMESSAGEMSG; typedef struct _WINSTATIONREPLYMESSAGEMSG { ULONG Response; PULONG pResponse; HANDLE hEvent; } WINSTATIONREPLYMESSAGEMSG; typedef struct _WINSTATIONTERMINATEMSG { ULONG NotUsed; } WINSTATIONTERMINATEMSG; typedef struct _WINSTATIONNTSDDEBUGMSG { ULONG LogonId; LONG ProcessId; CLIENT_ID ClientId; PVOID AttachCompletionRoutine; } WINSTATIONNTSDDEBUGMSG, *PWINSTATIONNTSDDEBUGMSG; typedef struct _WINSTATIONBREAKPOINTMSG { BOOLEAN KernelFlag; } WINSTATIONBREAKPOINTMSG; typedef struct _WINSTATIONSHADOWSETUPMSG { ULONG NotUsed; } WINSTATIONSHADOWSETUPMSG; typedef struct _WINSTATIONSHADOWSTARTMSG { PVOID pThinwireData; ULONG ThinwireDataLength; } WINSTATIONSHADOWSTARTMSG; typedef struct _WINSTATIONSHADOWSTOPMSG { ULONG NotUsed; } WINSTATIONSHADOWSTOPMSG; typedef struct _WINSTATIONSHADOWCLEANUPMSG { PVOID pThinwireData; ULONG ThinwireDataLength; } WINSTATIONSHADOWCLEANUPMSG; typedef struct _WINSTATIONBROKENCONNECTIONMSG { ULONG Reason; // reason for broken connection (BROKENCLASS) ULONG Source; // source for broken connection (BROKENSOURCECLASS) } WINSTATIONBROKENCONNECTIONMSG; typedef struct _WINSTATIONWCHARLOG { WCHAR Buffer[100]; } WINSTATIONWCHARLOG; // This data structure included all params used by window's BroadcastSystemMessage // Use this APIto send a message to all windows of a winstation. typedef struct _WINSTATIONBROADCASTSYSTEMMSG { DWORD dwFlags; DWORD dwRecipients; UINT uiMessage; WPARAM wParam; LPARAM lParam; PVOID dataBuffer; ULONG bufferSize; HANDLE hEvent; ULONG Response; } WINSTATIONBROADCASTSYSTEMMSG; // This data structure has all the params used by window's standard SendMessage()API. // Use this API to send a message to a specific hwnd of a winstation ( you need to know that the appropriate hwnd was) typedef struct _WINSTATIONSENDWINDOWMSG { HWND hWnd; // handle of destination window UINT Msg; // message to send WPARAM wParam; // first message parameter LPARAM lParam; // second message parameter PCHAR dataBuffer; ULONG bufferSize; HANDLE hEvent; ULONG Response; } WINSTATIONSENDWINDOWMSG; typedef struct _WINSTATIONSETTIMEZONE { TS_TIME_ZONE_INFORMATION TimeZone; } WINSTATIONSETTIMEZONE; typedef struct _WINSTATION_APIMSG { PORT_MESSAGE h; ULONG MessageId; WINSTATION_APINUMBER ApiNumber; BOOLEAN WaitForReply; NTSTATUS ReturnedStatus; union { WINSTATIONCREATEMSG Create; WINSTATIONRESETMSG Reset; WINSTATIONDISCONNECTMSG Disconnect; WINSTATIONWCHARLOG WCharLog; WINSTATIONREPLYMESSAGEMSG ReplyMessage; WINSTATIONDODISCONNECTMSG DoDisconnect; WINSTATIONDOCONNECTMSG DoConnect; WINSTATIONEXITWINDOWSMSG ExitWindows; WINSTATIONTERMINATEMSG Terminate; WINSTATIONSENDMESSAGEMSG SendMessage; WINSTATIONBREAKPOINTMSG BreakPoint; WINSTATIONDORECONNECTMSG DoReconnect; WINSTATIONTHINWIRESTATSMSG ThinwireStats; WINSTATIONSHADOWSETUPMSG ShadowSetup; WINSTATIONSHADOWSTARTMSG ShadowStart; WINSTATIONSHADOWSTOPMSG ShadowStop; WINSTATIONSHADOWCLEANUPMSG ShadowCleanup; WINSTATIONBROKENCONNECTIONMSG Broken; WINSTATIONNTSDDEBUGMSG NtsdDebug; WINSTATIONBROADCASTSYSTEMMSG bMsg; // API for Window's BroadcastSystemMessage() WINSTATIONSENDWINDOWMSG sMsg; // API for WIndows's SendMessage() WINSTATIONSETTIMEZONE SetTimeZone; WINSTATIONDONOTIFYMSG DoNotify; WINSTATIONWINDOWINVALIDMSG WindowInvalid; } u; } WINSTATION_APIMSG, *PWINSTATION_APIMSG; /* * WinStation Kernel object interface routines. These provide a common * interface to the Nt* API's for the object that can be used by the * Session manager, the WinStation client DLL, and the CSRSS subsystem. */ /* * WinStation kernel object root directory name */ #define CITRIX_WINSTATION_OBJECT_DIRECTORY L"\\WinStations" /* * OpenWinStationObject * * Open the WinStation Kernel Object of the given Name. * * ENTRY: * Id * Id of the WinStation Kernel Object to open. It will be under the path * of "\WinStations\xxx" in the kernel object name space when * created. * * pHandle (output) * Pointer to variable to place the handle if the object was created. * * EXIT: * Returns the NTSTATUS code from the operation. */ NTSTATUS OpenWinStationObject( ULONG, PHANDLE, ULONG );