delineation between smb and msrpc more marked. smbd now constructs
[tprouty/samba.git] / source / include / ntdomain.h
index 07d32519bf68ab6119f5f5bd4120a9ceb3920565..096e7cd66cab28bef1fd2986aea35d6472f19874 100644 (file)
 /* miscellaneous structures / defines */
 #include "rpc_misc.h"
 
+/* security descriptor structures */
+#include "rpc_secdes.h" 
+
 /* different dce/rpc pipes */
 #include "rpc_lsa.h"
 #include "rpc_netlogon.h"
 #include "rpc_reg.h"
 #include "rpc_samr.h"
 #include "rpc_srvsvc.h"
+#include "rpc_svcctl.h"
 #include "rpc_wkssvc.h"
+#include "rpc_brs.h"
+#include "rpc_atsvc.h"
+#include "rpc_spoolss.h"
+#include "rpc_eventlog.h"
 
 /* 
  * A bunch of stuff that was put into smb.h
@@ -50,51 +58,79 @@ typedef struct
        uint32 offset; /* offset currently being accessed in memory buffer */
        uint8 align; /* data alignment */
        BOOL io; /* parsing in or out of data stream */
+       BOOL error; /* error occurred */
 
 } prs_struct;
 
-typedef struct pipes_struct
+typedef struct rpcsrv_struct
 {
-       struct pipes_struct *next, *prev;
-       int pnum;
-       connection_struct *conn;
-       uint16 vuid;
-       BOOL open; /* open connection */
-       uint16 device_state;
-       uint16 priority;
-       fstring name;
-       fstring pipe_srv_name;
-
        prs_struct rhdr; /* output header */
+       prs_struct rfault; /* fault */
        prs_struct rdata; /* output data */
+       prs_struct rdata_i; /* output data (intermediate, for fragments) */
        prs_struct rauth; /* output authentication verifier */
        prs_struct rverf; /* output verifier */
        prs_struct rntlm; /* output ntlmssp */
 
-       RPC_HDR     hdr;
-       RPC_HDR_BA  hdr_ba;
-       RPC_HDR_RB  hdr_rb;
-       RPC_HDR_REQ  hdr_req;
-       RPC_HDR_RESP hdr_resp;
+       RPC_HDR       hdr;
+       RPC_HDR_BA    hdr_ba;
+       RPC_HDR_RB    hdr_rb;
+       RPC_HDR_REQ   hdr_req;
+       RPC_HDR_RESP  hdr_resp;
+       RPC_HDR_FAULT hdr_fault;
        RPC_HDR_AUTH  auth_info;
        RPC_HDR_AUTHA autha_info;
 
-       RPC_AUTH_VERIFIER     auth_verifier;
-       RPC_AUTH_NTLMSSP_NEG  ntlmssp_neg;
-       RPC_AUTH_NTLMSSP_CHAL ntlmssp_chal;
-       RPC_AUTH_NTLMSSP_RESP ntlmssp_resp;
+       RPC_AUTH_NTLMSSP_VERIFIER auth_verifier;
+       RPC_AUTH_NTLMSSP_NEG      ntlmssp_neg;
+       RPC_AUTH_NTLMSSP_CHAL     ntlmssp_chal;
+       RPC_AUTH_NTLMSSP_RESP     ntlmssp_resp;
+       RPC_AUTH_NTLMSSP_CHK      ntlmssp_chk;
 
        BOOL ntlmssp_auth;
        BOOL ntlmssp_validated;
        unsigned char ntlmssp_hash[258];
+       uint32 ntlmssp_seq_num;
        fstring user_name;
        fstring domain;
        fstring wks;
 
+       uchar user_sess_key[16];
+
+       /* per-user authentication info.  hmm, this not appropriate, but
+          it will do for now.  dcinfo contains NETLOGON-specific info,
+          so have to think of a better method.
+        */
+       struct dcinfo dc;
+
+} rpcsrv_struct;
+
+typedef struct pipes_struct
+{
+       struct pipes_struct *next, *prev;
+       int pnum;
+       connection_struct *conn;
+       uint16 vuid;
+       BOOL open; /* open connection */
+       uint16 device_state;
+       uint16 priority;
+       fstring name;
+       fstring pipe_srv_name;
+
+       /* remote, server-side rpc redirection */
+       struct msrpc_state *m;
+
+       /* local, server-side rpc state processing */
+       rpcsrv_struct *l;
+
+       /* to store pdus being constructed / communicated from smb to msrpc */
+       prs_struct smb_pdu;
+       prs_struct rsmb_pdu;
+
+       /* state-based info used in processing smbs to/from msrpc pdus */ 
        uint32 file_offset;
+       uint32 prev_pdu_file_offset;
        uint32 hdr_offsets;
-       uint32 frag_len_left;
-       uint32 next_frag_start;
 
 } pipes_struct;
 
