Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

140 lines
3.3 KiB

/*++
Copyright (c) 1990 Microsoft Corporation
Module Name:
svcsp.h
Abstract:
This file contains definitions used by service dlls that
run inside of services.exe.
Author:
Jonathan Schwartz (jschwart) 20-Sep-2000
--*/
#ifndef _SVCSP_
#define _SVCSP_
#ifndef RPC_NO_WINDOWS_H // Don't let rpc.h include windows.h
#define RPC_NO_WINDOWS_H
#endif // RPC_NO_WINDOWS_H
#include <rpc.h> // RPC_IF_HANDLE
//
// Service DLLs loaded into services.exe all export the same main
// entry point. SVCS_ENTRY_POINT defines that name.
//
// Note that SVCS_ENTRY_POINT_STRING is always ANSI, because that's
// what GetProcAddress takes.
//
#define SVCS_ENTRY_POINT ServiceEntry
#define SVCS_ENTRY_POINT_STRING "ServiceEntry"
//
// Name for the common RPC pipe shared by all the RPC servers in services.exe.
// Note: Because version 1.0 of WinNt had seperate names for each server's
// pipe, the client side names have remained the same. Mapping to the new
// name is handled by the named pipe file system.
//
#define SVCS_RPC_PIPE L"ntsvcs"
//
// Name for the common LRPC protocol and port available in services.exe.
//
#define SVCS_LRPC_PROTOCOL L"ncalrpc"
#define SVCS_LRPC_PORT L"ntsvcs"
//
// Start and stop RPC server entry point prototype.
//
typedef
NTSTATUS
(*PSVCS_START_RPC_SERVER) (
IN LPTSTR InterfaceName,
IN RPC_IF_HANDLE InterfaceSpecification
);
typedef
NTSTATUS
(*PSVCS_STOP_RPC_SERVER) (
IN RPC_IF_HANDLE InterfaceSpecification
);
//
// Structure containing "global" data for the various DLLs.
//
typedef struct _SVCS_GLOBAL_DATA
{
//
// NT well-known SIDs
//
PSID NullSid; // No members SID
PSID WorldSid; // All users SID
PSID LocalSid; // NT local users SID
PSID NetworkSid; // NT remote users SID
PSID LocalSystemSid; // NT system processes SID
PSID LocalServiceSid; // NT LocalService SID
PSID NetworkServiceSid; // NT NetworkService SID
PSID BuiltinDomainSid; // Domain Id of the Builtin Domain
PSID AuthenticatedUserSid; // NT authenticated users SID
//
// Well Known Aliases.
//
// These are aliases that are relative to the built-in domain.
//
PSID AliasAdminsSid; // Administrator Sid
PSID AliasUsersSid; // User Sid
PSID AliasGuestsSid; // Guest Sid
PSID AliasPowerUsersSid; // Power User Sid
PSID AliasAccountOpsSid; // Account Operator Sid
PSID AliasSystemOpsSid; // System Operator Sid
PSID AliasPrintOpsSid; // Print Operator Sid
PSID AliasBackupOpsSid; // Backup Operator Sid
//
// Entry points provided by services.exe
//
PSVCS_START_RPC_SERVER StartRpcServer;
PSVCS_STOP_RPC_SERVER StopRpcServer;
LPWSTR SvcsRpcPipeName;
//
// Miscellaneous useful data
//
BOOL fSetupInProgress; // TRUE if setup is in progress, FALSE otherwise
}
SVCS_GLOBAL_DATA, *PSVCS_GLOBAL_DATA;
//
// Service DLL entrypoint prototype
//
typedef
VOID
(*PSVCS_SERVICE_DLL_ENTRY) (
IN DWORD argc,
IN LPTSTR argv[],
IN PSVCS_GLOBAL_DATA pGlobalData,
IN HANDLE SvcReferenceHandle
);
#endif // ndef _SVCSP_