Rerun pidl.
[amitay/samba.git] / librpc / gen_ndr / svcctl.h
index c36f5781017ac6e71e1776d00c4e716efb75f257..6ba0e4f3785ef8cc2f40a1c192c7e51466bedc77 100644 (file)
@@ -2,6 +2,8 @@
 
 #include <stdint.h>
 
+#include "libcli/util/ntstatus.h"
+
 #include "librpc/gen_ndr/misc.h"
 #include "librpc/gen_ndr/security.h"
 #ifndef _HEADER_svcctl
@@ -15,9 +17,7 @@
 #define SERVICE_TYPE_WIN32_OWN_PROCESS ( 0x10 )
 #define SERVICE_TYPE_WIN32_SHARE_PROCESS       ( 0x20 )
 #define SERVICE_TYPE_WIN32     ( SERVICE_TYPE_WIN32_OWN_PROCESS|SERVICE_TYPE_WIN32_SHARE_PROCESS )
-#define SERVICE_STATE_ACTIVE   ( 0x01 )
-#define SERVICE_STATE_INACTIVE ( 0x02 )
-#define SERVICE_STATE_ALL      ( 0x03 )
+#define SERVICE_TYPE_INTERACTIVE_PROCESS       ( 0x100 )
 #define SV_TYPE_ALL    ( 0xFFFFFFFF )
 #define SC_MANAGER_READ_ACCESS ( (SEC_STD_READ_CONTROL|SC_RIGHT_MGR_CONNECT|SC_RIGHT_MGR_ENUMERATE_SERVICE|SC_RIGHT_MGR_QUERY_LOCK_STATUS) )
 #define SC_MANAGER_EXECUTE_ACCESS      ( SC_MANAGER_READ_ACCESS )
@@ -33,9 +33,44 @@ struct SERVICE_LOCK_STATUS {
        uint32_t lock_duration;
 };
 
