diff options
Diffstat (limited to 'source3/include/ntdomain.h')
-rw-r--r-- | source3/include/ntdomain.h | 214 |
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 */ - |