/** * This file has no copyright assigned and is placed in the Public Domain. * This file is part of the mingw-w64 runtime package. * No warranty is given; refer to the file DISCLAIMER.PD within this package. */ #ifndef SVRAPI_INCLUDED #define SVRAPI_INCLUDED #include <lmcons.h> #include <lmerr.h> #ifndef RC_INVOKED #pragma pack(1) #endif #ifdef __cplusplus extern "C" { #endif #ifndef _SVRAPI_ #define API_FUNCTION DECLSPEC_IMPORT API_RET_TYPE WINAPI #else #define API_FUNCTION API_RET_TYPE WINAPI #endif extern API_FUNCTION NetAccessAdd(const char *pszServer,short sLevel,char *pbBuffer,unsigned short cbBuffer); extern API_FUNCTION NetAccessCheck (char *pszReserved,char *pszUserName,char *pszResource,unsigned short usOperation,unsigned short *pusResult); extern API_FUNCTION NetAccessDel(const char *pszServer,char *pszResource); extern API_FUNCTION NetAccessEnum(const char *pszServer,char *pszBasePath,short fsRecursive,short sLevel,char *pbBuffer,unsigned short cbBuffer,unsigned short *pcEntriesRead,unsigned short *pcTotalAvail); extern API_FUNCTION NetAccessGetInfo(const char *pszServer,char *pszResource,short sLevel,char *pbBuffer,unsigned short cbBuffer,unsigned short *pcbTotalAvail); extern API_FUNCTION NetAccessSetInfo(const char *pszServer,char *pszResource,short sLevel,char *pbBuffer,unsigned short cbBuffer,short sParmNum); extern API_FUNCTION NetAccessGetUserPerms (char *pszServer,char *pszUgName,char *pszResource,unsigned short *pusPerms); struct access_list { char acl_ugname[LM20_UNLEN+1]; char acl_ugname_pad_1; short acl_access; }; struct access_list_2 { char *acl2_ugname; unsigned short acl2_access; }; struct access_list_12 { char *acl12_ugname; unsigned short acl12_access; }; struct access_info_0 { char *acc0_resource_name; }; struct access_info_1 { char *acc1_resource_name; short acc1_attr; short acc1_count; }; struct access_info_2 { char *acc2_resource_name; short acc2_attr; short acc2_count; }; struct access_info_10 { char *acc10_resource_name; }; struct access_info_12 { char *acc12_resource_name; short acc12_attr; short acc12_count; }; #define MAXPERMENTRIES 64 #define ACCESS_NONE 0 #define ACCESS_ALL (ACCESS_READ|ACCESS_WRITE|ACCESS_CREATE|ACCESS_EXEC|ACCESS_DELETE|ACCESS_ATRIB|ACCESS_PERM|ACCESS_FINDFIRST) #define ACCESS_READ 0x1 #define ACCESS_WRITE 0x2 #define ACCESS_CREATE 0x4 #define ACCESS_EXEC 0x8 #define ACCESS_DELETE 0x10 #define ACCESS_ATRIB 0x20 #define ACCESS_PERM 0x40 #define ACCESS_FINDFIRST 0x80 #define ACCESS_GROUP 0x8000 #define ACCESS_AUDIT 0x1 #define ACCESS_ATTR_PARMNUM 2 #define ACCESS_LETTERS "RWCXDAP " extern API_FUNCTION NetShareAdd(const char *pszServer,short sLevel,const char *pbBuffer,unsigned short cbBuffer); extern API_FUNCTION NetShareDel(const char *pszServer,const char *pszNetName,unsigned short usReserved); extern API_FUNCTION NetShareEnum(const char *pszServer,short sLevel,char *pbBuffer,unsigned short cbBuffer,unsigned short *pcEntriesRead,unsigned short *pcTotalAvail); extern API_FUNCTION NetShareGetInfo(const char *pszServer,const char *pszNetName,short sLevel,char *pbBuffer,unsigned short cbBuffer,unsigned short *pcbTotalAvail); extern API_FUNCTION NetShareSetInfo(const char *pszServer,const char *pszNetName,short sLevel,const char *pbBuffer,unsigned short cbBuffer,short sParmNum); struct share_info_0 { char shi0_netname[LM20_NNLEN+1]; }; struct share_info_1 { char shi1_netname[LM20_NNLEN+1]; char shi1_pad1; unsigned short shi1_type; char *shi1_remark; }; struct share_info_2 { char shi2_netname[LM20_NNLEN+1]; char shi2_pad1; unsigned short shi2_type; char *shi2_remark; unsigned short shi2_permissions; unsigned short shi2_max_uses; unsigned short shi2_current_uses; char *shi2_path; char shi2_passwd[SHPWLEN+1]; char shi2_pad2; }; struct share_info_50 { char shi50_netname[LM20_NNLEN+1]; unsigned char shi50_type; unsigned short shi50_flags; char *shi50_remark; char *shi50_path; char shi50_rw_password[SHPWLEN+1]; char shi50_ro_password[SHPWLEN+1]; }; #define SHI50F_RDONLY 0x0001 #define SHI50F_FULL 0x0002 #define SHI50F_DEPENDSON (SHI50F_RDONLY|SHI50F_FULL) #define SHI50F_ACCESSMASK (SHI50F_RDONLY|SHI50F_FULL) #define SHI50F_PERSIST 0x0100 #define SHI50F_SYSTEM 0x0200 #ifndef PARMNUM_ALL #define PARMNUM_ALL 0 #endif #define SHI_REMARK_PARMNUM 4 #define SHI_PERMISSIONS_PARMNUM 5 #define SHI_MAX_USES_PARMNUM 6 #define SHI_PASSWD_PARMNUM 9 #define SHI1_NUM_ELEMENTS 4 #define SHI2_NUM_ELEMENTS 10 #define STYPE_DISKTREE 0 #define STYPE_PRINTQ 1 #define STYPE_DEVICE 2 #define STYPE_IPC 3 #define SHI_USES_UNLIMITED -1 extern API_FUNCTION NetSessionDel(const char *pszServer,const char *pszClientName,short sReserved); extern API_FUNCTION NetSessionEnum(const char *pszServer,short sLevel,char *pbBuffer,unsigned short cbBuffer,unsigned short *pcEntriesRead,unsigned short *pcTotalAvail); extern API_FUNCTION NetSessionGetInfo(const char *pszServer,const char *pszClientName,short sLevel,char *pbBuffer,unsigned short cbBuffer,unsigned short *pcbTotalAvail); struct session_info_0 { char *sesi0_cname; }; struct session_info_1 { char *sesi1_cname; char *sesi1_username; unsigned short sesi1_num_conns; unsigned short sesi1_num_opens; unsigned short sesi1_num_users; unsigned __LONG32 sesi1_time; unsigned __LONG32 sesi1_idle_time; unsigned __LONG32 sesi1_user_flags; }; struct session_info_2 { char *sesi2_cname; char *sesi2_username; unsigned short sesi2_num_conns; unsigned short sesi2_num_opens; unsigned short sesi2_num_users; unsigned __LONG32 sesi2_time; unsigned __LONG32 sesi2_idle_time; unsigned __LONG32 sesi2_user_flags; char *sesi2_cltype_name; }; struct session_info_10 { char *sesi10_cname; char *sesi10_username; unsigned __LONG32 sesi10_time; unsigned __LONG32 sesi10_idle_time; }; struct session_info_50 { char *sesi50_cname; char *sesi50_username; unsigned __LONG32 sesi50_key; unsigned short sesi50_num_conns; unsigned short sesi50_num_opens; unsigned __LONG32 sesi50_time; unsigned __LONG32 sesi50_idle_time; unsigned char sesi50_protocol; unsigned char pad1; }; #define SESS_GUEST 1 #define SESS_NOENCRYPTION 2 #define SESI1_NUM_ELEMENTS 8 #define SESI2_NUM_ELEMENTS 9 extern API_FUNCTION NetConnectionEnum(const char *pszServer,const char *pszQualifier,short sLevel,char *pbBuffer,unsigned short cbBuffer,unsigned short *pcEntriesRead,unsigned short *pcTotalAvail); struct connection_info_0 { unsigned short coni0_id; }; struct connection_info_1 { unsigned short coni1_id; unsigned short coni1_type; unsigned short coni1_num_opens; unsigned short coni1_num_users; unsigned __LONG32 coni1_time; char *coni1_username; char *coni1_netname; }; struct connection_info_50 { unsigned short coni50_type; unsigned short coni50_num_opens; unsigned __LONG32 coni50_time; char *coni50_netname; char *coni50_username; }; extern API_FUNCTION NetFileClose2(const char *pszServer,unsigned __LONG32 ulFileId); extern API_FUNCTION NetFileEnum(const char *pszServer,const char *pszBasePath,short sLevel,char *pbBuffer,unsigned short cbBuffer,unsigned short *pcEntriesRead,unsigned short *pcTotalAvail); struct file_info_0 { unsigned short fi0_id; }; struct file_info_1 { unsigned short fi1_id; unsigned short fi1_permissions; unsigned short fi1_num_locks; char *fi1_pathname; char *fi1_username; }; struct file_info_2 { unsigned __LONG32 fi2_id; }; struct file_info_3 { unsigned __LONG32 fi3_id; unsigned short fi3_permissions; unsigned short fi3_num_locks; char *fi3_pathname; char *fi3_username; }; struct file_info_50 { unsigned __LONG32 fi50_id; unsigned short fi50_permissions; unsigned short fi50_num_locks; char *fi50_pathname; char *fi50_username; char *fi50_sharename; }; struct res_file_enum_2 { unsigned short res_pad; unsigned short res_fs; unsigned __LONG32 res_pro; }; #define PERM_FILE_READ 0x1 #define PERM_FILE_WRITE 0x2 #define PERM_FILE_CREATE 0x4 typedef struct res_file_enum_2 FRK; #define FRK_INIT(f) { (f).res_pad = 0; (f).res_fs = 0; (f).res_pro = 0; } extern API_FUNCTION NetServerGetInfo(const char *pszServer,short sLevel,char *pbBuffer,unsigned short cbBuffer,unsigned short *pcbTotalAvail); struct server_info_0 { char sv0_name[CNLEN + 1]; }; struct server_info_1 { char sv1_name[CNLEN + 1]; unsigned char sv1_version_major; unsigned char sv1_version_minor; unsigned __LONG32 sv1_type; char *sv1_comment; }; struct server_info_50 { char sv50_name[CNLEN + 1]; unsigned char sv50_version_major; unsigned char sv50_version_minor; unsigned __LONG32 sv50_type; char *sv50_comment; unsigned short sv50_security; unsigned short sv50_auditing; char *sv50_container; char *sv50_ab_server; char *sv50_ab_dll; }; struct server_info_2 { char sv2_name[CNLEN + 1]; unsigned char sv2_version_major; unsigned char sv2_version_minor; unsigned __LONG32 sv2_type; char *sv2_comment; unsigned __LONG32 sv2_ulist_mtime; unsigned __LONG32 sv2_glist_mtime; unsigned __LONG32 sv2_alist_mtime; unsigned short sv2_users; unsigned short sv2_disc; char *sv2_alerts; unsigned short sv2_security; unsigned short sv2_auditing; unsigned short sv2_numadmin; unsigned short sv2_lanmask; unsigned short sv2_hidden; unsigned short sv2_announce; unsigned short sv2_anndelta; char sv2_guestacct[LM20_UNLEN + 1]; unsigned char sv2_pad1; char *sv2_userpath; unsigned short sv2_chdevs; unsigned short sv2_chdevq; unsigned short sv2_chdevjobs; unsigned short sv2_connections; unsigned short sv2_shares; unsigned short sv2_openfiles; unsigned short sv2_sessopens; unsigned short sv2_sessvcs; unsigned short sv2_sessreqs; unsigned short sv2_opensearch; unsigned short sv2_activelocks; unsigned short sv2_numreqbuf; unsigned short sv2_sizreqbuf; unsigned short sv2_numbigbuf; unsigned short sv2_numfiletasks; unsigned short sv2_alertsched; unsigned short sv2_erroralert; unsigned short sv2_logonalert; unsigned short sv2_accessalert; unsigned short sv2_diskalert; unsigned short sv2_netioalert; unsigned short sv2_maxauditsz; char *sv2_srvheuristics; }; struct server_info_3 { char sv3_name[CNLEN + 1]; unsigned char sv3_version_major; unsigned char sv3_version_minor; unsigned __LONG32 sv3_type; char *sv3_comment; unsigned __LONG32 sv3_ulist_mtime; unsigned __LONG32 sv3_glist_mtime; unsigned __LONG32 sv3_alist_mtime; unsigned short sv3_users; unsigned short sv3_disc; char *sv3_alerts; unsigned short sv3_security; unsigned short sv3_auditing; unsigned short sv3_numadmin; unsigned short sv3_lanmask; unsigned short sv3_hidden; unsigned short sv3_announce; unsigned short sv3_anndelta; char sv3_guestacct[LM20_UNLEN + 1]; unsigned char sv3_pad1; char *sv3_userpath; unsigned short sv3_chdevs; unsigned short sv3_chdevq; unsigned short sv3_chdevjobs; unsigned short sv3_connections; unsigned short sv3_shares; unsigned short sv3_openfiles; unsigned short sv3_sessopens; unsigned short sv3_sessvcs; unsigned short sv3_sessreqs; unsigned short sv3_opensearch; unsigned short sv3_activelocks; unsigned short sv3_numreqbuf; unsigned short sv3_sizreqbuf; unsigned short sv3_numbigbuf; unsigned short sv3_numfiletasks; unsigned short sv3_alertsched; unsigned short sv3_erroralert; unsigned short sv3_logonalert; unsigned short sv3_accessalert; unsigned short sv3_diskalert; unsigned short sv3_netioalert; unsigned short sv3_maxauditsz; char *sv3_srvheuristics; unsigned __LONG32 sv3_auditedevents; unsigned short sv3_autoprofile; char *sv3_autopath; }; #define MAJOR_VERSION_MASK 0x0F #define SV_TYPE_WORKSTATION 0x00000001 #define SV_TYPE_SERVER 0x00000002 #define SV_TYPE_SQLSERVER 0x00000004 #define SV_TYPE_DOMAIN_CTRL 0x00000008 #define SV_TYPE_DOMAIN_BAKCTRL 0x00000010 #define SV_TYPE_TIME_SOURCE 0x00000020 #define SV_TYPE_AFP 0x00000040 #define SV_TYPE_NOVELL 0x00000080 #define SV_TYPE_DOMAIN_MEMBER 0x00000100 #define SV_TYPE_PRINTQ_SERVER 0x00000200 #define SV_TYPE_DIALIN_SERVER 0x00000400 #define SV_TYPE_ALL 0xFFFFFFFF #define SV_NODISC 0xFFFF #define SV_USERSECURITY 1 #define SV_SHARESECURITY 0 #define SV_SECURITY_SHARE 0 #define SV_SECURITY_WINNT 1 #define SV_SECURITY_WINNTAS 2 #define SV_SECURITY_NETWARE 3 #define SV_HIDDEN 1 #define SV_VISIBLE 0 #define SVI1_NUM_ELEMENTS 5 #define SVI2_NUM_ELEMENTS 44 #define SVI3_NUM_ELEMENTS 45 #define SW_AUTOPROF_LOAD_MASK 0x1 #define SW_AUTOPROF_SAVE_MASK 0x2 extern API_FUNCTION NetSecurityGetInfo(const char *pszServer,short sLevel,char *pbBuffer,unsigned short cbBuffer,unsigned short *pcbTotalAvail); struct security_info_1 { unsigned __LONG32 sec1_security; char *sec1_container; char *sec1_ab_server; char *sec1_ab_dll; }; #define SEC_SECURITY_SHARE SV_SECURITY_SHARE #define SEC_SECURITY_WINNT SV_SECURITY_WINNT #define SEC_SECURITY_WINNTAS SV_SECURITY_WINNTAS #define SEC_SECURITY_NETWARE SV_SECURITY_NETWARE #ifdef __cplusplus } #endif #ifndef RC_INVOKED #pragma pack() #endif #endif