@@ -102,7 +138,7 @@ struct api_struct
 {  
   char *name;
   uint8 opnum;
-  void (*fn) (uint16 vuid, prs_struct*, prs_struct*);
+  void (*fn) (rpcsrv_struct*, prs_struct*, prs_struct*);
 };
 
 struct mem_desc
@@ -129,18 +165,72 @@ struct mem_buf
        struct mem_buf *next;
 };
 
-typedef struct
-{  
-       uint32 rid;
-       char *name;
-
-} rid_name;
-
 struct acct_info
 {
     fstring acct_name; /* account name */
-    uint32 smb_userid; /* domain-relative RID */
+    fstring acct_desc; /* account description */
+    uint32  rid; /* domain-relative RID */
 };
 
+/*
+ * higher order functions for use with msrpc client code
+ */
+
+#define ALIAS_FN(fn)\
+       void (*fn)(const char*, const DOM_SID*, uint32, const char*)
+#define ALIAS_INFO_FN(fn)\
+       void (*fn)(const char*, const DOM_SID*, uint32, ALIAS_INFO_CTR *const)
+#define ALIAS_MEM_FN(fn)\
+       void(*fn)(const char*, const DOM_SID*, uint32, const char*,\
+                 uint32, DOM_SID *const *const, char *const *const,\
+                 uint8*const)
+
+#define GROUP_FN(fn)\
+       void (*fn)(const char*, const DOM_SID*, uint32, const char*)
+#define GROUP_INFO_FN(fn)\
+       void (*fn)(const char*, const DOM_SID*, uint32, GROUP_INFO_CTR *const)
+#define GROUP_MEM_FN(fn)\
+       void(*fn)(const char*, const DOM_SID*, uint32, const char*,\
+                 uint32, const uint32*, char *const *const,\
+                 uint32*const)
+
+#define DOMAIN_FN(fn)\
+       void (*fn)(const char*)
+#define DOMAIN_INFO_FN(fn)\
+       void (*fn)(const char*, const DOM_SID *, uint32, SAM_UNK_CTR *)
+
+#define USER_FN(fn)\
+       void (*fn)(const char*, const DOM_SID*, uint32, const char*)
+#define USER_INFO_FN(fn)\
+       void (*fn)(const char*, const DOM_SID*, uint32,\
+                  SAM_USER_INFO_21 *const)
+#define USER_MEM_FN(fn)\
+       void (*fn)(const char*, const DOM_SID*, uint32, const char*,\
+                  uint32, const uint32*, char *const *const, uint32* const)
+
+#define DISP_FN(fn)\
+       void (*fn)(const char*, const DOM_SID*, uint16, uint32, \
+                  SAM_DISPINFO_CTR *)
+
+#define REG_FN(fn)\
+       void (*fn)(int, const char *, int)
+#define REG_KEY_FN(fn)\
+       void (*fn)(const char*, const char*, time_t)
+#define REG_VAL_FN(fn)\
+       void (*fn)(const char *, const char*, uint32, const BUFFER2 *)
+
+#define SVC_QUERY_FN(fn)\
+       void (*fn)(const QUERY_SERVICE_CONFIG *)
+#define SVC_INFO_FN(fn)\
+       void (*fn)(const ENUM_SRVC_STATUS *)
+
+#define TPRT_INFO_FN(fn)\
+       void (*fn)(const SRV_TPRT_INFO_CTR *)
+
+#define PRINT_INFO_FN(fn)\
+       void (*fn)(const char*, uint32, uint32, void  *const *const)
+#define JOB_INFO_FN(fn)\
+       void (*fn)(const char*, const char*, uint32, uint32, void *const *const)
+
 #endif /* _NT_DOMAIN_H */