Removed version number from file header.
[samba.git] / source / include / rpc_srvsvc.h
index 6ba137da2f3e377490181ae4007caee33c2fcfba..10dbc102e00579fb29f5b18c74c9703630d4171f 100644 (file)
@@ -1,6 +1,5 @@
-/* 
-   Unix SMB/Netbios implementation.
-   Version 1.9.
+/*
+   Unix SMB/CIFS implementation.
    SMB parameters and setup
    Copyright (C) Andrew Tridgell 1992-1997
    Copyright (C) Luke Kenneth Casson Leighton 1996-1997
 
 
 /* srvsvc pipe */
-#define SRV_NETCONNENUM      0x08
-#define SRV_NETFILEENUM      0x09
-#define SRV_NETSESSENUM      0x0c
-#define SRV_NETSHAREENUM     0x0f
-#define SRV_NET_SRV_GET_INFO 0x15
-#define SRV_NET_SRV_SET_INFO 0x16
+#define SRV_NETCONNENUM        0x08
+#define SRV_NETFILEENUM        0x09
+#define SRV_NETSESSENUM        0x0c
+#define SRV_NET_SHARE_ADD      0x0e
+#define SRV_NETSHAREENUM_ALL   0x0f
+#define SRV_NET_SHARE_GET_INFO 0x10
+#define SRV_NET_SHARE_SET_INFO 0x11
+#define SRV_NET_SHARE_DEL      0x12
+#define SRV_NET_SRV_GET_INFO   0x15
+#define SRV_NET_SRV_SET_INFO   0x16
+#define SRV_NET_DISK_ENUM      0x17
+#define SRV_NET_REMOTE_TOD     0x1c
+#define SRV_NET_NAME_VALIDATE  0x21
+#define SRV_NETSHAREENUM       0x24
+#define SRV_NETFILEQUERYSECDESC 0x27
+#define SRV_NETFILESETSECDESC  0x28
+
+#define MAX_SERVER_DISK_ENTRIES 15
+
+typedef struct disk_info {
+       uint32  unknown;
+       UNISTR3 disk_name;
+} DISK_INFO;
+
+typedef struct disk_enum_container {
+       uint32 level;
+       uint32 entries_read;
+       uint32 unknown;
+       uint32 disk_info_ptr;
+       DISK_INFO disk_info[MAX_SERVER_DISK_ENTRIES];
+} DISK_ENUM_CONTAINER;
+
+typedef struct net_srv_disk_enum {
+       uint32 ptr_srv_name;         /* pointer (to server name?) */
+       UNISTR2 uni_srv_name;        /* server name */
 
+       DISK_ENUM_CONTAINER disk_enum_ctr;
+
+       uint32 preferred_len;        /* preferred maximum length (0xffff ffff) */
+       uint32 total_entries;        /* total number of entries */
+       ENUM_HND enum_hnd;
+       NTSTATUS status;               /* return status */
+} SRV_Q_NET_DISK_ENUM, SRV_R_NET_DISK_ENUM;
+
+typedef struct net_name_validate {
+       uint32 ptr_srv_name;
+       UNISTR2 uni_srv_name;
+       UNISTR2 uni_name; /*name to validate*/
+       uint32 type;
+       uint32 flags;
+       NTSTATUS status;
+} SRV_Q_NET_NAME_VALIDATE, SRV_R_NET_NAME_VALIDATE;
 
 /* SESS_INFO_0 (pointers to level 0 session info strings) */
 typedef struct ptr_sess_info0
@@ -140,7 +184,7 @@ typedef struct r_net_sess_enum_info
        uint32 total_entries;                    /* total number of entries */
        ENUM_HND enum_hnd;
 
-       uint32 status;               /* return status */
+       NTSTATUS status;               /* return status */
 
 } SRV_R_NET_SESS_ENUM;
 
@@ -243,14 +287,10 @@ typedef struct r_net_conn_enum_info
        uint32 total_entries;                    /* total number of entries */
        ENUM_HND enum_hnd;
 
-       uint32 status;               /* return status */
+       NTSTATUS status;               /* return status */
 
 } SRV_R_NET_CONN_ENUM;
 
