windows-nt/Source/XPSP1/NT/termsrv/remdsk/server/ics/icshelper/icshelpapi.h
2020-09-26 16:20:57 +08:00

163 lines
4.9 KiB
C

/*****************************************************************************
******************************************************************************
**
**
** ICShelp.h
** Contains the useful public entry points to an ICS-assistance library
** created for the Salem/PCHealth Remote Assistance feature in Whistler
**
** Dates:
** 11-1-2000 created by TomFr
** 11-17-2000 re-written as a DLL, had been an object.
**
******************************************************************************
*****************************************************************************/
#ifndef __ICSHELP_HH__
#define __ICSHELP_HH__
#ifdef __cplusplus
extern "C" {
#endif
/****************************************************************************
**
** OpenPort(int port)
** if there is no ICS available, then we should just return...
**
** Of course, we save away the Port, as it goes back in the
** FetchAllAddresses call, asthe formatted "port" whenever a
** different one is not specified.
**
****************************************************************************/
DWORD APIENTRY OpenPort(int Port);
/****************************************************************************
**
** Called to close a port, whenever a ticket is expired or closed.
**
****************************************************************************/
DWORD APIENTRY ClosePort(DWORD dwHandle);
/****************************************************************************
**
** FetchAllAddresses
** Returns a string listing all the valid IP addresses for the machine,
** followed by the DNS name of the machine.
** Formatting details:
** 1. Each address is seperated with a ";" (semicolon)
** 2. Each address consists of the "1.2.3.4", and is followed by ":p"
** where the colon is followed by the port number
**
****************************************************************************/
DWORD APIENTRY FetchAllAddresses(WCHAR *lpszAddr, int iBufSize);
/****************************************************************************
**
**
**
**
**
**
****************************************************************************/
DWORD APIENTRY CloseAllOpenPorts(void);
/****************************************************************************
**
**
**
**
**
**
****************************************************************************/
DWORD APIENTRY StartICSLib(void);
/****************************************************************************
**
**
**
**
**
**
****************************************************************************/
DWORD APIENTRY StopICSLib(void);
/****************************************************************************
**
** SetAlertEvent
** Pass in an event handle. Then, whenever the ICS changes state, I
** will signal that event.
**
****************************************************************************/
DWORD APIENTRY SetAlertEvent(HANDLE hEvent);
/****************************************************************************
**
** ExpandAddress(char *szIp, char *szCompIp)
** Takes a compressed IP address and returns it to
** "normal"
**
****************************************************************************/
DWORD APIENTRY ExpandAddress(WCHAR *szIp, WCHAR *szCompIp);
/****************************************************************************
**
** SquishAddress(char *szIp, char *szCompIp)
** Takes one IP address and compresses it to minimum size
**
****************************************************************************/
DWORD APIENTRY SquishAddress(WCHAR *szIp, WCHAR *szCompIp);
/****************************************************************************
**
** FetchAllAddressesEx
**
****************************************************************************/
// these are the flag bits to use.
#define IPF_ADD_DNS 1
#define IPF_COMPRESS 2
#define IPF_NO_SORT 4
DWORD APIENTRY FetchAllAddressesEx(WCHAR *lpszAddr, int iBufSize, int IPflags);
/****************************************************************************
**
** GetIcsStatus(PICSSTAT pStat)
** Returns a structire detailing much of what is going on inside this
** library. The dwSize entry must be filled in before calling this
** function. Use "sizeof(ICSSTAT))" to populate this.
**
****************************************************************************/
typedef struct _ICSSTAT {
DWORD dwSize;
BOOL bIcsFound; // TRUE if we found an ICS wse can talk to
BOOL bIcsServer; // TRUE if this machine is the ICS server
BOOL bUsingDP; // TRUE if using the DPNATHLP.DLL support
BOOL bUsingUpnp; // TRUE for uPnP, FALSE for PAST
BOOL bModemPresent;
BOOL bVpnPresent;
WCHAR wszPubAddr[25]; // filled in with the public side addr of ICS
WCHAR wszLocAddr[25]; // IP of local NIC used for PAST bindings
WCHAR wszDllName[32]; // name of DLL used for ICS support
} ICSSTAT, *PICSSTAT;
DWORD APIENTRY GetIcsStatus(PICSSTAT pStat);
#ifdef __cplusplus
}
#endif
#endif // __ICSHELP_HH__