+enum svcctl_ServiceStatus
+#ifndef USE_UINT_ENUMS
+ {
+       SVCCTL_STATE_UNKNOWN=0x00000000,
+       SVCCTL_STOPPED=0x00000001,
+       SVCCTL_START_PENDING=0x00000002,
+       SVCCTL_STOP_PENDING=0x00000003,
+       SVCCTL_RUNNING=0x00000004,
+       SVCCTL_CONTINUE_PENDING=0x00000005,
+       SVCCTL_PAUSE_PENDING=0x00000006,
+       SVCCTL_PAUSED=0x00000007
+}
+#else
+ { __donnot_use_enum_svcctl_ServiceStatus=0x7FFFFFFF}
+#define SVCCTL_STATE_UNKNOWN ( 0x00000000 )
+#define SVCCTL_STOPPED ( 0x00000001 )
+#define SVCCTL_START_PENDING ( 0x00000002 )
+#define SVCCTL_STOP_PENDING ( 0x00000003 )
+#define SVCCTL_RUNNING ( 0x00000004 )
+#define SVCCTL_CONTINUE_PENDING ( 0x00000005 )
+#define SVCCTL_PAUSE_PENDING ( 0x00000006 )
+#define SVCCTL_PAUSED ( 0x00000007 )
+#endif
+;
+
+/* bitmap svcctl_ControlsAccepted */
+#define SVCCTL_ACCEPT_NONE ( 0x00000000 )
+#define SVCCTL_ACCEPT_STOP ( 0x00000001 )
+#define SVCCTL_ACCEPT_PAUSE_CONTINUE ( 0x00000002 )
+#define SVCCTL_ACCEPT_SHUTDOWN ( 0x00000004 )
+#define SVCCTL_ACCEPT_PARAMCHANGE ( 0x00000008 )
+#define SVCCTL_ACCEPT_NETBINDCHANGE ( 0x00000010 )
+#define SVCCTL_ACCEPT_HARDWAREPROFILECHANGE ( 0x00000020 )
+#define SVCCTL_ACCEPT_POWEREVENT ( 0x00000040 )
+
 struct SERVICE_STATUS {
        uint32_t type;
-       uint32_t state;
+       enum svcctl_ServiceStatus state;
        uint32_t controls_accepted;
        WERROR win32_exit_code;
        uint32_t service_exit_code;
@@ -49,11 +84,17 @@ struct SERVICE_STATUS_PROCESS {
        uint32_t service_flags;
 }/* [public] */;
 
-struct ENUM_SERVICE_STATUS {
+struct ENUM_SERVICE_STATUSW {
+       const char * service_name;/* [relative,flag(LIBNDR_FLAG_STR_NULLTERM)] */
+       const char * display_name;/* [relative,flag(LIBNDR_FLAG_STR_NULLTERM)] */
+       struct SERVICE_STATUS status;
+}/* [gensize,public] */;
+
+struct ENUM_SERVICE_STATUSA {
        const char * service_name;/* [relative,flag(LIBNDR_FLAG_STR_ASCII|LIBNDR_FLAG_STR_NULLTERM)] */
        const char * display_name;/* [relative,flag(LIBNDR_FLAG_STR_ASCII|LIBNDR_FLAG_STR_NULLTERM)] */
        struct SERVICE_STATUS status;
-};
+}/* [gensize,public] */;
 
 /* bitmap svcctl_ServerType */
 #define SV_TYPE_WORKSTATION ( 0x00000001 )
@@ -142,15 +183,15 @@ enum svcctl_StartType
 enum svcctl_ServiceState
 #ifndef USE_UINT_ENUMS
  {
-       SVCCTL_STATE_ACTIVE=0x00000001,
-       SVCCTL_STATE_INACTIVE=0x00000002,
-       SVCCTL_STATE_ALL=(SVCCTL_STATE_ACTIVE|SVCCTL_STATE_INACTIVE)
+       SERVICE_STATE_ACTIVE=0x00000001,
+       SERVICE_STATE_INACTIVE=0x00000002,
+       SERVICE_STATE_ALL=(SERVICE_STATE_ACTIVE|SERVICE_STATE_INACTIVE)
 }
 #else
  { __donnot_use_enum_svcctl_ServiceState=0x7FFFFFFF}
-#define SVCCTL_STATE_ACTIVE ( 0x00000001 )
-#define SVCCTL_STATE_INACTIVE ( 0x00000002 )
-#define SVCCTL_STATE_ALL ( (SVCCTL_STATE_ACTIVE|SVCCTL_STATE_INACTIVE) )
+#define SERVICE_STATE_ACTIVE ( 0x00000001 )
+#define SERVICE_STATE_INACTIVE ( 0x00000002 )
+#define SERVICE_STATE_ALL ( (SERVICE_STATE_ACTIVE|SERVICE_STATE_INACTIVE) )
 #endif
 ;
 
@@ -456,14 +497,14 @@ struct svcctl_EnumServicesStatusW {
                struct policy_handle *handle;/* [ref] */
                uint32_t type;
                enum svcctl_ServiceState state;
-               uint32_t buf_size;/* [range(0,262144)] */
+               uint32_t buf_size;/* [range(0,0x40000)] */
                uint32_t *resume_handle;/* [unique] */
        } in;
 
        struct {
                uint8_t *service;/* [ref,size_is(buf_size)] */
-               uint32_t *bytes_needed;/* [ref,range(0,262144)] */
-               uint32_t *services_returned;/* [ref,range(0,262144)] */
+               uint32_t *bytes_needed;/* [ref,range(0,0x40000)] */
+               uint32_t *services_returned;/* [ref,range(0,0x40000)] */
                uint32_t *resume_handle;/* [unique] */
                WERROR result;
        } out;
@@ -646,7 +687,7 @@ struct svcctl_EnumDependentServicesA {
        } in;
 
        struct {
-               struct ENUM_SERVICE_STATUS *service_status;/* [unique] */
+               struct ENUM_SERVICE_STATUSA *service_status;/* [unique] */
                uint32_t *bytes_needed;/* [ref] */
                uint32_t *services_returned;/* [ref] */
                WERROR result;
@@ -659,7 +700,7 @@ struct svcctl_EnumServicesStatusA {
        struct {
                struct policy_handle *handle;/* [ref] */
                uint32_t type;
-               uint32_t state;
+               enum svcctl_ServiceState state;
                uint32_t buf_size;
                uint32_t *resume_handle;/* [unique] */
        } in;
@@ -877,7 +918,7 @@ struct EnumServicesStatusExA {
                struct policy_handle *scmanager;/* [ref] */
                uint32_t info_level;
                uint32_t type;
-               uint32_t state;
+               enum svcctl_ServiceState state;
                uint32_t buf_size;
                uint32_t *resume_handle;/* [unique] */
        } in;
@@ -899,17 +940,17 @@ struct EnumServicesStatusExW {
                struct policy_handle *scmanager;/* [ref] */
                uint32_t info_level;
                uint32_t type;
-               uint32_t state;
-               uint32_t buf_size;/* [range(0,262144)] */
+               enum svcctl_ServiceState state;
+               uint32_t buf_size;/* [range(0,0x40000)] */
                const char *group_name;/* [unique,charset(UTF16)] */
-               uint32_t *resume_handle;/* [unique,range(0,262144)] */
+               uint32_t *resume_handle;/* [unique,range(0,0x40000)] */
        } in;
 
        struct {
                uint8_t *services;/* [ref,size_is(buf_size)] */
-               uint32_t *bytes_needed;/* [ref,range(0,262144)] */
-               uint32_t *service_returned;/* [ref,range(0,262144)] */
-               uint32_t *resume_handle;/* [unique,range(0,262144)] */
+               uint32_t *bytes_needed;/* [ref,range(0,0x40000)] */
+               uint32_t *service_returned;/* [ref,range(0,0x40000)] */
+               uint32_t *resume_handle;/* [unique,range(0,0x40000)] */
                WERROR result;
        } out;