2020-09-30 16:53:55 +02:00

638 lines
14 KiB
C

/*++
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