/*++ Copyright (c) 1994 Microsoft Corporation Module Name: inetinfo.h Abstract: This file contains the internet info server admin APIs. Author: Madan Appiah (madana) 10-Oct-1995 Revision History: Madana 10-Oct-1995 Made a new copy for product split from inetasrv.h MuraliK 12-Oct-1995 Fixes to support product split MuraliK 15-Nov-1995 Support Wide Char interface names --*/ #ifndef _INETINFO_H_ #define _INETINFO_H_ # include "inetcom.h" # include "iiscnfg.h" #ifdef __cplusplus extern "C" { #endif // _cplusplus /************************************************************ * Symbolic Constants ************************************************************/ // // The total number of instances of common services using the commong // service counters // #define MAX_PERF_CTR_SVCS 3 #define LAST_PERF_CTR_SVC INET_HTTP_SVC_ID #ifndef NO_AUX_PERF #ifndef MAX_AUX_PERF_COUNTERS #define MAX_AUX_PERF_COUNTERS (20) #endif // MAX_AUX_PERF_COUNTERS #endif // NO_AUX_PERF // // Service name. // #ifndef _EXEXPRESS #define INET_INFO_SERVICE_NAME TEXT("INETINFO") #define INET_INFO_SERVICE_NAME_A "INETINFO" #define INET_INFO_SERVICE_NAME_W L"INETINFO" #else #define INET_INFO_SERVICE_NAME TEXT("KNETINFO") #define INET_INFO_SERVICE_NAME_A "KNETINFO" #define INET_INFO_SERVICE_NAME_W L"KNETINFO" #define inetinfo_ServerIfHandle knetinfo_ServerIfHandle #endif // // IIS Version number // #define IIS_VERSION_MAJOR 5 #define IIS_VERSION_MINOR 1 #define IIS_SERVER_VERSION_MAJOR 6 #define IIS_SERVER_VERSION_MINOR 0 // // Configuration parameters registry key. // #define INET_INFO_KEY \ TEXT("System\\CurrentControlSet\\Services\\InetInfo") #define INET_INFO_PARAMETERS_KEY \ INET_INFO_KEY TEXT("\\Parameters") // // If this registry key exists under the W3Svc\Parameters key, // it is used to validate server access. Basically, all new users // must have sufficient privilege to open this key before they // may access the Server. // #define INET_INFO_ACCESS_KEY TEXT("AccessCheck") // // Special instances value // // // First instance of the service. // #define INET_INSTANCE_FIRST 0xf0000001 // // None is used to support users of the old APIs where there was // no concept of an instance. // #define INET_INSTANCE_DOWNLEVEL 0xf0000002 // // indicates the the request is for global data // #define INET_INSTANCE_GLOBAL 0xf0000003 // // root instance is a special instance which is not active // #define INET_INSTANCE_ROOT 0 #define INET_INSTANCE_ALL 0xffffffff #define INET_INSTANCE_MIN (1) #define INET_INSTANCE_MAX (0x7ffffffff) // // Authentication requirements values // #define INET_INFO_AUTH_ANONYMOUS MD_AUTH_ANONYMOUS #define INET_INFO_AUTH_CLEARTEXT MD_AUTH_BASIC #define INET_INFO_AUTH_NT_AUTH MD_AUTH_NT #define INET_INFO_AUTH_MD5_AUTH MD_AUTH_MD5 #define INET_INFO_AUTH_MAPBASIC MD_AUTH_MAPBASIC #define INET_INFO_AUTH_W95_MASK INET_INFO_AUTH_ANONYMOUS // // Name of the LSA Secret Object containing the password for // anonymous logon. // #define INET_INFO_ANONYMOUS_SECRET TEXT("INET_INFO_ANONYMOUS_DATA") #define INET_INFO_ANONYMOUS_SECRET_A "INET_INFO_ANONYMOUS_DATA" #define INET_INFO_ANONYMOUS_SECRET_W L"INET_INFO_ANONYMOUS_DATA" ///////////////////////////////////////////////////////////////////////// // // // Internet Server Common Definitions // // // ///////////////////////////////////////////////////////////////////////// // // Client Interface Name for RPC connections over named pipes // # define INET_INFO_INTERFACE_NAME INET_INFO_SERVICE_NAME # define INET_INFO_NAMED_PIPE TEXT("\\PIPE\\") ## INET_INFO_INTERFACE_NAME # define INET_INFO_NAMED_PIPE_W L"\\PIPE\\" ## INET_INFO_SERVICE_NAME_W // // Field control values for the INET_INFO_CONFIG_INFO structure // #define FC_INET_INFO_CONNECTION_TIMEOUT ((FIELD_CONTROL)BitFlag(0)) #define FC_INET_INFO_MAX_CONNECTIONS ((FIELD_CONTROL)BitFlag(1)) #define FC_INET_INFO_LOG_CONFIG ((FIELD_CONTROL)BitFlag(2)) #define FC_INET_INFO_ADMIN_NAME ((FIELD_CONTROL)BitFlag(3)) #define FC_INET_INFO_SERVER_COMMENT ((FIELD_CONTROL)BitFlag(4)) #define FC_INET_INFO_ADMIN_EMAIL ((FIELD_CONTROL)BitFlag(5)) #define FC_INET_INFO_HOST_NAME ((FIELD_CONTROL)BitFlag(6)) #define FC_INET_INFO_SERVER_SIZE ((FIELD_CONTROL)BitFlag(7)) #define FC_INET_INFO_DEF_LOGON_DOMAIN ((FIELD_CONTROL)BitFlag(15)) #define FC_INET_INFO_AUTHENTICATION ((FIELD_CONTROL)BitFlag(16)) #define FC_INET_INFO_ALLOW_ANONYMOUS ((FIELD_CONTROL)BitFlag(17)) #define FC_INET_INFO_LOG_ANONYMOUS ((FIELD_CONTROL)BitFlag(18)) #define FC_INET_INFO_LOG_NONANONYMOUS ((FIELD_CONTROL)BitFlag(19)) #define FC_INET_INFO_ANON_USER_NAME ((FIELD_CONTROL)BitFlag(20)) #define FC_INET_INFO_ANON_PASSWORD ((FIELD_CONTROL)BitFlag(21)) #define FC_INET_INFO_PORT_NUMBER ((FIELD_CONTROL)BitFlag(22)) #define FC_INET_INFO_SITE_SECURITY ((FIELD_CONTROL)BitFlag(23)) #define FC_INET_INFO_VIRTUAL_ROOTS ((FIELD_CONTROL)BitFlag(24)) #define FC_INET_INFO_SECURE_PORT_NUMBER ((FIELD_CONTROL)BitFlag(25)) #define FC_INET_INFO_SERVER_NAME ((FIELD_CONTROL)BitFlag(26)) #define FC_INET_INFO_AUTO_START ((FIELD_CONTROL)BitFlag(27)) #define FC_INET_INFO_ADDRESS_TYPE ((FIELD_CONTROL)BitFlag(28)) #define FC_INET_INFO_IP_ADDRESS ((FIELD_CONTROL)BitFlag(29)) // common parameters for publishing servers only # define FC_INET_INFO_ALL (FC_INET_INFO_CONNECTION_TIMEOUT |\ FC_INET_INFO_MAX_CONNECTIONS |\ FC_INET_INFO_LOG_CONFIG |\ FC_INET_INFO_ADMIN_NAME |\ FC_INET_INFO_SERVER_COMMENT |\ FC_INET_INFO_ADMIN_EMAIL |\ FC_INET_INFO_HOST_NAME |\ FC_INET_INFO_SERVER_SIZE |\ FC_INET_INFO_AUTHENTICATION |\ FC_INET_INFO_ALLOW_ANONYMOUS |\ FC_INET_INFO_LOG_ANONYMOUS |\ FC_INET_INFO_LOG_NONANONYMOUS |\ FC_INET_INFO_ANON_USER_NAME |\ FC_INET_INFO_ANON_PASSWORD |\ FC_INET_INFO_PORT_NUMBER |\ FC_INET_INFO_SITE_SECURITY |\ FC_INET_INFO_VIRTUAL_ROOTS |\ FC_INET_INFO_SECURE_PORT_NUMBER |\ FC_INET_INFO_SERVER_NAME |\ FC_INET_INFO_AUTO_START |\ FC_INET_INFO_ADDRESS_TYPE |\ FC_INET_INFO_IP_ADDRESS |\ FC_INET_INFO_DEF_LOGON_DOMAIN \ ) // // Virtual root access mask values // #define VROOT_MASK_READ MD_ACCESS_READ #define VROOT_MASK_WRITE MD_ACCESS_WRITE #define VROOT_MASK_EXECUTE MD_ACCESS_EXECUTE #define VROOT_MASK_READ_SOURCE MD_ACCESS_SOURCE #define VROOT_MASK_SSL MD_ACCESS_SSL #define VROOT_MASK_DONT_CACHE MD_ACCESS_DONT_CACHE #define VROOT_MASK_NEGO_CERT MD_ACCESS_NEGO_CERT #define VROOT_MASK_NEGO_MANDATORY MD_ACCESS_REQUIRE_CERT #define VROOT_MASK_MAP_CERT MD_ACCESS_MAP_CERT #define VROOT_MASK_SSL128 MD_ACCESS_SSL128 #define VROOT_MASK_SCRIPT MD_ACCESS_SCRIPT #define VROOT_MASK_NO_REMOTE_READ MD_ACCESS_NO_REMOTE_READ #define VROOT_MASK_NO_REMOTE_WRITE MD_ACCESS_NO_REMOTE_WRITE #define VROOT_MASK_NO_REMOTE_EXECUTE MD_ACCESS_NO_REMOTE_EXECUTE #define VROOT_MASK_NO_REMOTE_SCRIPT MD_ACCESS_NO_REMOTE_SCRIPT #define VROOT_MASK_NO_PHYSICAL_DIR MD_ACCESS_NO_PHYSICAL_DIR #define VROOT_MASK_MASK MD_ACCESS_MASK // // INet admin API structures // typedef struct _INET_INFO_IP_SEC_ENTRY { DWORD dwMask; // Mask and network number in DWORD dwNetwork; // network order } INET_INFO_IP_SEC_ENTRY, *LPINET_INFO_IP_SEC_ENTRY; #pragma warning( disable:4200 ) // nonstandard ext. - zero sized array // (MIDL requires zero entries) typedef struct _INET_INFO_IP_SEC_LIST { DWORD cEntries; #ifdef MIDL_PASS [size_is( cEntries)] #endif INET_INFO_IP_SEC_ENTRY aIPSecEntry[]; } INET_INFO_IP_SEC_LIST, *LPINET_INFO_IP_SEC_LIST; typedef struct _INET_INFO_SITE_ENTRY { LPWSTR pszComment; // Site Comment DWORD dwInstance; // Site Instance Number } INET_INFO_SITE_ENTRY, *LPINET_INFO_SITE_ENTRY; typedef struct _INET_INFO_SITE_LIST { DWORD cEntries; #ifdef MIDL_PASS [size_is( cEntries)] #endif INET_INFO_SITE_ENTRY aSiteEntry[]; } INET_INFO_SITE_LIST, *LPINET_INFO_SITE_LIST; typedef struct _INET_INFO_VIRTUAL_ROOT_ENTRY { LPWSTR pszRoot; // Virtual root name LPWSTR pszAddress; // Optional IP address LPWSTR pszDirectory; // Physical direcotry DWORD dwMask; // Mask for this virtual root LPWSTR pszAccountName; // Account to connect as WCHAR AccountPassword[PWLEN+1]; // Password for pszAccountName DWORD dwError; // Error code if entry wasn't added // only used for gets } INET_INFO_VIRTUAL_ROOT_ENTRY, *LPINET_INFO_VIRTUAL_ROOT_ENTRY; typedef struct _INET_INFO_VIRTUAL_ROOT_LIST { DWORD cEntries; #ifdef MIDL_PASS [size_is( cEntries)] #endif INET_INFO_VIRTUAL_ROOT_ENTRY aVirtRootEntry[]; } INET_INFO_VIRTUAL_ROOT_LIST, *LPINET_INFO_VIRTUAL_ROOT_LIST; // // Admin configuration information // typedef struct _INET_INFO_CONFIG_INFO { FIELD_CONTROL FieldControl; DWORD dwConnectionTimeout; // how long to hold connections DWORD dwMaxConnections; // max connections allowed LPWSTR lpszAdminName; LPWSTR lpszAdminEmail; LPWSTR lpszServerComment; LPINET_LOG_CONFIGURATION lpLogConfig; LANGID LangId; // These are read only LCID LocalId; BYTE ProductId[64]; BOOL fLogAnonymous; // Log Anonymous users? BOOL fLogNonAnonymous; // Log Non anonymous users? LPWSTR lpszAnonUserName; // Anonymous user name? WCHAR szAnonPassword[PWLEN+1]; // Password for the anonymous user DWORD dwAuthentication; // What authentication is enabled? short sPort; // Port Number for service LPINET_INFO_IP_SEC_LIST DenyIPList; // Site security deny list LPINET_INFO_IP_SEC_LIST GrantIPList; // Site security grant list LPINET_INFO_VIRTUAL_ROOT_LIST VirtualRoots; // Symlinks to other data dirs } INET_INFO_CONFIG_INFO, * LPINET_INFO_CONFIG_INFO; ///////////////////////////////////////////////////////////////////////// // // // Global Internet Server Definitions // // // ///////////////////////////////////////////////////////////////////////// #define FC_GINET_INFO_BANDWIDTH_LEVEL ((FIELD_CONTROL)BitFlag(0)) #define FC_GINET_INFO_MEMORY_CACHE_SIZE ((FIELD_CONTROL)BitFlag(1)) #define FC_GINET_INFO_ALL \ ( FC_GINET_INFO_BANDWIDTH_LEVEL | \ FC_GINET_INFO_MEMORY_CACHE_SIZE | \ 0 \ ) typedef struct _INET_INFO_GLOBAL_CONFIG_INFO { FIELD_CONTROL FieldControl; DWORD BandwidthLevel; // Bandwidth Level used. DWORD cbMemoryCacheSize; } INET_INFO_GLOBAL_CONFIG_INFO, * LPINET_INFO_GLOBAL_CONFIG_INFO; // // Global statistics // typedef struct _INET_INFO_STATISTICS_0 { INETA_CACHE_STATISTICS CacheCtrs; INETA_ATQ_STATISTICS AtqCtrs; # ifndef NO_AUX_PERF DWORD nAuxCounters; // number of active counters in rgCounters DWORD rgCounters[MAX_AUX_PERF_COUNTERS]; # endif // NO_AUX_PERF } INET_INFO_STATISTICS_0, * LPINET_INFO_STATISTICS_0; // // Capabilities Flags // typedef struct _INET_INFO_CAP_FLAGS { DWORD Flag; // Which capabilities are enabled DWORD Mask; // Which capabilities are supported } INET_INFO_CAP_FLAGS, * LPINET_INFO_CAP_FLAGS; // // Inet info server capabilities // typedef struct _INET_INFO_CAPABILITIES { DWORD CapVersion; // Version number of this structure DWORD ProductType; // Product type DWORD MajorVersion; // Major version number DWORD MinorVersion; // Minor Version number DWORD BuildNumber; // Build number DWORD NumCapFlags; // Number of capabilities structures LPINET_INFO_CAP_FLAGS CapFlags; } INET_INFO_CAPABILITIES, * LPINET_INFO_CAPABILITIES; // // Location of FrontPage web registry settings if installed // #define REG_FP_PATH "Software\\Microsoft\\FrontPage\\3.0" // // Product type // #define INET_INFO_PRODUCT_NTSERVER 0x00000001 #define INET_INFO_PRODUCT_NTWKSTA 0x00000002 #define INET_INFO_PRODUCT_WINDOWS95 0x00000003 #define INET_INFO_PRODUCT_UNKNOWN 0xffffffff // // Settable server capabilities // #define IIS_CAP1_ODBC_LOGGING 0x00000001 #define IIS_CAP1_FILE_LOGGING 0x00000002 #define IIS_CAP1_VIRTUAL_SERVER 0x00000004 #define IIS_CAP1_BW_THROTTLING 0x00000008 #define IIS_CAP1_IP_ACCESS_CHECK 0x00000010 #define IIS_CAP1_MAX_CONNECTIONS 0x00000020 #define IIS_CAP1_10_CONNECTION_LIMIT 0x00000040 #define IIS_CAP1_MULTIPLE_INSTANCE 0x00000080 #define IIS_CAP1_SSL_SUPPORT 0x00000100 #define IIS_CAP1_OPERATORS_LIST 0x00000200 #define IIS_CAP1_CPU_AUDITING 0x00000800 #define IIS_CAP1_SERVER_COMPRESSION 0x00001000 #define IIS_CAP1_DAV 0x00002000 #define IIS_CAP1_POOLED_OOP 0x00010000 // // Get or'd in at runtime after checking the network configuration // #define IIS_CAP1_DIGEST_SUPPORT 0x00004000 #define IIS_CAP1_NT_CERTMAP_SUPPORT 0x00008000 // // Gets 'or'ed in at runtime after checking the registry // #define IIS_CAP1_FP_INSTALLED 0x00000400 #define IIS_CAP1_ALL ( IIS_CAP1_ODBC_LOGGING | \ IIS_CAP1_FILE_LOGGING | \ IIS_CAP1_VIRTUAL_SERVER | \ IIS_CAP1_BW_THROTTLING | \ IIS_CAP1_IP_ACCESS_CHECK | \ IIS_CAP1_MAX_CONNECTIONS | \ IIS_CAP1_10_CONNECTION_LIMIT| \ IIS_CAP1_MULTIPLE_INSTANCE | \ IIS_CAP1_SSL_SUPPORT | \ IIS_CAP1_OPERATORS_LIST | \ IIS_CAP1_SERVER_COMPRESSION | \ IIS_CAP1_CPU_AUDITING | \ IIS_CAP1_DAV | \ IIS_CAP1_POOLED_OOP \ ) #define IIS_CAP1_NTS ( IIS_CAP1_ODBC_LOGGING | \ IIS_CAP1_FILE_LOGGING | \ IIS_CAP1_VIRTUAL_SERVER | \ IIS_CAP1_BW_THROTTLING | \ IIS_CAP1_IP_ACCESS_CHECK | \ IIS_CAP1_MAX_CONNECTIONS | \ IIS_CAP1_MULTIPLE_INSTANCE | \ IIS_CAP1_SSL_SUPPORT | \ IIS_CAP1_OPERATORS_LIST | \ IIS_CAP1_SERVER_COMPRESSION | \ IIS_CAP1_CPU_AUDITING | \ IIS_CAP1_DAV | \ IIS_CAP1_POOLED_OOP \ ) #define IIS_CAP1_NTW ( IIS_CAP1_FILE_LOGGING | \ IIS_CAP1_MAX_CONNECTIONS | \ IIS_CAP1_10_CONNECTION_LIMIT| \ IIS_CAP1_SSL_SUPPORT | \ IIS_CAP1_SERVER_COMPRESSION | \ IIS_CAP1_DAV | \ IIS_CAP1_POOLED_OOP \ ) #define IIS_CAP1_W95 ( IIS_CAP1_FILE_LOGGING | \ IIS_CAP1_MAX_CONNECTIONS | \ IIS_CAP1_10_CONNECTION_LIMIT \ ) // // INet admin API Prototypes // NET_API_STATUS NET_API_FUNCTION InetInfoGetVersion( IN LPWSTR pszServer OPTIONAL, IN DWORD dwReserved, OUT DWORD * pdwVersion ); NET_API_STATUS NET_API_FUNCTION InetInfoGetServerCapabilities( IN LPWSTR pszServer OPTIONAL, IN DWORD dwReserved, OUT LPINET_INFO_CAPABILITIES * ppCap ); NET_API_STATUS NET_API_FUNCTION InetInfoGetGlobalAdminInformation( IN LPWSTR pszServer OPTIONAL, IN DWORD dwReserved, OUT LPINET_INFO_GLOBAL_CONFIG_INFO * ppConfig ); NET_API_STATUS NET_API_FUNCTION InetInfoSetGlobalAdminInformation( IN LPWSTR pszServer OPTIONAL, IN DWORD dwReserved, IN INET_INFO_GLOBAL_CONFIG_INFO * pConfig ); NET_API_STATUS NET_API_FUNCTION InetInfoGetAdminInformation( IN LPWSTR pszServer OPTIONAL, IN DWORD dwServerMask, OUT LPINET_INFO_CONFIG_INFO * ppConfig ); NET_API_STATUS NET_API_FUNCTION InetInfoSetAdminInformation( IN LPWSTR pszServer OPTIONAL, IN DWORD dwServerMask, IN INET_INFO_CONFIG_INFO * pConfig ); NET_API_STATUS NET_API_FUNCTION InetInfoQueryStatistics( IN LPWSTR pszServer OPTIONAL, IN DWORD Level, IN DWORD dwServerMask, OUT LPBYTE * Buffer ); NET_API_STATUS NET_API_FUNCTION InetInfoClearStatistics( IN LPWSTR pszServer OPTIONAL, IN DWORD dwServerMask ); NET_API_STATUS NET_API_FUNCTION InetInfoFlushMemoryCache( IN LPWSTR pszServer OPTIONAL, IN DWORD dwServerMask ); NET_API_STATUS NET_API_FUNCTION InetInfoGetSites( IN LPWSTR pszServer OPTIONAL, IN DWORD dwServerMask, OUT LPINET_INFO_SITE_LIST * ppSites ); ///////////////////////////////////////////////////////////////////////// // // // HTTP (w3) specific items // // // ///////////////////////////////////////////////////////////////////////// // // Client Interface Name for RPC connections over named pipes // #define W3_SERVICE_NAME TEXT("W3SVC") #define W3_SERVICE_NAME_A "W3SVC" #define W3_SERVICE_NAME_W L"W3SVC" # define W3_INTERFACE_NAME W3_SERVICE_NAME # define W3_NAMED_PIPE TEXT("\\PIPE\\") ## W3_INTERFACE_NAME # define W3_NAMED_PIPE_W L"\\PIPE\\" ## W3_SERVICE_NAME_W // // Built-in application package ID's and class ID's // #define W3_INPROC_PACKAGE_ID L"{3D14228C-FBE1-11d0-995D-00C04FD919C1}" #define W3_OOP_POOL_PACKAGE_ID L"{3D14228D-FBE1-11d0-995D-00C04FD919C1}" #define W3_INPROC_WAM_CLSID L"{99169CB0-A707-11d0-989D-00C04FD919C1}" #define W3_OOP_POOL_WAM_CLSID L"{99169CB1-A707-11d0-989D-00C04FD919C1}" // // Constants for ISAPI token query functions // #define TOKEN_ANONYMOUS_TOKEN 1 #define TOKEN_VR_TOKEN 2 // // Manifests for APIs // #define FC_W3_DIR_BROWSE_CONTROL ((FIELD_CONTROL)BitFlag(0)) #define FC_W3_DEFAULT_LOAD_FILE ((FIELD_CONTROL)BitFlag(1)) #define FC_W3_CHECK_FOR_WAISDB ((FIELD_CONTROL)BitFlag(2)) #define FC_W3_DIRECTORY_IMAGE ((FIELD_CONTROL)BitFlag(3)) #define FC_W3_SERVER_AS_PROXY ((FIELD_CONTROL)BitFlag(4)) #define FC_W3_CATAPULT_USER_AND_PWD ((FIELD_CONTROL)BitFlag(5)) #define FC_W3_SSI_ENABLED ((FIELD_CONTROL)BitFlag(6)) #define FC_W3_SSI_EXTENSION ((FIELD_CONTROL)BitFlag(7)) #define FC_W3_GLOBAL_EXPIRE ((FIELD_CONTROL)BitFlag(8)) #define FC_W3_SCRIPT_MAPPING ((FIELD_CONTROL)BitFlag(9)) #define FC_W3_CGI_SCRIPT_TIMEOUT ((FIELD_CONTROL)BitFlag(10)) #define FC_W3_POOL_ODBC_CONN_TIME ((FIELD_CONTROL)BitFlag(11)) #define FC_W3_CACHE_ISAPI_APPS ((FIELD_CONTROL)BitFlag(12)) #define FC_W3_USE_KEEP_ALIVES ((FIELD_CONTROL)BitFlag(13)) #define FC_W3_ENABLE_HEADER_DOC ((FIELD_CONTROL)BitFlag(14)) #define FC_W3_HEADER_DOC_NAME ((FIELD_CONTROL)BitFlag(15)) #define FC_W3_ENABLE_FOOT_DOC ((FIELD_CONTROL)BitFlag(16)) #define FC_W3_FOOTER_DOC_NAME ((FIELD_CONTROL)BitFlag(17)) #define FC_W3_CUSTOMER_HEADERS ((FIELD_CONTROL)BitFlag(18)) #define FC_W3_ALL (FC_W3_DIR_BROWSE_CONTROL | \ FC_W3_DEFAULT_LOAD_FILE | \ FC_W3_CHECK_FOR_WAISDB | \ FC_W3_DIRECTORY_IMAGE | \ FC_W3_SERVER_AS_PROXY | \ FC_W3_CATAPULT_USER_AND_PWD |\ FC_W3_SSI_ENABLED | \ FC_W3_SSI_EXTENSION | \ FC_W3_GLOBAL_EXPIRE | \ FC_W3_SCRIPT_MAPPING | \ FC_W3_CGI_SCRIPT_TIMEOUT | \ FC_W3_POOL_ODBC_CONN_TIME| \ FC_W3_CACHE_ISAPI_APPS | \ FC_W3_USE_KEEP_ALIVES | \ FC_W3_ENABLE_HEADER_DOC | \ FC_W3_HEADER_DOC_NAME | \ FC_W3_ENABLE_FOOT_DOC | \ FC_W3_FOOTER_DOC_NAME | \ FC_W3_CUSTOMER_HEADERS \ ) // // HTTP Directory browsing flags // //#define DIRBROW_SHOW_ICON 0x00000001 #define DIRBROW_SHOW_DATE MD_DIRBROW_SHOW_DATE #define DIRBROW_SHOW_TIME MD_DIRBROW_SHOW_TIME #define DIRBROW_SHOW_SIZE MD_DIRBROW_SHOW_SIZE #define DIRBROW_SHOW_EXTENSION MD_DIRBROW_SHOW_EXTENSION #define DIRBROW_LONG_DATE MD_DIRBROW_LONG_DATE #define DIRBROW_ENABLED MD_DIRBROW_ENABLED #define DIRBROW_LOADDEFAULT MD_DIRBROW_LOADDEFAULT #define DIRBROW_MASK MD_DIRBROW_MASK // // Setting the csecGlobalExpire field to this value will prevent the server // from generating an "Expires:" header. // #define NO_GLOBAL_EXPIRE 0xffffffff // // Encryption Capabilities // #define ENC_CAPS_NOT_INSTALLED 0x80000000 // No keys installed #define ENC_CAPS_DISABLED 0x40000000 // Disabled due to locale #define ENC_CAPS_SSL 0x00000001 // SSL active #define ENC_CAPS_PCT 0x00000002 // PCT active // // Encryption type (SSL/PCT etc) portion of encryption flag dword // #define ENC_CAPS_TYPE_MASK (ENC_CAPS_SSL | \ ENC_CAPS_PCT) #define ENC_CAPS_DEFAULT ENC_CAPS_TYPE_MASK // // Structures for APIs // typedef struct _W3_USER_INFO { DWORD idUser; // User id LPWSTR pszUser; // User name BOOL fAnonymous; // TRUE if the user is logged on as // Anonymous, FALSE otherwise DWORD inetHost; // Host Address DWORD tConnect; // User Connection Time (elapsed seconds) } W3_USER_INFO, * LPW3_USER_INFO; typedef struct _W3_STATISTICS_0 { LARGE_INTEGER TotalBytesSent; LARGE_INTEGER TotalBytesReceived; DWORD TotalFilesSent; DWORD TotalFilesReceived; DWORD CurrentAnonymousUsers; DWORD CurrentNonAnonymousUsers; DWORD TotalAnonymousUsers; DWORD TotalNonAnonymousUsers; DWORD MaxAnonymousUsers; DWORD MaxNonAnonymousUsers; DWORD CurrentConnections; DWORD MaxConnections; DWORD ConnectionAttempts; DWORD LogonAttempts; DWORD TotalGets; DWORD TotalPosts; DWORD TotalHeads; DWORD TotalOthers; // Other HTTP verbs DWORD TotalCGIRequests; DWORD TotalBGIRequests; DWORD TotalNotFoundErrors; DWORD CurrentCGIRequests; DWORD CurrentBGIRequests; DWORD MaxCGIRequests; DWORD MaxBGIRequests; DWORD TimeOfLastClear; # ifndef NO_AUX_PERF DWORD nAuxCounters; // number of active counters in rgCounters DWORD rgCounters[MAX_AUX_PERF_COUNTERS]; # endif // NO_AUX_PERF } W3_STATISTICS_0, * LPW3_STATISTICS_0; typedef struct _W3_STATISTICS_1 { LARGE_INTEGER TotalBytesSent; LARGE_INTEGER TotalBytesReceived; DWORD TotalFilesSent; DWORD TotalFilesReceived; DWORD CurrentAnonymousUsers; DWORD CurrentNonAnonymousUsers; DWORD TotalAnonymousUsers; DWORD TotalNonAnonymousUsers; DWORD MaxAnonymousUsers; DWORD MaxNonAnonymousUsers; DWORD CurrentConnections; DWORD MaxConnections; DWORD ConnectionAttempts; DWORD LogonAttempts; DWORD TotalOptions; DWORD TotalGets; DWORD TotalPosts; DWORD TotalHeads; DWORD TotalPuts; DWORD TotalDeletes; DWORD TotalTraces; DWORD TotalMove; DWORD TotalCopy; DWORD TotalMkcol; DWORD TotalPropfind; DWORD TotalProppatch; DWORD TotalSearch; DWORD TotalLock; DWORD TotalUnlock; DWORD TotalOthers; // Other HTTP verbs DWORD TotalCGIRequests; DWORD TotalBGIRequests; DWORD TotalNotFoundErrors; DWORD TotalLockedErrors; DWORD CurrentCalAuth; DWORD MaxCalAuth; DWORD TotalFailedCalAuth; DWORD CurrentCalSsl; DWORD MaxCalSsl; DWORD TotalFailedCalSsl; DWORD CurrentCGIRequests; DWORD CurrentBGIRequests; DWORD MaxCGIRequests; DWORD MaxBGIRequests; // bandwidth throttling info DWORD CurrentBlockedRequests; DWORD TotalBlockedRequests; DWORD TotalAllowedRequests; DWORD TotalRejectedRequests; DWORD MeasuredBw; DWORD ServiceUptime; DWORD TimeOfLastClear; # ifndef NO_AUX_PERF DWORD nAuxCounters; // number of active counters in rgCounters DWORD rgCounters[MAX_AUX_PERF_COUNTERS]; # endif // NO_AUX_PERF } W3_STATISTICS_1, * LPW3_STATISTICS_1; typedef struct _W3_SCRIPT_MAP_ENTRY { LPWSTR lpszExtension; LPWSTR lpszImage; } W3_SCRIPT_MAP_ENTRY, *LPW3_SCRIPT_MAP_ENTRY; typedef struct _W3_SCRIPT_MAP_LIST { DWORD cEntries; #ifdef MIDL_PASS [size_is( cEntries)] #endif W3_SCRIPT_MAP_ENTRY aScriptMap[]; } W3_SCRIPT_MAP_LIST, *LPW3_SCRIPT_MAP_LIST; typedef struct _W3_CONFIG_INFO { FIELD_CONTROL FieldControl; DWORD dwDirBrowseControl; // Directory listing and def. load LPWSTR lpszDefaultLoadFile; // File to load if feature is on BOOL fCheckForWAISDB; // Call waislookup if .dct found? LPWSTR lpszDirectoryImage; // Image for directory in file list BOOL fServerAsProxy; // Run server as a proxy if TRUE LPWSTR lpszCatapultUser; // The user/password to impersonate WCHAR szCatapultUserPwd[PWLEN+1]; // if the proxy server is using // the catapult server BOOL fSSIEnabled; // Are server side includes enabled? LPWSTR lpszSSIExtension; // Extension for server side inc. DWORD csecGlobalExpire; // Value to set Expires: header to LPW3_SCRIPT_MAP_LIST ScriptMap; // List of extension mappings DWORD dwEncCaps; // Encryption capabilities } W3_CONFIG_INFO, *LPW3_CONFIG_INFO; // // API Prototypes // NET_API_STATUS NET_API_FUNCTION W3GetAdminInformation( IN LPWSTR pszServer OPTIONAL, OUT LPW3_CONFIG_INFO * ppConfig ); NET_API_STATUS NET_API_FUNCTION W3SetAdminInformation( IN LPWSTR pszServer OPTIONAL, IN LPW3_CONFIG_INFO pConfig ); NET_API_STATUS NET_API_FUNCTION W3EnumerateUsers( IN LPWSTR pszServer OPTIONAL, OUT LPDWORD lpdwEntriesRead, OUT LPW3_USER_INFO * Buffer ); NET_API_STATUS NET_API_FUNCTION W3DisconnectUser( IN LPWSTR pszServer OPTIONAL, IN DWORD idUser ); NET_API_STATUS NET_API_FUNCTION W3QueryStatistics( IN LPWSTR pszServer OPTIONAL, IN DWORD Level, OUT LPBYTE * Buffer ); NET_API_STATUS NET_API_FUNCTION W3ClearStatistics( IN LPWSTR pszServer OPTIONAL ); ///////////////////////////////////////////////////////////////////////// // // // FTP specific items // // // ///////////////////////////////////////////////////////////////////////// // // Service name. // #define FTPD_SERVICE_NAME TEXT("MSFTPSVC") #define FTPD_SERVICE_NAME_A "MSFTPSVC" #define FTPD_SERVICE_NAME_W L"MSFTPSVC" // // Client Interface Name for RPC connections over named pipes // # define FTP_INTERFACE_NAME FTPD_SERVICE_NAME # define FTP_NAMED_PIPE TEXT("\\PIPE\\") ## FTP_INTERFACE_NAME # define FTP_NAMED_PIPE_W L"\\PIPE\\" ## FTPD_SERVICE_NAME_W // // Manifests for APIs. // #define FC_FTP_ALLOW_ANONYMOUS ((FIELD_CONTROL)BitFlag( 0)) #define FC_FTP_ALLOW_GUEST_ACCESS ((FIELD_CONTROL)BitFlag( 1)) #define FC_FTP_ANNOTATE_DIRECTORIES ((FIELD_CONTROL)BitFlag( 2)) #define FC_FTP_ANONYMOUS_ONLY ((FIELD_CONTROL)BitFlag( 3)) #define FC_FTP_EXIT_MESSAGE ((FIELD_CONTROL)BitFlag( 4)) #define FC_FTP_GREETING_MESSAGE ((FIELD_CONTROL)BitFlag( 5)) #define FC_FTP_HOME_DIRECTORY ((FIELD_CONTROL)BitFlag( 6)) #define FC_FTP_LISTEN_BACKLOG ((FIELD_CONTROL)BitFlag( 7)) #define FC_FTP_LOWERCASE_FILES ((FIELD_CONTROL)BitFlag( 8)) #define FC_FTP_MAX_CLIENTS_MESSAGE ((FIELD_CONTROL)BitFlag( 9)) #define FC_FTP_MSDOS_DIR_OUTPUT ((FIELD_CONTROL)BitFlag(10)) #define FC_FTP_READ_ACCESS_MASK ((FIELD_CONTROL)BitFlag(11)) #define FC_FTP_WRITE_ACCESS_MASK ((FIELD_CONTROL)BitFlag(12)) #define FC_FTP_ALLOW_REPLACE_ON_RENAME ((FIELD_CONTROL)BitFlag(13)) #define FC_FTP_SHOW_4_DIGIT_YEAR ((FIELD_CONTROL)BitFlag(14)) #define FC_FTP_BANNER_MESSAGE ((FIELD_CONTROL)BitFlag(15)) #define FC_FTP_USER_ISOLATION ((FIELD_CONTROL)BitFlag(16)) #define FC_FTP_LOG_IN_UTF_8 ((FIELD_CONTROL)BitFlag(17)) #define FC_FTP_ALL ( \ FC_FTP_ALLOW_ANONYMOUS | \ FC_FTP_ALLOW_GUEST_ACCESS | \ FC_FTP_ANNOTATE_DIRECTORIES | \ FC_FTP_ANONYMOUS_ONLY | \ FC_FTP_EXIT_MESSAGE | \ FC_FTP_GREETING_MESSAGE | \ FC_FTP_HOME_DIRECTORY | \ FC_FTP_LISTEN_BACKLOG | \ FC_FTP_LOWERCASE_FILES | \ FC_FTP_MAX_CLIENTS_MESSAGE | \ FC_FTP_MSDOS_DIR_OUTPUT | \ FC_FTP_READ_ACCESS_MASK | \ FC_FTP_WRITE_ACCESS_MASK | \ FC_FTP_ALLOW_REPLACE_ON_RENAME | \ FC_FTP_SHOW_4_DIGIT_YEAR | \ FC_FTP_BANNER_MESSAGE | \ FC_FTP_USER_ISOLATION | \ FC_FTP_LOG_IN_UTF_8 | \ 0 ) // // Structures for APIs. // typedef struct _FTP_CONFIG_INFO { FIELD_CONTROL FieldControl; BOOL fAllowAnonymous; BOOL fAllowGuestAccess; BOOL fAnnotateDirectories; BOOL fAnonymousOnly; LPWSTR lpszExitMessage; LPWSTR lpszGreetingMessage; LPWSTR lpszHomeDirectory; DWORD dwListenBacklog; BOOL fLowercaseFiles; LPWSTR lpszMaxClientsMessage; BOOL fMsdosDirOutput; BOOL fFourDigitYear; LPWSTR lpszBannerMessage; DWORD dwUserIsolationMode; BOOL fLogInUtf8; } FTP_CONFIG_INFO, * LPFTP_CONFIG_INFO; // // API Prototypes. // NET_API_STATUS NET_API_FUNCTION FtpGetAdminInformation( IN LPWSTR pszServer OPTIONAL, OUT LPFTP_CONFIG_INFO * ppConfig ); NET_API_STATUS NET_API_FUNCTION FtpSetAdminInformation( IN LPWSTR pszServer OPTIONAL, IN LPFTP_CONFIG_INFO pConfig ); # include ///////////////////////////////////////////////////////////////////////// // // // Gopher specific items // // // ///////////////////////////////////////////////////////////////////////// // // Service name. // # define GOPHERD_SERVICE_NAME TEXT("GopherSvc") # define GOPHERD_SERVICE_NAME_A "GopherSvc" # define GOPHERD_SERVICE_NAME_W L"GopherSvc" // // Client Interface Name for RPC connections over named pipes // # define GOPHERD_INTERFACE_NAME GOPHERD_SERVICE_NAME # define GOPHERD_NAMED_PIPE TEXT("\\PIPE\\") ## GOPHERD_INTERFACE_NAME # define GOPHERD_NAMED_PIPE_W L"\\PIPE\\" ## GOPHERD_SERVICE_NAME_W // // Gopher port // #define IPPORT_GOPHER 0x46 /************************************************************ * Symbolic Constants * Prefix GDA_ stands for Gopher Daemon Admin ************************************************************/ # define GDA_SITE ((FIELD_CONTROL ) BitFlag( 1)) // SZ # define GDA_ORGANIZATION ((FIELD_CONTROL ) BitFlag( 2)) // SZ # define GDA_LOCATION ((FIELD_CONTROL ) BitFlag( 3)) // SZ # define GDA_GEOGRAPHY ((FIELD_CONTROL ) BitFlag( 4)) // SZ # define GDA_LANGUAGE ((FIELD_CONTROL ) BitFlag( 5)) // SZ # define GDA_CHECK_FOR_WAISDB ((FIELD_CONTROL ) BitFlag( 8)) // BOOL # define GDA_DEBUG_FLAGS ((FIELD_CONTROL ) BitFlag( 30)) // DWORD # define GDA_ALL_CONFIG_INFO ( GDA_SITE | \ GDA_ORGANIZATION | \ GDA_LOCATION | \ GDA_GEOGRAPHY | \ GDA_LANGUAGE | \ GDA_CHECK_FOR_WAISDB | \ GDA_DEBUG_FLAGS \ ) # define GOPHERD_ANONYMOUS_SECRET_W L"GOPHERD_ANONYMOUS_DATA" # define GOPHERD_ROOT_SECRET_W L"GOPHERD_ROOT_DATA" // // Configuration information is the config data that is communicated // b/w the server and admin UI // typedef struct _GOPHERD_CONFIG_INFO { FIELD_CONTROL FieldControl; // bit mask indicating fields set. LPWSTR lpszSite; // Name of Gopher site LPWSTR lpszOrganization; // Organization Name LPWSTR lpszLocation; // Location of server LPWSTR lpszGeography; // Geographical data LPWSTR lpszLanguage; // Language for server BOOL fCheckForWaisDb; // Check & allow Wais Db // Debugging data DWORD dwDebugFlags; // Bitmap of debugging data } GOPHERD_CONFIG_INFO, * LPGOPHERD_CONFIG_INFO; typedef struct _GOPHERD_STATISTICS_INFO { LARGE_INTEGER TotalBytesSent; LARGE_INTEGER TotalBytesRecvd; DWORD TotalFilesSent; DWORD TotalDirectoryListings; DWORD TotalSearches; DWORD CurrentAnonymousUsers; DWORD CurrentNonAnonymousUsers; DWORD MaxAnonymousUsers; DWORD MaxNonAnonymousUsers; DWORD TotalAnonymousUsers; DWORD TotalNonAnonymousUsers; DWORD TotalConnections; DWORD MaxConnections; DWORD CurrentConnections; DWORD ConnectionAttempts; // raw connections made DWORD LogonAttempts; // total logons attempted DWORD AbortedAttempts; // Aborted connections DWORD ErroredConnections; // # in Error when processed DWORD GopherPlusRequests; DWORD TimeOfLastClear; } GOPHERD_STATISTICS_INFO, * LPGOPHERD_STATISTICS_INFO; // // GOPHERD_USER_INFO contains details about connected users. // This structure may undergo modification. Currently UserInformation // is not supported. // typedef struct _GOPHERD_USER_INFO { DWORD dwIdUser; // Id for user LPWSTR lpszUserName; // User name BOOL fAnonymous; // TRUE if user logged on as anonymous // FALSE otherwise DWORD dwInetHost; // host address for client // // Other details if required // } GOPHERD_USER_INFO, * LPGOPHERD_USER_INFO; /************************************************************ * Gopher Server RPC APIs ************************************************************/ // // Server Administrative Information // DWORD NET_API_FUNCTION GdGetAdminInformation( IN LPWSTR pszServer OPTIONAL, OUT LPGOPHERD_CONFIG_INFO * ppConfigInfo ); DWORD NET_API_FUNCTION GdSetAdminInformation( IN LPWSTR pszServer OPTIONAL, IN LPGOPHERD_CONFIG_INFO pConfigInfo ); // // API for Users enumeration ( Not Yet Supported). // DWORD NET_API_FUNCTION GdEnumerateUsers( IN LPWSTR pszServer OPTIONAL, OUT LPDWORD lpnEntriesRead, OUT LPGOPHERD_USER_INFO * lpUserBuffer ); DWORD NET_API_FUNCTION GdDisconnectUser( IN LPWSTR pszServer OPTIONAL, IN DWORD dwIdUser ); // // Statistics API // DWORD NET_API_FUNCTION GdGetStatistics( IN LPWSTR pszServer OPTIONAL, OUT LPBYTE lpStatBuffer // pass LPGOPHERD_STATISTICS_INFO ); DWORD NET_API_FUNCTION GdClearStatistics( IN LPWSTR pszServer OPTIONAL ); ///////////////////////////////////////////////////////////////////////// // // // Catapult specific items // // // ///////////////////////////////////////////////////////////////////////// # define INET_GATEWAY_INTERFACE_NAME TEXT("gateway") // preserve back ward compatibility typedef INET_INFO_CONFIG_INFO INETA_CONFIG_INFO, * LPINETA_CONFIG_INFO; typedef INET_INFO_IP_SEC_ENTRY INETA_IP_SEC_ENTRY, * LPINETA_IP_SEC_ENTRY; typedef INET_INFO_IP_SEC_LIST INETA_IP_SEC_LIST, * LPINETA_IP_SEC_LIST; typedef INET_INFO_VIRTUAL_ROOT_ENTRY INETA_VIRTUAL_ROOT_ENTRY, * LPINETA_VIRTUAL_ROOT_ENTRY; typedef INET_INFO_VIRTUAL_ROOT_LIST INETA_VIRTUAL_ROOT_LIST, * LPINETA_VIRTUAL_ROOT_LIST; typedef INET_INFO_GLOBAL_CONFIG_INFO INETA_GLOBAL_CONFIG_INFO, * LPINETA_GLOBAL_CONFIG_INFO; typedef INET_INFO_STATISTICS_0 INETA_STATISTICS_0, * LPINETA_STATISTICS_0; #define INETA_PARAMETERS_KEY (INET_INFO_PARAMETERS_KEY) #ifdef __cplusplus } #endif // _cplusplus #endif // _INETINFO_H_