summaryrefslogtreecommitdiffstats
path: root/public/sdk/inc/lmsvc.h
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--public/sdk/inc/lmsvc.h532
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_