summaryrefslogtreecommitdiffstats
path: root/source3/include/ntdomain.h
diff options
context:
space:
mode:
Diffstat (limited to 'source3/include/ntdomain.h')
-rw-r--r--source3/include/ntdomain.h214
1 files changed, 67 insertions, 147 deletions
diff --git a/source3/include/ntdomain.h b/source3/include/ntdomain.h
index 096e7cd66ca..d066ef3e36f 100644
--- a/source3/include/ntdomain.h
+++ b/source3/include/ntdomain.h
@@ -40,70 +40,37 @@
#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
* in the NTDOM branch - it didn't belong there.
*/
-typedef struct
+typedef struct _prs_struct
{
- struct mem_buf *data; /* memory buffer */
- 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 */
-
+ /*
+ * If the (incoming) data is big-endian. On output we are
+ * always little-endian.
+ */
+ BOOL bigendian_data;
+ uint8 align; /* data alignment */
+ BOOL is_dynamic; /* Do we own this memory or not ? */
+ uint32 data_offset; /* Current working offset into data. */
+ uint32 buffer_size; /* Current size of the buffer. */
+ char *data_p; /* The buffer itself. */
} prs_struct;
-typedef struct rpcsrv_struct
-{
- 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_FAULT hdr_fault;
- RPC_HDR_AUTH auth_info;
- RPC_HDR_AUTHA autha_info;
-
- 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];
+/*
+ * Defines for io member of prs_struct.
+ */
- /* 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;
+#define MARSHALL 0
+#define UNMARSHALL 1
-} rpcsrv_struct;
+#define MARSHALLING(ps) (!(ps)->io)
+#define UNMARSHALLING(ps) ((ps)->io)
typedef struct pipes_struct
{
@@ -117,120 +84,73 @@ typedef struct pipes_struct
fstring name;
fstring pipe_srv_name;
- /* remote, server-side rpc redirection */
- struct msrpc_state *m;
+ RPC_HDR hdr; /* Incoming RPC header. */
+ RPC_HDR_REQ hdr_req; /* Incoming request header. */
+
+ uint32 ntlmssp_chal_flags; /* Client challenge flags. */
+ BOOL ntlmssp_auth_requested; /* If the client wanted authenticated rpc. */
+ BOOL ntlmssp_auth_validated; /* If the client *got* authenticated rpc. */
+ unsigned char challenge[8];
+ unsigned char ntlmssp_hash[258];
+ uint32 ntlmssp_seq_num;
+
+ /*
+ * Windows user info.
+ */
+ fstring user_name;
+ fstring domain;
+ fstring wks;
+
+ /*
+ * Unix user name and credentials.
+ */
+ fstring unix_user_name;
+ uid_t uid;
+ gid_t gid;
+
+ /*
+ * Raw RPC output data. This does not include RPC headers or footers.
+ */
+ prs_struct rdata;
+
+ /* The amount of data sent from the current rdata struct. */
+ uint32 data_sent_length;
- /* local, server-side rpc state processing */
- rpcsrv_struct *l;
+ /*
+ * The current PDU being returned. This inclues
+ * headers, data and authentication footer.
+ */
+ unsigned char current_pdu[MAX_PDU_FRAG_LEN];
- /* to store pdus being constructed / communicated from smb to msrpc */
- prs_struct smb_pdu;
- prs_struct rsmb_pdu;
+ /* The amount of data in the current_pdu buffer. */
+ uint32 current_pdu_len;
- /* state-based info used in processing smbs to/from msrpc pdus */
- uint32 file_offset;
- uint32 prev_pdu_file_offset;
- uint32 hdr_offsets;
+ /* The amount of data sent from the current PDU. */
+ uint32 current_pdu_sent;
+ /* When replying to an SMBtrans, this is the maximum amount of
+ data that can be sent in the initial reply. */
+ int max_trans_reply;
} pipes_struct;
struct api_struct
{
char *name;
uint8 opnum;
- void (*fn) (rpcsrv_struct*, prs_struct*, prs_struct*);
+ BOOL (*fn) (uint16 vuid, prs_struct*, prs_struct*);
};
-struct mem_desc
-{
- /* array memory offsets */
- uint32 start;
- uint32 end;
-};
-
-struct mem_buf
+typedef struct
{
- BOOL dynamic; /* True iff data has been dynamically allocated
- (and therefore can be freed) */
- char *data;
- uint32 data_size;
- uint32 data_used;
-
- uint32 margin; /* safety margin when reallocing. */
- /* this can be abused quite nicely */
- uint8 align; /* alignment of data structures (smb, dce/rpc, udp etc) */
+ uint32 rid;
+ char *name;
- struct mem_desc offset;
-
- struct mem_buf *next;
-};
+} rid_name;
struct acct_info
{
fstring acct_name; /* account name */
- fstring acct_desc; /* account description */
- uint32 rid; /* domain-relative RID */
+ uint32 smb_userid; /* 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 */
-