/*++ BUILD Version: 0001 // Increment this if a change has global effects Copyright 1990 - 1998 Microsoft Corporation Module Name: lmshare.h Abstract: This module defines the API function prototypes and data structures for the following groups of NT API functions: NetShare NetSession NetFile NetConnection Environment: User Mode - Win32 Notes: You must include and before this file. --*/ // // SHARE API // #ifndef _LMSHARE_ #define _LMSHARE_ #ifdef __cplusplus extern "C" { #endif // // Function Prototypes - Share // NET_API_STATUS NET_API_FUNCTION NetShareAdd ( IN LPTSTR servername, IN DWORD level, IN LPBYTE buf, OUT LPDWORD parm_err ); NET_API_STATUS NET_API_FUNCTION NetShareEnum ( IN LPTSTR servername, IN DWORD level, OUT LPBYTE *bufptr, IN DWORD prefmaxlen, OUT LPDWORD entriesread, OUT LPDWORD totalentries, IN OUT LPDWORD resume_handle ); NET_API_STATUS NET_API_FUNCTION NetShareEnumSticky ( IN LPTSTR servername, IN DWORD level, OUT LPBYTE *bufptr, IN DWORD prefmaxlen, OUT LPDWORD entriesread, OUT LPDWORD totalentries, IN OUT LPDWORD resume_handle ); NET_API_STATUS NET_API_FUNCTION NetShareGetInfo ( IN LPTSTR servername, IN LPTSTR netname, IN DWORD level, OUT LPBYTE *bufptr ); NET_API_STATUS NET_API_FUNCTION NetShareSetInfo ( IN LPTSTR servername, IN LPTSTR netname, IN DWORD level, IN LPBYTE buf, OUT LPDWORD parm_err ); NET_API_STATUS NET_API_FUNCTION NetShareDel ( IN LPTSTR servername, IN LPTSTR netname, IN DWORD reserved ); NET_API_STATUS NET_API_FUNCTION NetShareDelSticky ( IN LPTSTR servername, IN LPTSTR netname, IN DWORD reserved ); NET_API_STATUS NET_API_FUNCTION NetShareCheck ( IN LPTSTR servername, IN LPTSTR device, OUT LPDWORD type ); // // Data Structures - Share // typedef struct _SHARE_INFO_0 { LPTSTR shi0_netname; } SHARE_INFO_0, *PSHARE_INFO_0, *LPSHARE_INFO_0; typedef struct _SHARE_INFO_1 { LPTSTR shi1_netname; DWORD shi1_type; LPTSTR shi1_remark; } SHARE_INFO_1, *PSHARE_INFO_1, *LPSHARE_INFO_1; typedef struct _SHARE_INFO_2 { LPTSTR shi2_netname; DWORD shi2_type; LPTSTR shi2_remark; DWORD shi2_permissions; DWORD shi2_max_uses; DWORD shi2_current_uses; LPTSTR shi2_path; LPTSTR shi2_passwd; } SHARE_INFO_2, *PSHARE_INFO_2, *LPSHARE_INFO_2; typedef struct _SHARE_INFO_501 { LPTSTR shi501_netname; DWORD shi501_type; LPTSTR shi501_remark; DWORD shi501_flags; } SHARE_INFO_501, *PSHARE_INFO_501, *LPSHARE_INFO_501; typedef struct _SHARE_INFO_502 { LPTSTR shi502_netname; DWORD shi502_type; LPTSTR shi502_remark; DWORD shi502_permissions; DWORD shi502_max_uses; DWORD shi502_current_uses; LPTSTR shi502_path; LPTSTR shi502_passwd; DWORD shi502_reserved; PSECURITY_DESCRIPTOR shi502_security_descriptor; } SHARE_INFO_502, *PSHARE_INFO_502, *LPSHARE_INFO_502; typedef struct _SHARE_INFO_1004 { LPTSTR shi1004_remark; } SHARE_INFO_1004, *PSHARE_INFO_1004, *LPSHARE_INFO_1004; typedef struct _SHARE_INFO_1005 { DWORD shi1005_flags; } SHARE_INFO_1005, *PSHARE_INFO_1005, *LPSHARE_INFO_1005; typedef struct _SHARE_INFO_1006 { DWORD shi1006_max_uses; } SHARE_INFO_1006, *PSHARE_INFO_1006, *LPSHARE_INFO_1006; typedef struct _SHARE_INFO_1007 { DWORD shi1007_flags; LPTSTR shi1007_AlternateDirectoryName; } SHARE_INFO_1007, *PSHARE_INFO_1007, *LPSHARE_INFO_1007; typedef struct _SHARE_INFO_1501 { DWORD shi1501_reserved; PSECURITY_DESCRIPTOR shi1501_security_descriptor; } SHARE_INFO_1501, *PSHARE_INFO_1501, *LPSHARE_INFO_1501; // // Special Values and Constants - Share // // // Values for parm_err parameter. // #define SHARE_NETNAME_PARMNUM 1 #define SHARE_TYPE_PARMNUM 3 #define SHARE_REMARK_PARMNUM 4 #define SHARE_PERMISSIONS_PARMNUM 5 #define SHARE_MAX_USES_PARMNUM 6 #define SHARE_CURRENT_USES_PARMNUM 7 #define SHARE_PATH_PARMNUM 8 #define SHARE_PASSWD_PARMNUM 9 #define SHARE_FILE_SD_PARMNUM 501 // // Single-field infolevels for NetShareSetInfo. // #define SHARE_REMARK_INFOLEVEL \ (PARMNUM_BASE_INFOLEVEL + SHARE_REMARK_PARMNUM) #define SHARE_MAX_USES_INFOLEVEL \ (PARMNUM_BASE_INFOLEVEL + SHARE_MAX_USES_PARMNUM) #define SHARE_FILE_SD_INFOLEVEL \ (PARMNUM_BASE_INFOLEVEL + SHARE_FILE_SD_PARMNUM) #define SHI1_NUM_ELEMENTS 4 #define SHI2_NUM_ELEMENTS 10 // // Share types (shi1_type and shi2_type fields). // #define STYPE_DISKTREE 0 #define STYPE_PRINTQ 1 #define STYPE_DEVICE 2 #define STYPE_IPC 3 #define STYPE_SPECIAL 0x80000000 #define SHI_USES_UNLIMITED (DWORD)-1 // // Flags values for the 501, 1005, and 1007 infolevels // #define SHI1005_FLAGS_DFS 0x01 // Share is in the DFS #define SHI1005_FLAGS_DFS_ROOT 0x02 // Share is root of DFS #define COW_PERMACHINE 0x04 // Share data is per-machine data #define COW_PERUSER 0x08 // Share data is per-user data #define CSC_CACHEABLE 0x10 // Client can cache files for off-line access #define CSC_NOFLOWOPS 0x20 // Client need not flow operations to the server #define CSC_AUTO_INWARD 0x40 // Auto inward propagation (server->client) w/o UI #define CSC_AUTO_OUTWARD 0x80 // Auto outward propagation(client->server) w/o UI // // The subset of 1005 and 1007 infolevel flags that can be set via the API // #define SHI1005_VALID_FLAGS_SET ( CSC_CACHEABLE | \ CSC_NOFLOWOPS | \ CSC_AUTO_INWARD | \ CSC_AUTO_OUTWARD| \ COW_PERMACHINE | \ COW_PERUSER ) #define SHI1007_VALID_FLAGS_SET SHI1005_VALID_FLAGS_SET #endif // _LMSHARE_ // // SESSION API // #ifndef _LMSESSION_ #define _LMSESSION_ // // Function Prototypes Session // NET_API_STATUS NET_API_FUNCTION NetSessionEnum ( IN LPTSTR servername OPTIONAL, IN LPTSTR UncClientName OPTIONAL, IN LPTSTR username OPTIONAL, IN DWORD level, OUT LPBYTE *bufptr, IN DWORD prefmaxlen, OUT LPDWORD entriesread, OUT LPDWORD totalentries, IN OUT LPDWORD resume_handle OPTIONAL ); NET_API_STATUS NET_API_FUNCTION NetSessionDel ( IN LPTSTR servername OPTIONAL, IN LPTSTR UncClientName, IN LPTSTR username ); NET_API_STATUS NET_API_FUNCTION NetSessionGetInfo ( IN LPTSTR servername OPTIONAL, IN LPTSTR UncClientName, IN LPTSTR username, IN DWORD level, OUT LPBYTE *bufptr ); // // Data Structures - Session // typedef struct _SESSION_INFO_0 { LPTSTR sesi0_cname; // client name (no backslashes) } SESSION_INFO_0, *PSESSION_INFO_0, *LPSESSION_INFO_0; typedef struct _SESSION_INFO_1 { LPTSTR sesi1_cname; // client name (no backslashes) LPTSTR sesi1_username; DWORD sesi1_num_opens; DWORD sesi1_time; DWORD sesi1_idle_time; DWORD sesi1_user_flags; } SESSION_INFO_1, *PSESSION_INFO_1, *LPSESSION_INFO_1; typedef struct _SESSION_INFO_2 { LPTSTR sesi2_cname; // client name (no backslashes) LPTSTR sesi2_username; DWORD sesi2_num_opens; DWORD sesi2_time; DWORD sesi2_idle_time; DWORD sesi2_user_flags; LPTSTR sesi2_cltype_name; } SESSION_INFO_2, *PSESSION_INFO_2, *LPSESSION_INFO_2; typedef struct _SESSION_INFO_10 { LPTSTR sesi10_cname; // client name (no backslashes) LPTSTR sesi10_username; DWORD sesi10_time; DWORD sesi10_idle_time; } SESSION_INFO_10, *PSESSION_INFO_10, *LPSESSION_INFO_10; typedef struct _SESSION_INFO_502 { LPTSTR sesi502_cname; // client name (no backslashes) LPTSTR sesi502_username; DWORD sesi502_num_opens; DWORD sesi502_time; DWORD sesi502_idle_time; DWORD sesi502_user_flags; LPTSTR sesi502_cltype_name; LPTSTR sesi502_transport; } SESSION_INFO_502, *PSESSION_INFO_502, *LPSESSION_INFO_502; // // Special Values and Constants - Session // // // Bits defined in sesi1_user_flags. // #define SESS_GUEST 0x00000001 // session is logged on as a guest #define SESS_NOENCRYPTION 0x00000002 // session is not using encryption #define SESI1_NUM_ELEMENTS 8 #define SESI2_NUM_ELEMENTS 9 #endif // _LMSESSION_ // // CONNECTION API // #ifndef _LMCONNECTION_ #define _LMCONNECTION_ // // Function Prototypes - CONNECTION // NET_API_STATUS NET_API_FUNCTION NetConnectionEnum ( IN LPTSTR servername OPTIONAL, IN LPTSTR qualifier, IN DWORD level, OUT LPBYTE *bufptr, IN DWORD prefmaxlen, OUT LPDWORD entriesread, OUT LPDWORD totalentries, IN OUT LPDWORD resume_handle OPTIONAL ); // // Data Structures - CONNECTION // typedef struct _CONNECTION_INFO_0 { DWORD coni0_id; } CONNECTION_INFO_0, *PCONNECTION_INFO_0, *LPCONNECTION_INFO_0; typedef struct _CONNECTION_INFO_1 { DWORD coni1_id; DWORD coni1_type; DWORD coni1_num_opens; DWORD coni1_num_users; DWORD coni1_time; LPTSTR coni1_username; LPTSTR coni1_netname; } CONNECTION_INFO_1, *PCONNECTION_INFO_1, *LPCONNECTION_INFO_1; #endif // _LMCONNECTION_ // // FILE API // #ifndef _LMFILE_ #define _LMFILE_ // // Function Prototypes - FILE // NET_API_STATUS NET_API_FUNCTION NetFileClose ( IN LPTSTR servername OPTIONAL, IN DWORD fileid ); NET_API_STATUS NET_API_FUNCTION NetFileEnum ( IN LPTSTR servername OPTIONAL, IN LPTSTR basepath OPTIONAL, IN LPTSTR username OPTIONAL, IN DWORD level, OUT LPBYTE *bufptr, IN DWORD prefmaxlen, OUT LPDWORD entriesread, OUT LPDWORD totalentries, IN OUT LPDWORD resume_handle OPTIONAL ); NET_API_STATUS NET_API_FUNCTION NetFileGetInfo ( IN LPTSTR servername OPTIONAL, IN DWORD fileid, IN DWORD level, OUT LPBYTE *bufptr ); // // Data Structures - File // // File APIs are available at information levels 2 & 3 only. Levels 0 & // 1 are not supported. // typedef struct _FILE_INFO_2 { DWORD fi2_id; } FILE_INFO_2, *PFILE_INFO_2, *LPFILE_INFO_2; typedef struct _FILE_INFO_3 { DWORD fi3_id; DWORD fi3_permissions; DWORD fi3_num_locks; LPTSTR fi3_pathname; LPTSTR fi3_username; } FILE_INFO_3, *PFILE_INFO_3, *LPFILE_INFO_3; // // Special Values and Constants - File // // // bit values for permissions // #define PERM_FILE_READ 0x1 // user has read access #define PERM_FILE_WRITE 0x2 // user has write access #define PERM_FILE_CREATE 0x4 // user has create access #ifdef __cplusplus } #endif #endif // _LMFILE_