|
|
/*++ BUILD Version: 0002 // Increment this if a change has global effects
Copyright (c) 1991-1999 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_
#if _MSC_VER > 1000 #pragma once #endif
#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 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 primary Domain Controller for this domain could not be located. */
#define SERVICE_UIC_M_NETLOGON_DC_CFLCT (SERVICE_BASE + 47) /* * This computer is configured to be the primary domain controller of its domain. * However, the computer %1 is currently claiming to be the primary domain controller * of the 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_
|