mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
637 lines
14 KiB
637 lines
14 KiB
/*++
|
|
|
|
Copyright (c) Microsoft Corporation. All rights reserved.
|
|
|
|
Module Name:
|
|
|
|
npapi.h
|
|
|
|
Abstract:
|
|
|
|
Network Provider API prototypes and manifests. A network provider
|
|
is a client of the Win32 Winnet driver. See the "NT/Win32 Network
|
|
Provider API Specification" document for further details.
|
|
|
|
Author:
|
|
|
|
John Ludeman (JohnL) 06-Dec-1991
|
|
|
|
Environment:
|
|
|
|
User Mode -Win32
|
|
|
|
Notes:
|
|
|
|
This file currently contains the function typedefs that will be needed
|
|
by the winnet driver to support multiple providers using LoadLibrary.
|
|
|
|
Revision History:
|
|
|
|
06-Dec-1991 Johnl
|
|
Created from Spec.
|
|
|
|
25-Aug-1992 Johnl
|
|
Changed all LPTSTR to LPWSTR since providers are Unicode only
|
|
|
|
23-Dec-1992 YiHsinS
|
|
Added NPFormatNetworkName
|
|
|
|
07-Jan-1993 Danl
|
|
Added Credential Management API functions.
|
|
|
|
23-Feb-1993 YiHsinS
|
|
Fix type LPNETRESOURCE->LPNETRESOURCEW, LPTSTR->LPWSTR
|
|
|
|
21-Aug-1998 jschwart
|
|
Declare NP function pointers as APIENTRY
|
|
|
|
--*/
|
|
|
|
#ifndef _NPAPI_INCLUDED
|
|
#define _NPAPI_INCLUDED
|
|
|
|
#if _MSC_VER > 1000
|
|
#pragma once
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
//
|
|
// CONNECTIONS
|
|
//
|
|
|
|
DWORD APIENTRY
|
|
NPAddConnection (
|
|
LPNETRESOURCEW lpNetResource,
|
|
LPWSTR lpPassword,
|
|
LPWSTR lpUserName
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPAddConnection) (
|
|
LPNETRESOURCEW lpNetResource,
|
|
LPWSTR lpPassword,
|
|
LPWSTR lpUserName
|
|
);
|
|
|
|
|
|
DWORD APIENTRY
|
|
NPAddConnection3 (
|
|
HWND hwndOwner,
|
|
LPNETRESOURCEW lpNetResource,
|
|
LPWSTR lpPassword,
|
|
LPWSTR lpUserName,
|
|
DWORD dwFlags
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPAddConnection3) (
|
|
HWND hwndOwner,
|
|
LPNETRESOURCEW lpNetResource,
|
|
LPWSTR lpPassword,
|
|
LPWSTR lpUserName,
|
|
DWORD dwFlags
|
|
);
|
|
|
|
|
|
DWORD APIENTRY
|
|
NPCancelConnection (
|
|
LPWSTR lpName,
|
|
BOOL fForce
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPCancelConnection) (
|
|
LPWSTR lpName,
|
|
BOOL fForce
|
|
);
|
|
|
|
|
|
DWORD APIENTRY
|
|
NPGetConnection (
|
|
LPWSTR lpLocalName,
|
|
LPWSTR lpRemoteName,
|
|
LPDWORD lpnBufferLen
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPGetConnection) (
|
|
LPWSTR lpLocalName,
|
|
LPWSTR lpRemoteName,
|
|
LPDWORD lpnBufferLen
|
|
);
|
|
|
|
|
|
#define WNGETCON_CONNECTED 0x00000000
|
|
#define WNGETCON_DISCONNECTED 0x00000001
|
|
|
|
DWORD APIENTRY
|
|
NPGetConnection3 (
|
|
LPCWSTR lpLocalName,
|
|
DWORD dwLevel,
|
|
LPVOID lpBuffer,
|
|
LPDWORD lpBufferSize
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPGetConnection3) (
|
|
LPCWSTR lpLocalName,
|
|
DWORD dwLevel,
|
|
LPVOID lpBuffer,
|
|
LPDWORD lpBufferSize
|
|
);
|
|
|
|
|
|
DWORD APIENTRY
|
|
NPGetUniversalName (
|
|
LPCWSTR lpLocalPath,
|
|
DWORD dwInfoLevel,
|
|
LPVOID lpBuffer,
|
|
LPDWORD lpBufferSize
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPGetUniversalName) (
|
|
LPCWSTR lpLocalPath,
|
|
DWORD dwInfoLevel,
|
|
LPVOID lpBuffer,
|
|
LPDWORD lpnBufferSize
|
|
);
|
|
|
|
DWORD APIENTRY
|
|
NPGetConnectionPerformance (
|
|
LPCWSTR lpRemoteName,
|
|
LPNETCONNECTINFOSTRUCT lpNetConnectInfo
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPGetConnectionPerformance) (
|
|
LPCWSTR lpRemoteName,
|
|
LPNETCONNECTINFOSTRUCT lpNetConnectInfo
|
|
);
|
|
|
|
|
|
DWORD APIENTRY
|
|
NPOpenEnum (
|
|
DWORD dwScope,
|
|
DWORD dwType,
|
|
DWORD dwUsage,
|
|
LPNETRESOURCEW lpNetResource,
|
|
LPHANDLE lphEnum
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPOpenEnum) (
|
|
DWORD dwScope,
|
|
DWORD dwType,
|
|
DWORD dwUsage,
|
|
LPNETRESOURCEW lpNetResource,
|
|
LPHANDLE lphEnum
|
|
);
|
|
|
|
DWORD APIENTRY
|
|
NPEnumResource (
|
|
HANDLE hEnum,
|
|
LPDWORD lpcCount,
|
|
LPVOID lpBuffer,
|
|
LPDWORD lpBufferSize
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPEnumResource) (
|
|
HANDLE hEnum,
|
|
LPDWORD lpcCount,
|
|
LPVOID lpBuffer,
|
|
LPDWORD lpBufferSize
|
|
);
|
|
|
|
DWORD APIENTRY
|
|
NPCloseEnum (
|
|
HANDLE hEnum
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPCloseEnum) (
|
|
HANDLE hEnum
|
|
);
|
|
|
|
|
|
//
|
|
// CAPABILITIES
|
|
//
|
|
|
|
#define WNNC_SPEC_VERSION 0x00000001
|
|
#define WNNC_SPEC_VERSION51 0x00050001
|
|
|
|
#define WNNC_NET_TYPE 0x00000002
|
|
#define WNNC_NET_NONE 0x00000000
|
|
|
|
#define WNNC_DRIVER_VERSION 0x00000003
|
|
|
|
#define WNNC_USER 0x00000004
|
|
#define WNNC_USR_GETUSER 0x00000001
|
|
|
|
#define WNNC_CONNECTION 0x00000006
|
|
#define WNNC_CON_ADDCONNECTION 0x00000001
|
|
#define WNNC_CON_CANCELCONNECTION 0x00000002
|
|
#define WNNC_CON_GETCONNECTIONS 0x00000004
|
|
#define WNNC_CON_ADDCONNECTION3 0x00000008
|
|
#define WNNC_CON_GETPERFORMANCE 0x00000040
|
|
#define WNNC_CON_DEFER 0x00000080
|
|
|
|
#define WNNC_DIALOG 0x00000008
|
|
#define WNNC_DLG_DEVICEMODE 0x00000001
|
|
#define WNNC_DLG_PROPERTYDIALOG 0x00000020
|
|
#define WNNC_DLG_SEARCHDIALOG 0x00000040
|
|
#define WNNC_DLG_FORMATNETWORKNAME 0x00000080
|
|
#define WNNC_DLG_PERMISSIONEDITOR 0x00000100
|
|
#define WNNC_DLG_GETRESOURCEPARENT 0x00000200
|
|
#define WNNC_DLG_GETRESOURCEINFORMATION 0x00000800
|
|
|
|
#define WNNC_ADMIN 0x00000009
|
|
#define WNNC_ADM_GETDIRECTORYTYPE 0x00000001
|
|
#define WNNC_ADM_DIRECTORYNOTIFY 0x00000002
|
|
|
|
#define WNNC_ENUMERATION 0x0000000B
|
|
#define WNNC_ENUM_GLOBAL 0x00000001
|
|
#define WNNC_ENUM_LOCAL 0x00000002
|
|
#define WNNC_ENUM_CONTEXT 0x00000004
|
|
#define WNNC_ENUM_SHAREABLE 0x00000008
|
|
|
|
#define WNNC_START 0x0000000C
|
|
#define WNNC_WAIT_FOR_START 0x00000001
|
|
|
|
#define WNNC_CONNECTION_FLAGS 0x0000000D
|
|
#define WNNC_CF_DEFAULT ( CONNECT_TEMPORARY | CONNECT_INTERACTIVE | CONNECT_PROMPT )
|
|
#define WNNC_CF_MAXIMUM (WNNC_CF_DEFAULT | CONNECT_DEFERRED | CONNECT_COMMANDLINE | CONNECT_CMD_SAVECRED)
|
|
|
|
|
|
|
|
DWORD APIENTRY
|
|
NPGetCaps (
|
|
DWORD ndex
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPGetCaps) (
|
|
DWORD ndex
|
|
);
|
|
|
|
//
|
|
// OTHER
|
|
//
|
|
|
|
DWORD APIENTRY
|
|
NPGetUser (
|
|
LPWSTR lpName,
|
|
LPWSTR lpUserName,
|
|
LPDWORD lpnBufferLen
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPGetUser) (
|
|
LPWSTR lpName,
|
|
LPWSTR lpUserName,
|
|
LPDWORD lpnBufferLen
|
|
);
|
|
|
|
#define WNTYPE_DRIVE 1
|
|
#define WNTYPE_FILE 2
|
|
#define WNTYPE_PRINTER 3
|
|
#define WNTYPE_COMM 4
|
|
|
|
#define WNPS_FILE 0
|
|
#define WNPS_DIR 1
|
|
#define WNPS_MULT 2
|
|
|
|
DWORD APIENTRY
|
|
NPDeviceMode(
|
|
HWND hParent
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPDeviceMode) (
|
|
HWND hParent
|
|
);
|
|
|
|
// flag for search dialog
|
|
#define WNSRCH_REFRESH_FIRST_LEVEL 0x00000001
|
|
|
|
DWORD APIENTRY
|
|
NPSearchDialog(
|
|
HWND hwndParent,
|
|
LPNETRESOURCEW lpNetResource,
|
|
LPVOID lpBuffer,
|
|
DWORD cbBuffer,
|
|
LPDWORD lpnFlags
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPSearchDialog) (
|
|
HWND hwndParent,
|
|
LPNETRESOURCEW lpNetResource,
|
|
LPVOID lpBuffer,
|
|
DWORD cbBuffer,
|
|
LPDWORD lpnFlags
|
|
);
|
|
|
|
DWORD APIENTRY
|
|
NPGetResourceParent(
|
|
LPNETRESOURCEW lpNetResource,
|
|
LPVOID lpBuffer,
|
|
LPDWORD lpBufferSize
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPGetResourceParent) (
|
|
LPNETRESOURCEW lpNetResource,
|
|
LPVOID lpBuffer,
|
|
LPDWORD lpBufferSize
|
|
);
|
|
|
|
DWORD APIENTRY NPGetResourceInformation(
|
|
LPNETRESOURCEW lpNetResource,
|
|
LPVOID lpBuffer,
|
|
LPDWORD lpBufferSize,
|
|
LPWSTR *lplpSystem
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPGetResourceInformation) (
|
|
LPNETRESOURCEW lpNetResource,
|
|
LPVOID lpBuffer,
|
|
LPDWORD lpBufferSize,
|
|
LPWSTR *lplpSystem
|
|
);
|
|
|
|
DWORD APIENTRY
|
|
NPFormatNetworkName(
|
|
LPWSTR lpRemoteName,
|
|
LPWSTR lpFormattedName,
|
|
LPDWORD lpnLength,
|
|
DWORD dwFlags,
|
|
DWORD dwAveCharPerLine
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPFormatNetworkName) (
|
|
LPWSTR lpRemoteName,
|
|
LPWSTR lpFormattedName,
|
|
LPDWORD lpnLength,
|
|
DWORD dwFlags,
|
|
DWORD dwAveCharPerLine
|
|
);
|
|
|
|
DWORD APIENTRY
|
|
NPGetPropertyText(
|
|
DWORD iButton,
|
|
DWORD nPropSel,
|
|
LPWSTR lpName,
|
|
LPWSTR lpButtonName,
|
|
DWORD nButtonNameLen,
|
|
DWORD nType
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPGetPropertyText) (
|
|
DWORD iButton,
|
|
DWORD nPropSel,
|
|
LPWSTR lpName,
|
|
LPWSTR lpButtonName,
|
|
DWORD nButtonNameLen,
|
|
DWORD nType
|
|
);
|
|
|
|
DWORD APIENTRY
|
|
NPPropertyDialog(
|
|
HWND hwndParent,
|
|
DWORD iButtonDlg,
|
|
DWORD nPropSel,
|
|
LPWSTR lpFileName,
|
|
DWORD nType
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPPropertyDialog) (
|
|
HWND hwndParent,
|
|
DWORD iButtonDlg,
|
|
DWORD nPropSel,
|
|
LPWSTR lpFileName,
|
|
DWORD nType
|
|
);
|
|
|
|
|
|
//
|
|
// ADMIN
|
|
//
|
|
|
|
#define WNDT_NORMAL 0
|
|
#define WNDT_NETWORK 1
|
|
|
|
#define WNDN_MKDIR 1
|
|
#define WNDN_RMDIR 2
|
|
#define WNDN_MVDIR 3
|
|
|
|
DWORD APIENTRY
|
|
NPGetDirectoryType (
|
|
LPWSTR lpName,
|
|
LPINT lpType,
|
|
BOOL bFlushCache
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPGetDirectoryType) (
|
|
LPWSTR lpName,
|
|
LPINT lpType,
|
|
BOOL bFlushCache
|
|
);
|
|
|
|
DWORD APIENTRY
|
|
NPDirectoryNotify (
|
|
HWND hwnd,
|
|
LPWSTR lpDir,
|
|
DWORD dwOper
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPDirectoryNotify) (
|
|
HWND hwnd,
|
|
LPWSTR lpDir,
|
|
DWORD dwOper
|
|
);
|
|
|
|
VOID
|
|
WNetSetLastErrorA(
|
|
DWORD err,
|
|
LPSTR lpError,
|
|
LPSTR lpProviders
|
|
);
|
|
|
|
VOID
|
|
WNetSetLastErrorW(
|
|
DWORD err,
|
|
LPWSTR lpError,
|
|
LPWSTR lpProviders
|
|
);
|
|
|
|
#ifdef UNICODE
|
|
#define WNetSetLastError WNetSetLastErrorW
|
|
#else
|
|
#define WNetSetLastError WNetSetLastErrorA
|
|
#endif // UNICODE
|
|
|
|
//
|
|
// CREDENTIAL MANAGEMENT and other classes of providers
|
|
//
|
|
|
|
|
|
// Define the Net/Authentication and othr Provider Classes
|
|
#define WN_NETWORK_CLASS 0x00000001
|
|
#define WN_CREDENTIAL_CLASS 0x00000002
|
|
#define WN_PRIMARY_AUTHENT_CLASS 0x00000004
|
|
#define WN_SERVICE_CLASS 0x00000008
|
|
|
|
#define WN_VALID_LOGON_ACCOUNT 0x00000001
|
|
#define WN_NT_PASSWORD_CHANGED 0x00000002
|
|
|
|
DWORD APIENTRY
|
|
NPLogonNotify (
|
|
PLUID lpLogonId,
|
|
LPCWSTR lpAuthentInfoType,
|
|
LPVOID lpAuthentInfo,
|
|
LPCWSTR lpPreviousAuthentInfoType,
|
|
LPVOID lpPreviousAuthentInfo,
|
|
LPWSTR lpStationName,
|
|
LPVOID StationHandle,
|
|
LPWSTR *lpLogonScript
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPLogonNotify) (
|
|
PLUID lpLogonId,
|
|
LPCWSTR lpAuthentInfoType,
|
|
LPVOID lpAuthentInfo,
|
|
LPCWSTR lpPreviousAuthentInfoType,
|
|
LPVOID lpPreviousAuthentInfo,
|
|
LPWSTR lpStationName,
|
|
LPVOID StationHandle,
|
|
LPWSTR *lpLogonScript
|
|
);
|
|
|
|
DWORD APIENTRY
|
|
NPPasswordChangeNotify (
|
|
LPCWSTR lpAuthentInfoType,
|
|
LPVOID lpAuthentInfo,
|
|
LPCWSTR lpPreviousAuthentInfoType,
|
|
LPVOID lpPreviousAuthentInfo,
|
|
LPWSTR lpStationName,
|
|
LPVOID StationHandle,
|
|
DWORD dwChangeInfo
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPPasswordChangeNotify) (
|
|
LPCWSTR lpAuthentInfoType,
|
|
LPVOID lpAuthentInfo,
|
|
LPCWSTR lpPreviousAuthentInfoType,
|
|
LPVOID lpPreviousAuthentInfo,
|
|
LPWSTR lpStationName,
|
|
LPVOID StationHandle,
|
|
DWORD dwChangeInfo
|
|
);
|
|
|
|
//
|
|
// CONNECTION NOTIFICATION
|
|
//
|
|
|
|
//
|
|
// NotifyStatus
|
|
//
|
|
#define NOTIFY_PRE 0x00000001
|
|
#define NOTIFY_POST 0x00000002
|
|
|
|
typedef struct _NOTIFYINFO {
|
|
DWORD dwNotifyStatus;
|
|
DWORD dwOperationStatus;
|
|
LPVOID lpContext;
|
|
} NOTIFYINFO, *LPNOTIFYINFO;
|
|
|
|
typedef struct _NOTIFYADD {
|
|
HWND hwndOwner;
|
|
NETRESOURCE NetResource;
|
|
DWORD dwAddFlags;
|
|
} NOTIFYADD, *LPNOTIFYADD;
|
|
|
|
typedef struct _NOTIFYCANCEL {
|
|
LPWSTR lpName;
|
|
LPWSTR lpProvider;
|
|
DWORD dwFlags;
|
|
BOOL fForce;
|
|
} NOTIFYCANCEL, *LPNOTIFYCANCEL;
|
|
|
|
|
|
DWORD APIENTRY
|
|
AddConnectNotify (
|
|
LPNOTIFYINFO lpNotifyInfo,
|
|
LPNOTIFYADD lpAddInfo
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_AddConnectNotify) (
|
|
LPNOTIFYINFO lpNotifyInfo,
|
|
LPNOTIFYADD lpAddInfo
|
|
);
|
|
|
|
DWORD APIENTRY
|
|
CancelConnectNotify (
|
|
LPNOTIFYINFO lpNotifyInfo,
|
|
LPNOTIFYCANCEL lpCancelInfo
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_CancelConnectNotify) (
|
|
LPNOTIFYINFO lpNotifyInfo,
|
|
LPNOTIFYCANCEL lpCancelInfo
|
|
);
|
|
|
|
//
|
|
// Permission editor dialogs
|
|
//
|
|
|
|
//
|
|
// Capabilities bits of permission editor dialogs
|
|
//
|
|
#define WNPERMC_PERM 0x00000001
|
|
#define WNPERMC_AUDIT 0x00000002
|
|
#define WNPERMC_OWNER 0x00000004
|
|
|
|
DWORD APIENTRY
|
|
NPFMXGetPermCaps (
|
|
LPWSTR lpDriveName
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPFMXGetPermCaps) (
|
|
LPWSTR lpDriveName
|
|
);
|
|
|
|
//
|
|
// Type of security dialog
|
|
//
|
|
#define WNPERM_DLG_PERM 0
|
|
#define WNPERM_DLG_AUDIT 1
|
|
#define WNPERM_DLG_OWNER 2
|
|
|
|
DWORD APIENTRY
|
|
NPFMXEditPerm (
|
|
LPWSTR lpDriveName,
|
|
HWND hwndFMX,
|
|
DWORD nDialogType
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPFMXEditPerm) (
|
|
LPWSTR lpDriveName,
|
|
HWND hwndFMX,
|
|
DWORD nDialogType
|
|
);
|
|
|
|
DWORD APIENTRY
|
|
NPFMXGetPermHelp (
|
|
LPWSTR lpDriveName,
|
|
DWORD nDialogType,
|
|
BOOL fDirectory,
|
|
LPVOID lpFileNameBuffer,
|
|
LPDWORD lpBufferSize,
|
|
LPDWORD lpnHelpContext
|
|
);
|
|
|
|
typedef DWORD (APIENTRY *PF_NPFMXGetPermHelp) (
|
|
LPWSTR lpDriveName,
|
|
DWORD nDialogType,
|
|
BOOL fDirectory,
|
|
LPVOID lpFileNameBuffer,
|
|
LPDWORD lpBufferSize,
|
|
LPDWORD lpnHelpContext
|
|
);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif // _NPAPI_INCLUDED
|