Windows NT version 4.0 enables you to install a RAS administration DLL on a Windows NT RAS server. The DLL exports functions that the RAS server calls whenever a user tries to connect or disconnect. You can use the DLL to perform the following administrative functions:
The RasAdminAcceptNewConnection and RasAdminConnectionHangupNotification functions enable the DLL to audit user connections to the server. A Windows NT RAS server calls the DLL's RasAdminAcceptNewConnection function whenever a user tries to connect. The function can prevent the user from connecting. You can also use the function to generate an entry in a log for billing or auditing. When the user disconnects, the RAS server calls the DLL's RasAdminConnectionHangupNotification function, which can log the time at which the user disconnected.
After the RAS server has authenticated a caller, it calls the DLL's RasAdminGetIpAddressForUser function to get an IP address for the dialed-in remote client. The DLL can use this function to provide an alternate scheme for mapping an IP address to a dial-in user. By default, a RAS server connects a remote user to an IP address selected from a static pool of IP addresses, or one selected by a Dynamic Host Configuration Protocol (DHCP) server. The RasAdminGetIpAddressForUser function allows the DLL to override the default IP address and specify a particular IP address for each user. The RasAdminGetIpAddressForUser function can set a flag that causes RAS to call the DLL's RasAdminReleaseIPAddress function when the user disconnects. The DLL can use RasAdminReleaseIPAddress to update its user-to-IP-address map.
Note that RAS executes the functions for assigning IP addresses in one process, and executes the functions for connection and disconnection notifications in another process. Consequently, the DLL should not depend on shared data between the two sets of functions.
The RAS server logs an error in the system event log if an error occurs when it tries to load a RAS administration DLL or when it calls one of the DLL's functions. This can happen, for example, if the DLL specified the wrong name for an exported function, or if it did not include the function name in the .DEF file. The entry in the event log indicates the reason for the failure.