svcctl: add svcctl_ErrorControl and svcctl_Type (based on samba3) to IDL.
[metze/samba/wip.git] / source3 / include / rpc_svcctl.h
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 3 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, see <http://www.gnu.org/licenses/>.
19 */
20
21 #ifndef _RPC_SVCCTL_H /* _RPC_SVCCTL_H */
22 #define _RPC_SVCCTL_H 
23
24 /* svcctl pipe */
25
26 #define SVCCTL_CLOSE_SERVICE                    0x00
27 #define SVCCTL_CONTROL_SERVICE                  0x01
28 #define SVCCTL_LOCK_SERVICE_DB                  0x03
29 #define SVCCTL_QUERY_SERVICE_SEC                0x04
30 #define SVCCTL_SET_SERVICE_SEC                  0x05
31 #define SVCCTL_QUERY_STATUS                     0x06
32 #define SVCCTL_UNLOCK_SERVICE_DB                0x08
33 #define SVCCTL_ENUM_DEPENDENT_SERVICES_W        0x0d
34 #define SVCCTL_ENUM_SERVICES_STATUS_W           0x0e
35 #define SVCCTL_OPEN_SCMANAGER_W                 0x0f
36 #define SVCCTL_OPEN_SERVICE_W                   0x10
37 #define SVCCTL_QUERY_SERVICE_CONFIG_W           0x11
38 #define SVCCTL_START_SERVICE_W                  0x13
39 #define SVCCTL_GET_DISPLAY_NAME                 0x14
40 #define SVCCTL_QUERY_SERVICE_CONFIG2_W          0x27
41 #define SVCCTL_QUERY_SERVICE_STATUSEX_W         0x28
42
43 /* ANSI versions not implemented currently 
44 #define SVCCTL_ENUM_SERVICES_STATUS_A           0x0e
45 #define SVCCTL_OPEN_SCMANAGER_A                 0x1b
46 */
47
48 /* SERVER_STATUS - type */
49
50 #define SVCCTL_TYPE_WIN32               0x00000030
51 #define SVCCTL_TYPE_DRIVER              0x0000000f
52
53 /* SERVER_STATUS - state */
54 #define SVCCTL_STATE_ACTIVE             0x00000001
55 #define SVCCTL_STATE_INACTIVE           0x00000002
56 #define SVCCTL_STATE_ALL                ( SVCCTL_STATE_ACTIVE | SVCCTL_STATE_INACTIVE )
57
58 /* SERVER_STATUS - CurrentState */
59
60 #define SVCCTL_STATE_UNKNOWN            0x00000000      /* only used internally to smbd */
61 #define SVCCTL_STOPPED                  0x00000001
62 #define SVCCTL_START_PENDING            0x00000002
63 #define SVCCTL_STOP_PENDING             0x00000003
64 #define SVCCTL_RUNNING                  0x00000004
65 #define SVCCTL_CONTINUE_PENDING         0x00000005
66 #define SVCCTL_PAUSE_PENDING            0x00000006
67 #define SVCCTL_PAUSED                   0x00000007
68
69 /* SERVER_STATUS - ControlAccepted */
70
71 #define SVCCTL_ACCEPT_NONE                      0x00000000
72 #define SVCCTL_ACCEPT_STOP                      0x00000001
73 #define SVCCTL_ACCEPT_PAUSE_CONTINUE            0x00000002
74 #define SVCCTL_ACCEPT_SHUTDOWN                  0x00000004
75 #define SVCCTL_ACCEPT_PARAMCHANGE               0x00000008
76 #define SVCCTL_ACCEPT_NETBINDCHANGE             0x00000010
77 #define SVCCTL_ACCEPT_HARDWAREPROFILECHANGE     0x00000020
78 #define SVCCTL_ACCEPT_POWEREVENT                0x00000040
79
80 /* Service Config - values for ServiceType field*/
81
82 #define SVCCTL_KERNEL_DRVR                         0x00000001  /* doubtful we'll have these */
83 #define SVCCTL_FILE_SYSTEM_DRVR                    0x00000002  
84 #define SVCCTL_WIN32_OWN_PROC                      0x00000010
85 #define SVCCTL_WIN32_SHARED_PROC                   0x00000020
86 #define SVCCTL_WIN32_INTERACTIVE                   0x00000100 
87
88 #define SVC_HANDLE_IS_SCM                       0x0000001
89 #define SVC_HANDLE_IS_SERVICE                   0x0000002
90 #define SVC_HANDLE_IS_DBLOCK                    0x0000003
91
92 /* utility structures for RPCs */
93
94 /*
95  * "struct SERVICE_STATUS" comes from librpc/gen_ndr/svcctl.h
96  */
97
98 typedef struct SERVICE_STATUS SERVICE_STATUS;
99
100 typedef struct {
101         SERVICE_STATUS status;
102         uint32 process_id;
103         uint32 service_flags;
104 } SERVICE_STATUS_PROCESS;
105
106
107 typedef struct {
108         UNISTR servicename;
109         UNISTR displayname;
110         SERVICE_STATUS status;
111 } ENUM_SERVICES_STATUS;
112
113 typedef struct {
114         uint32 unknown; 
115         UNISTR description;
116 } SERVICE_DESCRIPTION;
117
118 typedef struct {
119         uint32 type;
120         uint32 delay;
121 } SC_ACTION;
122
123 typedef struct {
124         uint32 reset_period;
125         UNISTR2 *rebootmsg;     /* i have no idea if these are UNISTR2's.  I can't get a good trace */
126         UNISTR2 *command;
127         uint32  num_actions;
128         SC_ACTION *actions;
129 } SERVICE_FAILURE_ACTIONS;
130
131
132 /* rpc structures */
133
134 /**************************/
135
136 typedef struct {
137         POLICY_HND handle;
138         uint32 type;
139         uint32 state;
140         uint32 buffer_size;
141         uint32 *resume;
142 } SVCCTL_Q_ENUM_SERVICES_STATUS;
143
144 typedef struct {
145         RPC_BUFFER buffer;
146         uint32 needed;
147         uint32 returned;
148         uint32 *resume;
149         WERROR status;
150 } SVCCTL_R_ENUM_SERVICES_STATUS;
151
152 /**************************/
153
154 typedef struct {
155         POLICY_HND handle;
156         uint32 level;
157         uint32 buffer_size;
158 } SVCCTL_Q_QUERY_SERVICE_CONFIG2;
159
160 typedef struct {
161         RPC_BUFFER buffer;
162         uint32 needed;
163         WERROR status;
164 } SVCCTL_R_QUERY_SERVICE_CONFIG2;
165
166
167 /**************************/
168
169 typedef struct {
170         POLICY_HND handle;
171         uint32 level;
172         uint32 buffer_size;
173 } SVCCTL_Q_QUERY_SERVICE_STATUSEX;
174
175 typedef struct {
176         RPC_BUFFER buffer;
177         uint32 needed;
178         WERROR status;
179 } SVCCTL_R_QUERY_SERVICE_STATUSEX;
180
181 #endif /* _RPC_SVCCTL_H */
182