diff options
author | Adam <you@example.com> | 2020-05-17 05:51:50 +0200 |
---|---|---|
committer | Adam <you@example.com> | 2020-05-17 05:51:50 +0200 |
commit | e611b132f9b8abe35b362e5870b74bce94a1e58e (patch) | |
tree | a5781d2ec0e085eeca33cf350cf878f2efea6fe5 /public/sdk/inc/lmsvc.h | |
download | NT4.0-e611b132f9b8abe35b362e5870b74bce94a1e58e.tar NT4.0-e611b132f9b8abe35b362e5870b74bce94a1e58e.tar.gz NT4.0-e611b132f9b8abe35b362e5870b74bce94a1e58e.tar.bz2 NT4.0-e611b132f9b8abe35b362e5870b74bce94a1e58e.tar.lz NT4.0-e611b132f9b8abe35b362e5870b74bce94a1e58e.tar.xz NT4.0-e611b132f9b8abe35b362e5870b74bce94a1e58e.tar.zst NT4.0-e611b132f9b8abe35b362e5870b74bce94a1e58e.zip |
Diffstat (limited to '')
-rw-r--r-- | public/sdk/inc/lmsvc.h | 532 |
1 files changed, 532 insertions, 0 deletions
diff --git a/public/sdk/inc/lmsvc.h b/public/sdk/inc/lmsvc.h new file mode 100644 index 000000000..a319f1e05 --- /dev/null +++ b/public/sdk/inc/lmsvc.h @@ -0,0 +1,532 @@ +/*++ BUILD Version: 0002 // Increment this if a change has global effects + +Copyright (c) 1991-1996 Microsoft Corporation + +Module Name: + + lmsvc.h + +Abstract: + + This file contains structures, function prototypes, and definitions + for the NetService API. + +[Environment:] + + User Mode -Win32 + +[Notes:] + + You must include NETCONS.H before this file, since this file depends + on values defined in NETCONS.H. + +--*/ + +#ifndef _LMSVC_ +#define _LMSVC_ + +#ifdef __cplusplus +extern "C" { +#endif + +// +// Include the file which contains all the service name strings. +// +#include <lmsname.h> + +// +// Data Structures +// + +typedef struct _SERVICE_INFO_0 { + LPWSTR svci0_name; +} SERVICE_INFO_0, *PSERVICE_INFO_0, * LPSERVICE_INFO_0; + +typedef struct _SERVICE_INFO_1 { + LPWSTR svci1_name; + DWORD svci1_status; + DWORD svci1_code; + DWORD svci1_pid; +} SERVICE_INFO_1, *PSERVICE_INFO_1, * LPSERVICE_INFO_1; + +typedef struct _SERVICE_INFO_2 { + LPWSTR svci2_name; + DWORD svci2_status; + DWORD svci2_code; + DWORD svci2_pid; + LPWSTR svci2_text; + DWORD svci2_specific_error; + LPWSTR svci2_display_name; +} SERVICE_INFO_2, *PSERVICE_INFO_2, * LPSERVICE_INFO_2; + +// +// Function Prototypes +// + +NET_API_STATUS NET_API_FUNCTION +NetServiceControl ( + IN LPCWSTR servername OPTIONAL, + IN LPCWSTR service, + IN DWORD opcode, + IN DWORD arg, + OUT LPBYTE *bufptr + ); + +NET_API_STATUS NET_API_FUNCTION +NetServiceEnum ( + IN LPCWSTR servername 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 +NetServiceGetInfo ( + IN LPCWSTR servername OPTIONAL, + IN LPCWSTR service, + IN DWORD level, + OUT LPBYTE *bufptr + ); + +NET_API_STATUS NET_API_FUNCTION +NetServiceInstall ( + IN LPCWSTR servername OPTIONAL, + IN LPCWSTR service, + IN DWORD argc, + IN LPCWSTR argv[], + OUT LPBYTE *bufptr + ); + +// +// Special Values and Constants +// + +// +// Bitmask and bit values for svci1_status, and svci2_status +// fields. For each "subfield", there is a mask defined, +// and a number of constants representing the value +// obtained by doing (status & mask). +// + +// Bits 0,1 -- general status + +#define SERVICE_INSTALL_STATE 0x03 +#define SERVICE_UNINSTALLED 0x00 +#define SERVICE_INSTALL_PENDING 0x01 +#define SERVICE_UNINSTALL_PENDING 0x02 +#define SERVICE_INSTALLED 0x03 + +// Bits 2,3 -- paused/active status + +#define SERVICE_PAUSE_STATE 0x0C +#define LM20_SERVICE_ACTIVE 0x00 +#define LM20_SERVICE_CONTINUE_PENDING 0x04 +#define LM20_SERVICE_PAUSE_PENDING 0x08 +#define LM20_SERVICE_PAUSED 0x0C + +// Bit 4 -- uninstallable indication + +#define SERVICE_NOT_UNINSTALLABLE 0x00 +#define SERVICE_UNINSTALLABLE 0x10 + +// Bit 5 -- pausable indication + +#define SERVICE_NOT_PAUSABLE 0x00 +#define SERVICE_PAUSABLE 0x20 + +// Workstation service only: +// Bits 8,9,10 -- redirection paused/active + +#define SERVICE_REDIR_PAUSED 0x700 +#define SERVICE_REDIR_DISK_PAUSED 0x100 +#define SERVICE_REDIR_PRINT_PAUSED 0x200 +#define SERVICE_REDIR_COMM_PAUSED 0x400 + +// +// Additional standard LAN Manager for MS-DOS services +// + +#define SERVICE_DOS_ENCRYPTION L"ENCRYPT" + +// +// NetServiceControl opcodes. +// + +#define SERVICE_CTRL_INTERROGATE 0 +#define SERVICE_CTRL_PAUSE 1 +#define SERVICE_CTRL_CONTINUE 2 +#define SERVICE_CTRL_UNINSTALL 3 + +// +// Workstation service only: Bits used in the "arg" parameter +// to NetServiceControl in conjunction with the opcode +// SERVICE_CTRL_PAUSE or SERVICE_CTRL_CONTINUE, to pause or +// continue redirection. +// + +#define SERVICE_CTRL_REDIR_DISK 0x1 +#define SERVICE_CTRL_REDIR_PRINT 0x2 +#define SERVICE_CTRL_REDIR_COMM 0x4 + +// +// Values for svci1_code, and svci2_code when status +// of the service is SERVICE_INSTALL_PENDING or +// SERVICE_UNINSTALL_PENDING. +// A service can optionally provide a hint to the installer +// that the install is proceeding and how long to wait +// (in 0.1 second increments) before querying status again. +// + +#define SERVICE_IP_NO_HINT 0x0 +#define SERVICE_CCP_NO_HINT 0x0 + +#define SERVICE_IP_QUERY_HINT 0x10000 +#define SERVICE_CCP_QUERY_HINT 0x10000 + +// +// Mask for install proceeding checkpoint number +// + +#define SERVICE_IP_CHKPT_NUM 0x0FF +#define SERVICE_CCP_CHKPT_NUM 0x0FF + +// +// Mask for wait time hint before querying again +// + +#define SERVICE_IP_WAIT_TIME 0x0FF00 +#define SERVICE_CCP_WAIT_TIME 0x0FF00 + +// +// Shift count for building wait time _code values +// + +#define SERVICE_IP_WAITTIME_SHIFT 8 +#define SERVICE_NTIP_WAITTIME_SHIFT 12 + +// +// Mask used for upper and lower portions of wait hint time. +// +#define UPPER_HINT_MASK 0x0000FF00 +#define LOWER_HINT_MASK 0x000000FF +#define UPPER_GET_HINT_MASK 0x0FF00000 +#define LOWER_GET_HINT_MASK 0x0000FF00 +#define SERVICE_NT_MAXTIME 0x0000FFFF +#define SERVICE_RESRV_MASK 0x0001FFFF +#define SERVICE_MAXTIME 0x000000FF + +// +// SERVICE_BASE is the base of service error codes, +// chosen to avoid conflict with OS, redirector, +// netapi, and errlog codes. +// +// Don't change the comments following the manifest constants without +// understanding how mapmsg works. +// + +#define SERVICE_BASE 3050 +#define SERVICE_UIC_NORMAL 0 +/* + * Uninstall codes, to be used in high byte of 'code' on final NetStatus, + * which sets the status to UNINSTALLED. + */ + +#define SERVICE_UIC_BADPARMVAL (SERVICE_BASE + 1) +/* + * The Registry or the information you just typed includes an illegal + * value for "%1". + */ + +#define SERVICE_UIC_MISSPARM (SERVICE_BASE + 2) +/* + * The required parameter was not provided on the command + * line or in the configuration file. + */ + +#define SERVICE_UIC_UNKPARM (SERVICE_BASE + 3) +/* + * LAN Manager does not recognize "%1" as a valid option. + */ + +#define SERVICE_UIC_RESOURCE (SERVICE_BASE + 4) +/* + * A request for resource could not be satisfied. + */ + +#define SERVICE_UIC_CONFIG (SERVICE_BASE + 5) +/* + * A problem exists with the system configuration. + */ + +#define SERVICE_UIC_SYSTEM (SERVICE_BASE + 6) +/* + * A system error has occurred. + */ + +#define SERVICE_UIC_INTERNAL (SERVICE_BASE + 7) +/* + * An internal consistency error has occurred. + */ + +#define SERVICE_UIC_AMBIGPARM (SERVICE_BASE + 8) +/* + * The configuration file or the command line has an ambiguous option. + */ + +#define SERVICE_UIC_DUPPARM (SERVICE_BASE + 9) +/* + * The configuration file or the command line has a duplicate parameter. + */ + +#define SERVICE_UIC_KILL (SERVICE_BASE + 10) +/* + * The service did not respond to control and was stopped with + * the DosKillProc function. + */ + +#define SERVICE_UIC_EXEC (SERVICE_BASE + 11) +/* + * An error occurred when attempting to run the service program. + */ + +#define SERVICE_UIC_SUBSERV (SERVICE_BASE + 12) +/* + * The sub-service failed to start. + */ + +#define SERVICE_UIC_CONFLPARM (SERVICE_BASE + 13) +/* + * There is a conflict in the value or use of these options: %1. + */ + +#define SERVICE_UIC_FILE (SERVICE_BASE + 14) +/* + * There is a problem with the file. + */ + + + +// +// The modifiers +// + +// +// General: +// + +#define SERVICE_UIC_M_NULL 0 + +// +// RESOURCE: +// + +#define SERVICE_UIC_M_MEMORY (SERVICE_BASE + 20) /* memory */ +#define SERVICE_UIC_M_DISK (SERVICE_BASE + 21) /* disk space */ +#define SERVICE_UIC_M_THREADS (SERVICE_BASE + 22) /* thread */ +#define SERVICE_UIC_M_PROCESSES (SERVICE_BASE + 23) /* process */ + +// +// CONFIG: +// + +// +// Security failure +// + +#define SERVICE_UIC_M_SECURITY (SERVICE_BASE + 24) +/* Security Failure. %0 */ + +#define SERVICE_UIC_M_LANROOT (SERVICE_BASE + 25) +/* + * Bad or missing LAN Manager root directory. + */ + +#define SERVICE_UIC_M_REDIR (SERVICE_BASE + 26) +/* + * The network software is not installed. + */ + +#define SERVICE_UIC_M_SERVER (SERVICE_BASE + 27) +/* + * The server is not started. + */ + +#define SERVICE_UIC_M_SEC_FILE_ERR (SERVICE_BASE + 28) +/* + * The server cannot access the user accounts database (NET.ACC). + */ + +#define SERVICE_UIC_M_FILES (SERVICE_BASE + 29) +/* + * Incompatible files are installed in the LANMAN tree. + */ + +#define SERVICE_UIC_M_LOGS (SERVICE_BASE + 30) +/* + * The LANMAN\LOGS directory is invalid. + */ + +#define SERVICE_UIC_M_LANGROUP (SERVICE_BASE + 31) +/* + * The domain specified could not be used. + */ + +#define SERVICE_UIC_M_MSGNAME (SERVICE_BASE + 32) +/* + * The computer name is being used as a message alias on another computer. + */ + +#define SERVICE_UIC_M_ANNOUNCE (SERVICE_BASE + 33) +/* + * The announcement of the server name failed. + */ + +#define SERVICE_UIC_M_UAS (SERVICE_BASE + 34) +/* + * The user accounts database is not configured correctly. + */ + +#define SERVICE_UIC_M_SERVER_SEC_ERR (SERVICE_BASE + 35) +/* + * The server is not running with user-level security. + */ + +#define SERVICE_UIC_M_WKSTA (SERVICE_BASE + 37) +/* + * The workstation is not configured properly. + */ + +#define SERVICE_UIC_M_ERRLOG (SERVICE_BASE + 38) +/* + * View your error log for details. + */ + +#define SERVICE_UIC_M_FILE_UW (SERVICE_BASE + 39) +/* + * Unable to write to this file. + */ + +#define SERVICE_UIC_M_ADDPAK (SERVICE_BASE + 40) +/* + * ADDPAK file is corrupted. Delete LANMAN\NETPROG\ADDPAK.SER + * and reapply all ADDPAKs. + */ + +#define SERVICE_UIC_M_LAZY (SERVICE_BASE + 41) +/* + * The LM386 server cannot be started because CACHE.EXE is not running. + */ + +#define SERVICE_UIC_M_UAS_MACHINE_ACCT (SERVICE_BASE + 42) +/* + * There is no account for this computer in the security database. + */ + +#define SERVICE_UIC_M_UAS_SERVERS_NMEMB (SERVICE_BASE + 43) +/* + * This computer is not a member of the group SERVERS. + */ + +#define SERVICE_UIC_M_UAS_SERVERS_NOGRP (SERVICE_BASE + 44) +/* + * The group SERVERS is not present in the local security database. + */ + +#define SERVICE_UIC_M_UAS_INVALID_ROLE (SERVICE_BASE + 45) +/* + * This Windows NT computer is configured as a member of a workgroup, not as + * a member of a domain. The Netlogon service does not need to run in this + * configuration. + */ + +#define SERVICE_UIC_M_NETLOGON_NO_DC (SERVICE_BASE + 46) +/* + * The Windows NT domain controller for this domain could not be located. + */ + +#define SERVICE_UIC_M_NETLOGON_DC_CFLCT (SERVICE_BASE + 47) +/* + * A primary domain controller is already running in this domain. + */ + +#define SERVICE_UIC_M_NETLOGON_AUTH (SERVICE_BASE + 48) +/* + * The service failed to authenticate with the primary domain controller. + */ + +#define SERVICE_UIC_M_UAS_PROLOG (SERVICE_BASE + 49) +/* + * There is a problem with the security database creation date or serial number. + */ + + +#define SERVICE2_BASE 5600 +/* new SEVICE_UIC messages go here */ + +#define SERVICE_UIC_M_NETLOGON_MPATH (SERVICE2_BASE + 0) +/* + * Could not share the User or Script path. + */ + +#define SERVICE_UIC_M_LSA_MACHINE_ACCT (SERVICE2_BASE + 1) +/* + * The password for this computer is not found in the local security + * database. + */ + +#define SERVICE_UIC_M_DATABASE_ERROR (SERVICE2_BASE + 2) +/* + * An internal error occurred while accessing the computer's + * local or network security database. + */ + + +// +// End modifiers +// + +// +// Commonly used Macros: +// + +#define SERVICE_IP_CODE(tt,nn) \ + ((long)SERVICE_IP_QUERY_HINT|(long)(nn|(tt<<SERVICE_IP_WAITTIME_SHIFT))) + +#define SERVICE_CCP_CODE(tt,nn) \ + ((long)SERVICE_CCP_QUERY_HINT|(long)(nn|(tt<<SERVICE_IP_WAITTIME_SHIFT))) + +#define SERVICE_UIC_CODE(cc,mm) \ + ((long)(((long)cc<<16)|(long)(unsigned short)mm)) + +// +// This macro takes a wait hint (tt) which can have a maximum value of +// 0xFFFF and puts it into the service status code field. +// 0x0FF1FFnn (where nn is the checkpoint information). +// +#define SERVICE_NT_CCP_CODE(tt,nn) \ + ( \ + ((long)SERVICE_CCP_QUERY_HINT) | \ + ((long)(nn)) | \ + (((tt)&LOWER_HINT_MASK) << SERVICE_IP_WAITTIME_SHIFT) | \ + (((tt)&UPPER_HINT_MASK) << SERVICE_NTIP_WAITTIME_SHIFT) \ + ) + +// +// This macro takes a status code field, and strips out the wait hint +// from the upper and lower sections. +// 0x0FF1FFnn results in 0x0000FFFF. +// +#define SERVICE_NT_WAIT_GET(code) \ + ( \ + (((code) & UPPER_GET_HINT_MASK) >> SERVICE_NTIP_WAITTIME_SHIFT) | \ + (((code) & LOWER_GET_HINT_MASK) >> SERVICE_IP_WAITTIME_SHIFT) \ + ) + +#ifdef __cplusplus +} +#endif + +#endif // _LMSVC_ |