-/* oops - this is going to take up a *massive* amount of stack. */
-/* the UNISTR2s already have 1024 uint16 chars in them... */
-#define MAX_SHARE_ENTRIES 128
-
 /* SH_INFO_1 (pointers to level 1 share info strings) */
 typedef struct ptr_share_info1
 {
@@ -271,12 +311,8 @@ typedef struct str_share_info1
 /* SRV_SHARE_INFO_1 */
 typedef struct share_info_1_info
 {
-       uint32 num_entries_read;                     /* EntriesRead */
-       uint32 ptr_share_info;                       /* Buffer */
-       uint32 num_entries_read2;                    /* EntriesRead */
-
-       SH_INFO_1     info_1    [MAX_SHARE_ENTRIES]; /* share entry pointers */
-       SH_INFO_1_STR info_1_str[MAX_SHARE_ENTRIES]; /* share entry strings */
+       SH_INFO_1 info_1;
+       SH_INFO_1_STR info_1_str;
 
 } SRV_SHARE_INFO_1;
 
@@ -307,26 +343,80 @@ typedef struct str_share_info2
 /* SRV_SHARE_INFO_2 */
 typedef struct share_info_2_info
 {
-       uint32 num_entries_read;                     /* EntriesRead */
-       uint32 ptr_share_info;                       /* Buffer */
-       uint32 num_entries_read2;                    /* EntriesRead */
-
-       SH_INFO_2     info_2    [MAX_SHARE_ENTRIES]; /* share entry pointers */
-       SH_INFO_2_STR info_2_str[MAX_SHARE_ENTRIES]; /* share entry strings */
+       SH_INFO_2 info_2;
+       SH_INFO_2_STR info_2_str;
 
 } SRV_SHARE_INFO_2;
 
+/* SH_INFO_502 (pointers to level 502 share info strings) */
+typedef struct ptr_share_info502
+{
+       uint32 ptr_netname; /* pointer to net name. */
+       uint32 type; /* ipc, print, disk ... */
+       uint32 ptr_remark; /* pointer to comment. */
+       uint32 perms;      /* permissions */
+       uint32 max_uses;   /* maximum uses */
+       uint32 num_uses;   /* current uses */
+       uint32 ptr_path;   /* pointer to path name */
+       uint32 ptr_passwd; /* pointer to password */
+       uint32 sd_size;    /* size of security descriptor */
+       uint32 ptr_sd;     /* pointer to security descriptor */
+
+} SH_INFO_502;
+
+/* SH_INFO_502_STR (level 502 share info strings) */
+typedef struct str_share_info502
+{
+       SH_INFO_502 *ptrs;
+
+       UNISTR2 uni_netname; /* unicode string of net name (e.g NETLOGON) */
+       UNISTR2 uni_remark;  /* unicode string of comment (e.g "Logon server share") */
+       UNISTR2 uni_path;    /* unicode string of local path (e.g c:\winnt\system32\repl\import\scripts) */
+       UNISTR2 uni_passwd;  /* unicode string of password - presumably for share level security (e.g NULL) */
+
+       uint32 sd_size;
+       SEC_DESC *sd;
+
+} SH_INFO_502_STR;
+
+/* SRV_SHARE_INFO_502 */
+typedef struct share_info_502_info
+{
+       SH_INFO_502 info_502;
+       SH_INFO_502_STR info_502_str;
+
+} SRV_SHARE_INFO_502;
+
+/* SRV_SHARE_INFO_1005 */
+typedef struct share_info_1005_info
+{
+  uint32 dfs_root_flag; 
+} SRV_SHARE_INFO_1005;
+
+/* SRV_SHARE_INFO_1501 */
+typedef struct share_info_1501_info
+{
+       SEC_DESC_BUF *sdb;
+} SRV_SHARE_INFO_1501;
+
 /* SRV_SHARE_INFO_CTR */
-typedef struct srv_share_info_1_info
+typedef struct srv_share_info_ctr_info
 {
-       uint32 switch_value;         /* switch value */
-       uint32 ptr_share_ctr;       /* pointer to share info union */
-       union
-    {
-               SRV_SHARE_INFO_1 info1; /* share info level 1 */
-               SRV_SHARE_INFO_2 info2; /* share info level 2 */
+       uint32 info_level;
+       uint32 switch_value;
+       uint32 ptr_share_info;
 
-    } share;
+       uint32 num_entries;
+       uint32 ptr_entries;
+       uint32 num_entries2;
+
+       union {
+               SRV_SHARE_INFO_1 *info1; /* share info level 1 */
+               SRV_SHARE_INFO_2 *info2; /* share info level 2 */
+               SRV_SHARE_INFO_502 *info502; /* share info level 502 */
+               void *info;
+
+       } share;
 
 } SRV_SHARE_INFO_CTR;
 
@@ -336,9 +426,7 @@ typedef struct q_net_share_enum_info
        uint32 ptr_srv_name;         /* pointer (to server name?) */
        UNISTR2 uni_srv_name;        /* server name */
 
-       uint32 share_level;          /* share level */
-
-       SRV_SHARE_INFO_CTR *ctr;     /* share info container */
+       SRV_SHARE_INFO_CTR ctr;     /* share info container */
 
        uint32 preferred_len;        /* preferred maximum length (0xffff ffff) */
 
@@ -350,16 +438,110 @@ typedef struct q_net_share_enum_info
 /* SRV_R_NET_SHARE_ENUM */
 typedef struct r_net_share_enum_info
 {
-       uint32 share_level;          /* share level */
-       SRV_SHARE_INFO_CTR *ctr;     /* share info container */
+       SRV_SHARE_INFO_CTR ctr;     /* share info container */
 
        uint32 total_entries;                    /* total number of entries */
        ENUM_HND enum_hnd;
 
-       uint32 status;               /* return status */
+       NTSTATUS status;               /* return status */
 
 } SRV_R_NET_SHARE_ENUM;
 
+
+/* SRV_Q_NET_SHARE_GET_INFO */
+typedef struct q_net_share_get_info_info
+{
+       uint32 ptr_srv_name;
+       UNISTR2 uni_srv_name;
+
+       UNISTR2 uni_share_name;
+       uint32 info_level;
+
+} SRV_Q_NET_SHARE_GET_INFO;
+
+/* JRA. NB. We also need level 1004 and 1006 here. */
+
+/* SRV_SHARE_INFO */
+typedef struct srv_share_info {
+       uint32 switch_value;
+       uint32 ptr_share_ctr;
+
+       union {
+               SRV_SHARE_INFO_1 info1;
+               SRV_SHARE_INFO_2 info2;
+               SRV_SHARE_INFO_502 info502;
+        SRV_SHARE_INFO_1005 info1005;
+        SRV_SHARE_INFO_1501 info1501;
+       } share;
+} SRV_SHARE_INFO;
+
+/* SRV_R_NET_SHARE_GET_INFO */
+typedef struct r_net_share_get_info_info
+{
+       SRV_SHARE_INFO info;
+       NTSTATUS status;
+
+} SRV_R_NET_SHARE_GET_INFO;
+
+/* SRV_Q_NET_SHARE_SET_INFO */
+typedef struct q_net_share_set_info_info
+{
+       uint32 ptr_srv_name;
+       UNISTR2 uni_srv_name;
+
+       UNISTR2 uni_share_name;
+       uint32 info_level;
+
+       SRV_SHARE_INFO info;
+
+} SRV_Q_NET_SHARE_SET_INFO;
+
+/* SRV_R_NET_SHARE_SET_INFO */
+typedef struct r_net_share_set_info
+{
+       uint32 switch_value;         /* switch value */
+
+       NTSTATUS status;               /* return status */
+
+} SRV_R_NET_SHARE_SET_INFO;
+
+/* SRV_Q_NET_SHARE_ADD */
+typedef struct q_net_share_add
+{
+       uint32 ptr_srv_name;
+       UNISTR2 uni_srv_name;
+
+       uint32 info_level;
+
+       SRV_SHARE_INFO info;
+
+} SRV_Q_NET_SHARE_ADD;
+
+/* SRV_R_NET_SHARE_ADD */
+typedef struct r_net_share_add
+{
+       uint32 switch_value;         /* switch value */
+
+       NTSTATUS status;               /* return status */
+
+} SRV_R_NET_SHARE_ADD;
+
+/* SRV_Q_NET_SHARE_DEL */
+typedef struct q_net_share_del
+{
+       uint32 ptr_srv_name;
+       UNISTR2 uni_srv_name;
+       UNISTR2 uni_share_name;
+
+} SRV_Q_NET_SHARE_DEL;
+
+/* SRV_R_NET_SHARE_DEL */
+typedef struct r_net_share_del
+{
+       NTSTATUS status;               /* return status */
+
+} SRV_R_NET_SHARE_DEL;
+
 /* FILE_INFO_3 (level 3 file info strings) */
 typedef struct file_info3_info
 {
@@ -439,10 +621,20 @@ typedef struct r_net_file_enum_info
        uint32 total_entries;                    /* total number of files */
        ENUM_HND enum_hnd;
 
-       uint32 status;        /* return status */
+       NTSTATUS status;        /* return status */
 
 } SRV_R_NET_FILE_ENUM;
 
+/* SRV_INFO_100 */
+typedef struct srv_info_100_info
+{
+       uint32 platform_id;     /* 0x500 */
+       uint32 ptr_name;        /* pointer to server name */
+
+       UNISTR2 uni_name;       /* server name "server" */
+
+} SRV_INFO_100;
+
 /* SRV_INFO_101 */
 typedef struct srv_info_101_info
 {
@@ -491,6 +683,7 @@ typedef struct srv_info_ctr_info
     {
                SRV_INFO_102 sv102; /* server info level 102 */
                SRV_INFO_101 sv101; /* server info level 101 */
+               SRV_INFO_100 sv100; /* server info level 100 */
 
     } srv;
 
@@ -510,7 +703,7 @@ typedef struct r_net_srv_get_info
 {
        SRV_INFO_CTR *ctr;
 
-       uint32 status;               /* return status */
+       NTSTATUS status;               /* return status */
 
 } SRV_R_NET_SRV_GET_INFO;
 
@@ -531,10 +724,88 @@ typedef struct r_net_srv_set_info
 {
        uint32 switch_value;         /* switch value */
 
-       uint32 status;               /* return status */
+       NTSTATUS status;               /* return status */
 
 } SRV_R_NET_SRV_SET_INFO;
 
+/* SRV_Q_NET_REMOTE_TOD */
+typedef struct q_net_remote_tod
+{
+       uint32  ptr_srv_name;
+       UNISTR2 uni_srv_name; /* "\\server" */
+
+} SRV_Q_NET_REMOTE_TOD;
 
-#endif /* _RPC_SRVSVC_H */
+/* TIME_OF_DAY_INFO */
+typedef struct time_of_day_info
+{
+       uint32  elapsedt;
+       uint32  msecs;
+       uint32  hours;
+       uint32  mins;
+       uint32  secs;
+       uint32  hunds;
+       uint32  zone;
+       uint32  tintervals;
+       uint32  day;
+       uint32  month;
+       uint32  year;
+       uint32  weekday;
+       
+} TIME_OF_DAY_INFO;
+
+/* SRV_R_NET_REMOTE_TOD */
+typedef struct r_net_remote_tod
+{
+       uint32 ptr_srv_tod;         /* pointer to TOD */
+       TIME_OF_DAY_INFO *tod;
+       
+       NTSTATUS status;               /* return status */
 
+} SRV_R_NET_REMOTE_TOD;
+
+/* SRV_Q_NET_FILE_QUERY_SECDESC */
+typedef struct q_net_file_query_secdesc
+{
+       uint32  ptr_srv_name;
+       UNISTR2 uni_srv_name;
+       uint32  ptr_qual_name;
+       UNISTR2 uni_qual_name;
+       UNISTR2 uni_file_name;
+       uint32  unknown1;
+       uint32  unknown2;
+       uint32  unknown3;
+} SRV_Q_NET_FILE_QUERY_SECDESC;
+
+/* SRV_R_NET_FILE_QUERY_SECDESC */
+typedef struct r_net_file_query_secdesc
+{
+       uint32 ptr_response;
+       uint32 size_response;
+       uint32 ptr_secdesc;
+       uint32 size_secdesc;
+       SEC_DESC *sec_desc;
+       NTSTATUS status;
+} SRV_R_NET_FILE_QUERY_SECDESC;
+
+/* SRV_Q_NET_FILE_SET_SECDESC */
+typedef struct q_net_file_set_secdesc
+{
+       uint32  ptr_srv_name;
+       UNISTR2 uni_srv_name;
+       uint32  ptr_qual_name;
+       UNISTR2 uni_qual_name;
+       UNISTR2 uni_file_name;
+       uint32  sec_info;
+       uint32  size_set;
+       uint32  ptr_secdesc;
+       uint32  size_secdesc;
+       SEC_DESC *sec_desc;
+} SRV_Q_NET_FILE_SET_SECDESC;
+
+/* SRV_R_NET_FILE_SET_SECDESC */
+typedef struct r_net_file_set_secdesc
+{
+       NTSTATUS status;
+} SRV_R_NET_FILE_SET_SECDESC;
+#endif /* _RPC_SRVSVC_H */