|
|
//+--------------------------------------------------------------------------- // // Microsoft Windows // Copyright (c) Microsoft Corporation. All rights reserved. // // File: R A S U I P . H // // Contents: Private RAS APIs used by the NT5 Connections UI. These // APIs are exported by rasdlg.dll. // // Notes: // // Author: shaunco 10 Nov 1997 // //----------------------------------------------------------------------------
#ifndef _RASUIP_ #define _RASUIP_
#if defined (_MSC_VER) #if ( _MSC_VER >= 1200 ) #pragma warning(push) #endif #if ( _MSC_VER >= 800 ) #pragma warning(disable:4001) #pragma warning(disable:4201) #pragma warning(disable:4214) #pragma warning(disable:4514) #endif #if (_MSC_VER >= 1020) #pragma once #endif #endif
#include <prsht.h> #include <ras.h> #include <hnetcfg.h>
#ifdef __cplusplus extern "C" { #endif
//+--------------------------------------------------------------------------- // RASENTRYDLG.reserved2 argument block valid when RASENTRYDLG.dwFlags // RASEDFLAG_ShellOwned is set. //
typedef struct _RASEDSHELLOWNEDR2 { // Add page routine to be called by RasEntryDlg before returning. // Callback returns context 'lparam'. // LPFNADDPROPSHEETPAGE pfnAddPage; LPARAM lparam;
// When RASEDFLAG_NewEntry and RASEDFLAG_ShellOwned are set, // pvWizardCtx is filled in by RasEntryDlg so that the shell has // context information with which to pass to the NccXXX APIs below. // LPVOID pvWizardCtx; } RASEDSHELLOWNEDR2;
//+--------------------------------------------------------------------------- // RAS Connection wizard APIs //
// Flags returned from RasWizCreateNewEntry // #define NCC_FLAG_ALL_USERS 0x1 // Create connection for all users #define NCC_FLAG_CREATE_INCOMING 0x2 // Create incoming connection instead #define NCC_FLAG_SHARED 0x4 #define NCC_FLAG_FIREWALL 0x8 // If turn on Firewall #define NCC_FLAG_GLOBALCREDS 0x10 // If the credentials is for all users #define NCC_FLAG_DEFAULT_INTERNET 0x20 // If this is a default internet connection
// Types of connections to be used in calls to RasWizXXX #define RASWIZ_TYPE_DIALUP 0x1 #define RASWIZ_TYPE_DIRECT 0x2 #define RASWIZ_TYPE_INCOMING 0x3 #define RASWIZ_TYPE_BROADBAND 0x4
DWORD APIENTRY RasWizCreateNewEntry( IN DWORD dwRasWizType, IN LPVOID pvData, OUT LPWSTR pszwPbkFile, OUT LPWSTR pszwEntryName, OUT DWORD* pdwFlags);
DWORD APIENTRY RasWizGetNCCFlags( IN DWORD dwRasWizType, IN LPVOID pvData, OUT DWORD * pdwFlags);
DWORD APIENTRY RasWizGetUserInputConnectionName ( IN LPVOID pvData, OUT LPWSTR pszwInputName);
DWORD APIENTRY RasWizGetSuggestedEntryName( IN DWORD dwRasWizType, IN LPVOID pvData, OUT LPWSTR pszwSuggestedName);
DWORD APIENTRY RasWizQueryMaxPageCount( IN DWORD dwRasWizType);
DWORD APIENTRY RasWizSetEntryName( IN DWORD dwRasWizType, IN LPVOID pvData, IN LPCWSTR pszwName);
DWORD APIENTRY RasWizIsEntryRenamable( IN DWORD dwRasWizType, IN LPVOID pvData, OUT BOOL* pfRenamable);
//+--------------------------------------------------------------------------- // Inbound connection APIs //
typedef HANDLE HRASSRVCONN;
#define RASSRV_MaxName 256
// Types of ras server connections (RASSRVCONN.dwType values) // #define RASSRVUI_MODEM 0 #define RASSRVUI_VPN 1 #define RASSRVUI_DCC 2
// Defines a structure that identifies a client connection // typedef struct _RASSRVCONN { DWORD dwSize; // Size of the structure (used for versioning) HRASSRVCONN hRasSrvConn; // Handle of the connection DWORD dwType; WCHAR szEntryName [RASSRV_MaxName + 1]; WCHAR szDeviceName [RASSRV_MaxName + 1]; GUID Guid; } RASSRVCONN, *LPRASSRVCONN;
// Starts the remote access service and marks it as autostart. // If the remoteaccess service is not installed, this function // returns an error. DWORD APIENTRY RasSrvInitializeService ( VOID);
// Stops the remote access service and marks it as disabled. DWORD APIENTRY RasSrvCleanupService ( VOID);
DWORD APIENTRY RasSrvIsServiceRunning ( OUT BOOL* pfIsRunning);
// // Returns whether is it ok to display the "Incoming Connections" // connection. // DWORD APIENTRY RasSrvAllowConnectionsConfig ( OUT BOOL* pfAllow);
DWORD APIENTRY RasSrvAddPropPages ( IN HRASSRVCONN hRasSrvConn, IN HWND hwndParent, IN LPFNADDPROPSHEETPAGE pfnAddPage, IN LPARAM lParam, IN OUT PVOID * ppvContext);
DWORD APIENTRY RasSrvAddWizPages ( IN LPFNADDPROPSHEETPAGE pfnAddPage, IN LPARAM lParam, IN OUT PVOID * ppvContext); // context should be passed in as pvData // subsequent calls to RasWizXXX
// Function behaves anagolously to the WIN32 function RasEnumConnections but // for client connections instead of dialout connections. DWORD APIENTRY RasSrvEnumConnections ( IN OUT LPRASSRVCONN pRasSrvConn, // Buffer of array of connections. IN LPDWORD pcb, // size in bytes of buffer OUT LPDWORD pcConnections); // number of connections written to buffer
// Gets the status of a Ras Server Connection DWORD APIENTRY RasSrvIsConnectionConnected ( IN HRASSRVCONN hRasSrvConn, // The connection in question OUT BOOL* pfConnected); // Buffer to hold the type
// Hang up the given connection DWORD APIENTRY RasSrvHangupConnection ( IN HRASSRVCONN hRasSrvConn); // The connection in question
// Has "show icons in taskbar" been checked? DWORD APIENTRY RasSrvQueryShowIcon ( OUT BOOL* pfShowIcon);
// Allows the editing of ras user preferences DWORD APIENTRY RasUserPrefsDlg ( HWND hwndParent);
// Enables or disables having the user manually dial // his/her remote access server. DWORD APIENTRY RasUserEnableManualDial ( IN HWND hwndParent, // parent for error dialogs IN BOOL bLogon, // whether a user is logged in IN BOOL bEnable ); // whether to enable or not
DWORD APIENTRY RasUserGetManualDial ( IN HWND hwndParent, // parent for error dialogs IN BOOL bLogon, // whether a user is logged in IN PBOOL pbEnabled ); // whether to enable or not
//+--------------------------------------------------------------------------- // Connection sharing API routines //
// Defines the structure used to store information about the shared connection. // This structure is stored as binary data in the registry, and any changes // to it must be made with this in mind. // #include <packon.h> typedef struct _RASSHARECONN { DWORD dwSize; BOOL fIsLanConnection; union { GUID guid; RASENTRYNAMEW name; }; } RASSHARECONN, *LPRASSHARECONN; #include <packoff.h>
// Flag set by 'RasQueryLanConnTable' for private LAN connections // #define NCCF_PRIVATE_LAN 0x1000
// Name of secure event object shared with rasauto service. // #define RAS_AUTO_DIAL_SHARED_CONNECTION_EVENT \ "RasAutoDialSharedConnectionEvent"
// VOID // RasEntryToSharedConnection( // IN LPCWSTR pszPhonebookPath, // IN LPCWSTR pszEntryName, // OUT LPRASSHARECONN pConn ); // // Macro for conversion of phonebook/entry to 'RASSHARECONN'. // #define RasEntryToSharedConnection( _pszPhonebookPath, _pszEntryName, _pConn ) \ ( \ ZeroMemory((_pConn), sizeof(RASSHARECONN)), \ (_pConn)->dwSize = sizeof(RASSHARECONN), \ (_pConn)->fIsLanConnection = FALSE, \ (_pConn)->name.dwSize = sizeof((_pConn)->name), \ (_pConn)->name.dwFlags = REN_AllUsers, \ lstrcpynW((_pConn)->name.szPhonebookPath, _pszPhonebookPath, MAX_PATH), \ lstrcpynW((_pConn)->name.szEntryName, _pszEntryName, RAS_MaxEntryName) \ )
// VOID // RasGuidToSharedConnection( // IN REFGUID guid, // OUT LPRASSHARECONN pConn ); // // Macro for conversion of LAN GUID to 'RASSHARECONN' // #define RasGuidToSharedConnection( _guid, _pConn ) \ ( \ ZeroMemory((_pConn), sizeof(RASSHARECONN)), \ (_pConn)->dwSize = sizeof(RASSHARECONN), \ (_pConn)->fIsLanConnection = TRUE, \ CopyMemory(&(_pConn)->guid, (_guid), sizeof(GUID)) \ )
// VOID // RasIsEqualSharedConnection( // IN LPRASSHARECONN pConn1, // IN LPRASSHARECONN pConn2 ); // // Macro for comparison of 'RASSHARECONN' values // #define RasIsEqualSharedConnection( _pConn1, _pConn2 ) \ ( \ ((_pConn1)->fIsLanConnection == (_pConn2)->fIsLanConnection) && \ ((_pConn1)->fIsLanConnection \ ? !memcmp(&(_pConn1)->guid, &(_pConn2)->guid, sizeof(GUID)) \ : (!lstrcmpiW( \ (_pConn1)->name.szPhonebookPath, \ (_pConn2)->name.szPhonebookPath) && \ !lstrcmpiW( \ (_pConn1)->name.szEntryName, \ (_pConn2)->name.szEntryName))) \ )
DWORD APIENTRY RasAutoDialSharedConnection( VOID );
DWORD APIENTRY RasIsSharedConnection( IN LPRASSHARECONN pConn, OUT PBOOL pfShared );
DWORD APIENTRY RasQuerySharedAutoDial( IN PBOOL pfEnabled );
DWORD APIENTRY RasQuerySharedConnection( OUT LPRASSHARECONN pConn );
DWORD APIENTRY RasSetSharedAutoDial( IN BOOL fEnable );
//+--------------------------------------------------------------------------- // Internal RAS APIs //
DWORD APIENTRY DwRasUninitialize();
#ifdef __cplusplus } // extern "C" #endif
#if defined (_MSC_VER) #if ( _MSC_VER >= 1200 ) #pragma warning(pop) #elif ( _MSC_VER >= 800 ) #pragma warning(default:4001) #pragma warning(default:4201) #pragma warning(default:4214) #pragma warning(default:4514) #endif #endif
#endif // _RASUIP_
|