source: branches/samba-3.0/source/include/rpc_svcctl.h

Last change on this file was 1, checked in by Paul Smedley, 18 years ago

Initial code import

File size: 9.6 KB
Line 
1/*
2 Unix SMB/CIFS implementation.
3 SMB parameters and setup
4 Copyright (C) Andrew Tridgell 1992-1997,
5 Copyright (C) Gerald (Jerry) Carter 2005
6
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2 of the License, or
10 (at your option) any later version.
11
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software
19 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20*/
21
22#ifndef _RPC_SVCCTL_H /* _RPC_SVCCTL_H */
23#define _RPC_SVCCTL_H
24
25/* svcctl pipe */
26
27#define SVCCTL_CLOSE_SERVICE 0x00
28#define SVCCTL_CONTROL_SERVICE 0x01
29#define SVCCTL_LOCK_SERVICE_DB 0x03
30#define SVCCTL_QUERY_SERVICE_SEC 0x04
31#define SVCCTL_SET_SERVICE_SEC 0x05
32#define SVCCTL_QUERY_STATUS 0x06
33#define SVCCTL_UNLOCK_SERVICE_DB 0x08
34#define SVCCTL_ENUM_DEPENDENT_SERVICES_W 0x0d
35#define SVCCTL_ENUM_SERVICES_STATUS_W 0x0e
36#define SVCCTL_OPEN_SCMANAGER_W 0x0f
37#define SVCCTL_OPEN_SERVICE_W 0x10
38#define SVCCTL_QUERY_SERVICE_CONFIG_W 0x11
39#define SVCCTL_START_SERVICE_W 0x13
40#define SVCCTL_GET_DISPLAY_NAME 0x14
41#define SVCCTL_QUERY_SERVICE_CONFIG2_W 0x27
42#define SVCCTL_QUERY_SERVICE_STATUSEX_W 0x28
43
44/* ANSI versions not implemented currently
45#define SVCCTL_ENUM_SERVICES_STATUS_A 0x0e
46#define SVCCTL_OPEN_SCMANAGER_A 0x1b
47*/
48
49/* SERVER_STATUS - type */
50
51#define SVCCTL_TYPE_WIN32 0x00000030
52#define SVCCTL_TYPE_DRIVER 0x0000000f
53
54/* SERVER_STATUS - state */
55#define SVCCTL_STATE_ACTIVE 0x00000001
56#define SVCCTL_STATE_INACTIVE 0x00000002
57#define SVCCTL_STATE_ALL ( SVCCTL_STATE_ACTIVE | SVCCTL_STATE_INACTIVE )
58
59/* SERVER_STATUS - CurrentState */
60
61#define SVCCTL_STATE_UNKNOWN 0x00000000 /* only used internally to smbd */
62#define SVCCTL_STOPPED 0x00000001
63#define SVCCTL_START_PENDING 0x00000002
64#define SVCCTL_STOP_PENDING 0x00000003
65#define SVCCTL_RUNNING 0x00000004
66#define SVCCTL_CONTINUE_PENDING 0x00000005
67#define SVCCTL_PAUSE_PENDING 0x00000006
68#define SVCCTL_PAUSED 0x00000007
69
70/* SERVER_STATUS - ControlAccepted */
71
72#define SVCCTL_ACCEPT_NONE 0x00000000
73#define SVCCTL_ACCEPT_STOP 0x00000001
74#define SVCCTL_ACCEPT_PAUSE_CONTINUE 0x00000002
75#define SVCCTL_ACCEPT_SHUTDOWN 0x00000004
76#define SVCCTL_ACCEPT_PARAMCHANGE 0x00000008
77#define SVCCTL_ACCEPT_NETBINDCHANGE 0x00000010
78#define SVCCTL_ACCEPT_HARDWAREPROFILECHANGE 0x00000020
79#define SVCCTL_ACCEPT_POWEREVENT 0x00000040
80
81/* SERVER_STATUS - ControlAccepted */
82#define SVCCTL_SVC_ERROR_IGNORE 0x00000000
83#define SVCCTL_SVC_ERROR_NORMAL 0x00000001
84#define SVCCTL_SVC_ERROR_CRITICAL 0x00000002
85#define SVCCTL_SVC_ERROR_SEVERE 0x00000003
86
87/* QueryServiceConfig2 options */
88#define SERVICE_CONFIG_DESCRIPTION 0x00000001
89#define SERVICE_CONFIG_FAILURE_ACTIONS 0x00000002
90
91
92/* Service Config - values for ServiceType field*/
93
94#define SVCCTL_KERNEL_DRVR 0x00000001 /* doubtful we'll have these */
95#define SVCCTL_FILE_SYSTEM_DRVR 0x00000002
96#define SVCCTL_WIN32_OWN_PROC 0x00000010
97#define SVCCTL_WIN32_SHARED_PROC 0x00000020
98#define SVCCTL_WIN32_INTERACTIVE 0x00000100
99
100/* Service Config - values for StartType field */
101#define SVCCTL_BOOT_START 0x00000000
102#define SVCCTL_SYSTEM_START 0x00000001
103#define SVCCTL_AUTO_START 0x00000002
104#define SVCCTL_DEMAND_START 0x00000003
105#define SVCCTL_DISABLED 0x00000004
106
107/* Service Controls */
108
109#define SVCCTL_CONTROL_STOP 0x00000001
110#define SVCCTL_CONTROL_PAUSE 0x00000002
111#define SVCCTL_CONTROL_CONTINUE 0x00000003
112#define SVCCTL_CONTROL_INTERROGATE 0x00000004
113#define SVCCTL_CONTROL_SHUTDOWN 0x00000005
114
115#define SVC_HANDLE_IS_SCM 0x0000001
116#define SVC_HANDLE_IS_SERVICE 0x0000002
117#define SVC_HANDLE_IS_DBLOCK 0x0000003
118
119#define SVC_STATUS_PROCESS_INFO 0x00000000
120
121/* where we assume the location of the service control scripts */
122#define SVCCTL_SCRIPT_DIR "svcctl"
123
124/* utility structures for RPCs */
125
126typedef struct {
127 uint32 type;
128 uint32 state;
129 uint32 controls_accepted;
130 WERROR win32_exit_code;
131 uint32 service_exit_code;
132 uint32 check_point;
133 uint32 wait_hint;
134} SERVICE_STATUS;
135
136typedef struct {
137 SERVICE_STATUS status;
138 uint32 process_id;
139 uint32 service_flags;
140} SERVICE_STATUS_PROCESS;
141
142
143typedef struct {
144 UNISTR servicename;
145 UNISTR displayname;
146 SERVICE_STATUS status;
147} ENUM_SERVICES_STATUS;
148
149typedef struct {
150 uint32 service_type;
151 uint32 start_type;
152 uint32 error_control;
153 UNISTR2 *executablepath;
154 UNISTR2 *loadordergroup;
155 uint32 tag_id;
156 UNISTR2 *dependencies;
157 UNISTR2 *startname;
158 UNISTR2 *displayname;
159} SERVICE_CONFIG;
160
161typedef struct {
162 uint32 unknown;
163 UNISTR description;
164} SERVICE_DESCRIPTION;
165
166typedef struct {
167 uint32 type;
168 uint32 delay;
169} SC_ACTION;
170
171typedef struct {
172 uint32 reset_period;
173 UNISTR2 *rebootmsg; /* i have no idea if these are UNISTR2's. I can't get a good trace */
174 UNISTR2 *command;
175 uint32 num_actions;
176 SC_ACTION *actions;
177} SERVICE_FAILURE_ACTIONS;
178
179/*
180 * dispatch table of functions to handle the =ServiceControl API
181 */
182
183typedef struct {
184 /* functions for enumerating subkeys and values */
185 WERROR (*stop_service)( const char *service, SERVICE_STATUS *status );
186 WERROR (*start_service) ( const char *service );
187 WERROR (*service_status)( const char *service, SERVICE_STATUS *status );
188} SERVICE_CONTROL_OPS;
189
190/* structure to store the service handle information */
191
192typedef struct _ServiceInfo {
193 uint8 type;
194 char *name;
195 uint32 access_granted;
196 SERVICE_CONTROL_OPS *ops;
197} SERVICE_INFO;
198
199
200/* rpc structures */
201
202/**************************/
203
204typedef struct {
205 POLICY_HND handle;
206} SVCCTL_Q_CLOSE_SERVICE;
207
208typedef struct {
209 POLICY_HND handle;
210 WERROR status;
211} SVCCTL_R_CLOSE_SERVICE;
212
213/**************************/
214
215typedef struct {
216 UNISTR2 *servername;
217 UNISTR2 *database;
218 uint32 access;
219} SVCCTL_Q_OPEN_SCMANAGER;
220
221typedef struct {
222 POLICY_HND handle;
223 WERROR status;
224} SVCCTL_R_OPEN_SCMANAGER;
225
226/**************************/
227
228typedef struct {
229 POLICY_HND handle;
230 UNISTR2 servicename;
231 uint32 display_name_len;
232} SVCCTL_Q_GET_DISPLAY_NAME;
233
234typedef struct {
235 UNISTR2 displayname;
236 uint32 display_name_len;
237 WERROR status;
238} SVCCTL_R_GET_DISPLAY_NAME;
239
240/**************************/
241
242typedef struct {
243 POLICY_HND handle;
244 UNISTR2 servicename;
245 uint32 access;
246} SVCCTL_Q_OPEN_SERVICE;
247
248typedef struct {
249 POLICY_HND handle;
250 WERROR status;
251} SVCCTL_R_OPEN_SERVICE;
252
253/**************************/
254
255typedef struct {
256 POLICY_HND handle;
257 uint32 parmcount;
258 UNISTR4_ARRAY *parameters;
259} SVCCTL_Q_START_SERVICE;
260
261typedef struct {
262 WERROR status;
263} SVCCTL_R_START_SERVICE;
264
265/**************************/
266
267typedef struct {
268 POLICY_HND handle;
269 uint32 control;
270} SVCCTL_Q_CONTROL_SERVICE;
271
272typedef struct {
273 SERVICE_STATUS svc_status;
274 WERROR status;
275} SVCCTL_R_CONTROL_SERVICE;
276
277/**************************/
278
279typedef struct {
280 POLICY_HND handle;
281} SVCCTL_Q_QUERY_STATUS;
282
283typedef struct {
284 SERVICE_STATUS svc_status;
285 WERROR status;
286} SVCCTL_R_QUERY_STATUS;
287
288/**************************/
289
290typedef struct {
291 POLICY_HND handle;
292 uint32 type;
293 uint32 state;
294 uint32 buffer_size;
295 uint32 *resume;
296} SVCCTL_Q_ENUM_SERVICES_STATUS;
297
298typedef struct {
299 RPC_BUFFER buffer;
300 uint32 needed;
301 uint32 returned;
302 uint32 *resume;
303 WERROR status;
304} SVCCTL_R_ENUM_SERVICES_STATUS;
305
306/**************************/
307
308typedef struct {
309 POLICY_HND handle;
310 uint32 state;
311 uint32 buffer_size;
312} SVCCTL_Q_ENUM_DEPENDENT_SERVICES;
313
314typedef struct {
315 RPC_BUFFER buffer;
316 uint32 needed;
317 uint32 returned;
318 WERROR status;
319} SVCCTL_R_ENUM_DEPENDENT_SERVICES;
320
321
322/**************************/
323
324typedef struct {
325 POLICY_HND handle;
326 uint32 buffer_size;
327} SVCCTL_Q_QUERY_SERVICE_CONFIG;
328
329typedef struct {
330 SERVICE_CONFIG config;
331 uint32 needed;
332 WERROR status;
333} SVCCTL_R_QUERY_SERVICE_CONFIG;
334
335
336/**************************/
337
338typedef struct {
339 POLICY_HND handle;
340 uint32 level;
341 uint32 buffer_size;
342} SVCCTL_Q_QUERY_SERVICE_CONFIG2;
343
344typedef struct {
345 RPC_BUFFER buffer;
346 uint32 needed;
347 WERROR status;
348} SVCCTL_R_QUERY_SERVICE_CONFIG2;
349
350
351/**************************/
352
353typedef struct {
354 POLICY_HND handle;
355 uint32 level;
356 uint32 buffer_size;
357} SVCCTL_Q_QUERY_SERVICE_STATUSEX;
358
359typedef struct {
360 RPC_BUFFER buffer;
361 uint32 needed;
362 WERROR status;
363} SVCCTL_R_QUERY_SERVICE_STATUSEX;
364
365
366/**************************/
367
368typedef struct {
369 POLICY_HND handle;
370} SVCCTL_Q_LOCK_SERVICE_DB;
371
372typedef struct {
373 POLICY_HND h_lock;
374 WERROR status;
375} SVCCTL_R_LOCK_SERVICE_DB;
376
377
378/**************************/
379
380typedef struct {
381 POLICY_HND h_lock;
382} SVCCTL_Q_UNLOCK_SERVICE_DB;
383
384typedef struct {
385 WERROR status;
386} SVCCTL_R_UNLOCK_SERVICE_DB;
387
388
389/**************************/
390
391typedef struct {
392 POLICY_HND handle;
393 uint32 security_flags;
394 uint32 buffer_size;
395} SVCCTL_Q_QUERY_SERVICE_SEC;
396
397typedef struct {
398 RPC_BUFFER buffer;
399 uint32 needed;
400 WERROR status;
401} SVCCTL_R_QUERY_SERVICE_SEC;
402
403/**************************/
404
405typedef struct {
406 POLICY_HND handle;
407 uint32 security_flags;
408 RPC_BUFFER buffer;
409 uint32 buffer_size;
410} SVCCTL_Q_SET_SERVICE_SEC;
411
412typedef struct {
413 WERROR status;
414} SVCCTL_R_SET_SERVICE_SEC;
415
416
417#endif /* _RPC_SVCCTL_H */
418
Note: See TracBrowser for help on using the repository browser.