0001-01-01 02:30:17 +02:30
/*
0001-01-01 02:30:17 +02:30
Unix SMB / CIFS implementation .
2005-03-24 02:26:33 +03:00
2005-04-06 07:08:25 +04:00
Copyright ( C ) Andrew Tridgell 1992 - 1997
Copyright ( C ) Luke Kenneth Casson Leighton 1996 - 1997
Copyright ( C ) Paul Ashton 1997
Copyright ( C ) Gerald ( Jerry ) Carter 2005
0001-01-01 02:30:17 +02:30
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation ; either version 2 of the License , or
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
You should have received a copy of the GNU General Public License
along with this program ; if not , write to the Free Software
Foundation , Inc . , 675 Mass Ave , Cambridge , MA 0213 9 , USA .
*/
0001-01-01 02:30:17 +02:30
# include "ntdomain.h"
# include "rpc_dce.h"
0001-01-01 02:30:17 +02:30
# ifndef _RPC_MISC_H /* _RPC_MISC_H */
# define _RPC_MISC_H
0001-01-01 02:30:17 +02:30
# define SMB_RPC_INTERFACE_VERSION 1
2005-03-24 02:26:33 +03:00
# define PRS_POINTER_CAST BOOL (*)(const char*, prs_struct*, int, void*)
2005-04-06 07:08:25 +04:00
enum unistr2_term_codes { UNI_FLAGS_NONE = 0 , UNI_STR_TERMINATE = 1 , UNI_MAXLEN_TERMINATE = 2 , UNI_BROKEN_NON_NULL = 3 } ;
2005-03-24 02:26:33 +03:00
2005-04-06 07:08:25 +04:00
/**********************************************************************
* well - known RIDs - Relative IDs
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
0001-01-01 02:30:17 +02:30
/* RIDs - Well-known users ... */
# define DOMAIN_USER_RID_ADMIN (0x000001F4L)
# define DOMAIN_USER_RID_GUEST (0x000001F5L)
0001-01-01 02:30:17 +02:30
# define DOMAIN_USER_RID_KRBTGT (0x000001F6L)
0001-01-01 02:30:17 +02:30
/* RIDs - well-known groups ... */
# define DOMAIN_GROUP_RID_ADMINS (0x00000200L)
# define DOMAIN_GROUP_RID_USERS (0x00000201L)
# define DOMAIN_GROUP_RID_GUESTS (0x00000202L)
0001-01-01 02:30:17 +02:30
# define DOMAIN_GROUP_RID_COMPUTERS (0x00000203L)
# define DOMAIN_GROUP_RID_CONTROLLERS (0x00000204L)
# define DOMAIN_GROUP_RID_CERT_ADMINS (0x00000205L)
# define DOMAIN_GROUP_RID_SCHEMA_ADMINS (0x00000206L)
# define DOMAIN_GROUP_RID_ENTERPRISE_ADMINS (0x00000207L)
/* is the following the right number? I bet it is --simo
# define DOMAIN_GROUP_RID_POLICY_ADMINS (0x00000208L)
*/
0001-01-01 02:30:17 +02:30
/* RIDs - well-known aliases ... */
0001-01-01 02:30:17 +02:30
# define BUILTIN_ALIAS_RID_ADMINS (0x00000220L)
# define BUILTIN_ALIAS_RID_USERS (0x00000221L)
# define BUILTIN_ALIAS_RID_GUESTS (0x00000222L)
# define BUILTIN_ALIAS_RID_POWER_USERS (0x00000223L)
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
# define BUILTIN_ALIAS_RID_ACCOUNT_OPS (0x00000224L)
# define BUILTIN_ALIAS_RID_SYSTEM_OPS (0x00000225L)
# define BUILTIN_ALIAS_RID_PRINT_OPS (0x00000226L)
# define BUILTIN_ALIAS_RID_BACKUP_OPS (0x00000227L)
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
# define BUILTIN_ALIAS_RID_REPLICATOR (0x00000228L)
0001-01-01 02:30:17 +02:30
# define BUILTIN_ALIAS_RID_RAS_SERVERS (0x00000229L)
0001-01-01 02:30:17 +02:30
# define BUILTIN_ALIAS_RID_PRE_2K_ACCESS (0x0000022aL)
0001-01-01 02:30:17 +02:30
2005-04-06 07:08:25 +04:00
/**********************************************************************
0001-01-01 02:30:17 +02:30
* Masks for mappings between unix uid and gid types and
* NT RIDS .
2005-04-06 07:08:25 +04:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
0001-01-01 02:30:17 +02:30
# define BASE_RID (0x000003E8L)
0001-01-01 02:30:17 +02:30
/* Take the bottom bit. */
2005-04-06 07:08:25 +04:00
# define RID_TYPE_MASK 1
# define RID_MULTIPLIER 2
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
/* The two common types. */
2005-04-06 07:08:25 +04:00
# define USER_RID_TYPE 0
# define GROUP_RID_TYPE 1
0001-01-01 02:30:17 +02:30
2005-04-06 07:08:25 +04:00
/**********************************************************************
* RPC policy handle used pretty much everywhere
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
typedef struct {
0001-01-01 02:30:17 +02:30
uint32 ptr_hnd ; /* pointer to enumeration handle */
uint32 handle ; /* enumeration handle */
} ENUM_HND ;
2005-04-06 07:08:25 +04:00
/**********************************************************************
* RPC policy handle used pretty much everywhere
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
0001-01-01 02:30:17 +02:30
2005-04-06 07:08:25 +04:00
typedef struct {
uint32 data1 ;
uint32 data2 ;
uint16 data3 ;
uint16 data4 ;
uint8 data5 [ 8 ] ;
# ifdef __INSURE__
0001-01-01 02:30:17 +02:30
2005-04-06 07:08:25 +04:00
/* To prevent the leakage of policy handles mallocate a bit of
memory when a policy handle is created and free it when the
handle is closed . This should cause Insure to flag an error
when policy handles are overwritten or fall out of scope without
being freed . */
0001-01-01 02:30:17 +02:30
2005-04-06 07:08:25 +04:00
char * marker ;
# endif
} POLICY_HND ;
/**********************************************************************
* Buffer Headers - - use by SEC_DESC_BUF in winreg and netlogon code
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
typedef struct {
0001-01-01 02:30:17 +02:30
uint32 buf_max_len ;
uint32 buf_len ;
0001-01-01 02:30:17 +02:30
} BUFHDR ;
2005-04-06 07:08:25 +04:00
typedef struct {
uint32 info_level ;
uint32 length ; /* uint8 chars */
uint32 buffer ;
} BUFHDR2 ;
typedef struct {
uint32 size ;
uint32 buffer ;
} BUFHDR4 ;
/**********************************************************************
* Buffers use by winreg
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-03-24 02:26:33 +03:00
/*
OLD COMMENT :
BUFFER2 - unicode string , size ( in uint8 ascii chars ) and buffer
pathetic . some stupid team of \ PIPE \ winreg writers got the concept
of a unicode string different from the other \ PIPE \ writers
NEW COMMENT :
buffer used by \ winreg \ calls to fill in arbitrary REG_XXX values .
It * may * look like a UNISTR2 but it is * not * . This is not a goof
by the winreg developers . It is a generic buffer
*/
typedef struct {
0001-01-01 02:30:17 +02:30
uint32 buf_max_len ;
0001-01-01 02:30:17 +02:30
uint32 offset ;
0001-01-01 02:30:17 +02:30
uint32 buf_len ;
uint16 * buffer ;
2005-03-24 02:26:33 +03:00
} REGVAL_BUFFER ;
0001-01-01 02:30:17 +02:30
2005-04-06 07:08:25 +04:00
typedef struct buffer3_info {
0001-01-01 02:30:17 +02:30
uint32 buf_max_len ;
2005-04-06 07:08:25 +04:00
uint8 * buffer ; /* Data */
0001-01-01 02:30:17 +02:30
uint32 buf_len ;
0001-01-01 02:30:17 +02:30
} BUFFER3 ;
0001-01-01 02:30:17 +02:30
2005-04-06 07:08:25 +04:00
/**********************************************************************
* Buffers use by spoolss
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
typedef struct {
0001-01-01 02:30:17 +02:30
uint32 buf_len ;
uint16 * buffer ; /* data */
0001-01-01 02:30:17 +02:30
} BUFFER5 ;
2005-04-06 07:08:25 +04:00
/**********************************************************************
* Buffers use by netlogon
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
typedef struct {
uint32 buf_len ;
uint8 * buffer ;
} BUFFER4 ;
/**********************************************************************
* Unicode and basic string headers
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
typedef struct {
uint16 str_str_len ;
uint16 str_max_len ;
uint32 buffer ; /* non-zero */
} STRHDR ;
typedef struct {
uint16 uni_str_len ;
uint16 uni_max_len ;
uint32 buffer ;
} UNIHDR ;
/**********************************************************************
* UNICODE string variations
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
typedef struct { /* UNISTR - unicode string size and buffer */
uint16 * buffer ; /* unicode characters. ***MUST*** be
little - endian . * * * MUST * * * be null - terminated */
} UNISTR ;
typedef struct { /* UNISTR2 - unicode string size (in
uint16 unicode chars ) and buffer */
0001-01-01 02:30:17 +02:30
uint32 uni_max_len ;
0001-01-01 02:30:17 +02:30
uint32 offset ;
0001-01-01 02:30:17 +02:30
uint32 uni_str_len ;
2005-04-06 07:08:25 +04:00
uint16 * buffer ; /* unicode characters. ***MUST*** be little-endian.
* * must * * be null - terminated and the uni_str_len
should include the NULL character */
0001-01-01 02:30:17 +02:30
} UNISTR2 ;
2005-04-06 07:08:25 +04:00
typedef struct { /* UNISTR3 - XXXX not sure about this structure */
0001-01-01 02:30:17 +02:30
uint32 uni_str_len ;
UNISTR str ;
} UNISTR3 ;
2005-04-07 02:27:55 +04:00
typedef struct { /* Buffer wrapped around a UNISTR2 */
2005-04-06 07:08:25 +04:00
uint16 length ; /* number of bytes not counting NULL terminatation */
uint16 size ; /* number of bytes including NULL terminatation */
2005-03-26 09:52:56 +03:00
UNISTR2 * string ;
} UNISTR4 ;
typedef struct {
0001-01-01 02:30:17 +02:30
uint32 count ;
2005-03-26 09:52:56 +03:00
UNISTR4 * strings ;
} UNISTR4_ARRAY ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
2005-04-06 07:08:25 +04:00
/**********************************************************************
* String variations
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
typedef struct { /* STRING2 - string size (in uint8 chars) and buffer */
uint32 str_max_len ;
uint32 offset ;
uint32 str_str_len ;
uint8 * buffer ; /* uint8 characters. **NOT** necessarily null-terminated */
} STRING2 ;
0001-01-01 02:30:17 +02:30
2005-04-06 07:08:25 +04:00
/**********************************************************************
* Domain SID structures
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
typedef struct {
uint32 num_auths ; /* length, bytes, including length of len :-) */
DOM_SID sid ;
} DOM_SID2 ;
/**********************************************************************
* Domain SID structures
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
/* DOM_RID2 - domain RID structure for ntlsa pipe */
2005-04-06 07:08:25 +04:00
typedef struct {
0001-01-01 02:30:17 +02:30
uint8 type ; /* value is SID_NAME_USE enum */
uint32 rid ;
uint32 rid_idx ; /* referenced domain index */
0001-01-01 02:30:17 +02:30
} DOM_RID2 ;
2005-04-06 07:08:25 +04:00
typedef struct { /* DOM_RID3 - domain RID structure for samr pipe */
0001-01-01 02:30:17 +02:30
uint32 rid ; /* domain-relative (to a SID) id */
uint32 type1 ; /* value is 0x1 */
uint32 ptr_type ; /* undocumented pointer */
uint32 type2 ; /* value is 0x1 */
0001-01-01 02:30:17 +02:30
uint32 unk ; /* value is 0x2 */
0001-01-01 02:30:17 +02:30
} DOM_RID3 ;
0001-01-01 02:30:17 +02:30
/* DOM_RID4 - rid + user attributes */
typedef struct domrid4_info
{
0001-01-01 02:30:17 +02:30
uint32 unknown ;
uint16 attr ;
uint32 rid ; /* user RID */
0001-01-01 02:30:17 +02:30
} DOM_RID4 ;
2005-04-06 07:08:25 +04:00
/* DOM_GID - group id + user attributes */
typedef struct {
uint32 g_rid ; /* a group RID */
uint32 attr ;
} DOM_GID ;
/**********************************************************************
* ? ? ? ?
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
0001-01-01 02:30:17 +02:30
/* DOM_CLNT_SRV - client / server names */
typedef struct clnt_srv_info
{
0001-01-01 02:30:17 +02:30
uint32 undoc_buffer ; /* undocumented 32 bit buffer pointer */
UNISTR2 uni_logon_srv ; /* logon server name */
uint32 undoc_buffer2 ; /* undocumented 32 bit buffer pointer */
UNISTR2 uni_comp_name ; /* client machine name */
0001-01-01 02:30:17 +02:30
} DOM_CLNT_SRV ;
/* DOM_LOG_INFO - login info */
typedef struct log_info
{
0001-01-01 02:30:17 +02:30
uint32 undoc_buffer ; /* undocumented 32 bit buffer pointer */
UNISTR2 uni_logon_srv ; /* logon server name */
UNISTR2 uni_acct_name ; /* account name */
uint16 sec_chan ; /* secure channel type */
UNISTR2 uni_comp_name ; /* client machine name */
0001-01-01 02:30:17 +02:30
} DOM_LOG_INFO ;
0001-01-01 02:30:17 +02:30
/* DOM_CHAL - challenge info */
typedef struct chal_info
{
0001-01-01 02:30:17 +02:30
uchar data [ 8 ] ; /* credentials */
0001-01-01 02:30:17 +02:30
} DOM_CHAL ;
/* DOM_CREDs - timestamped client or server credentials */
typedef struct cred_info
{
0001-01-01 02:30:17 +02:30
DOM_CHAL challenge ; /* credentials */
UTIME timestamp ; /* credential time-stamp */
0001-01-01 02:30:17 +02:30
} DOM_CRED ;
0001-01-01 02:30:17 +02:30
/* DOM_CLNT_INFO - client info */
typedef struct clnt_info
{
0001-01-01 02:30:17 +02:30
DOM_LOG_INFO login ;
DOM_CRED cred ;
0001-01-01 02:30:17 +02:30
} DOM_CLNT_INFO ;
/* DOM_CLNT_INFO2 - client info */
typedef struct clnt_info2
{
0001-01-01 02:30:17 +02:30
DOM_CLNT_SRV login ;
uint32 ptr_cred ;
DOM_CRED cred ;
0001-01-01 02:30:17 +02:30
} DOM_CLNT_INFO2 ;
/* DOM_LOGON_ID - logon id */
typedef struct logon_info
{
0001-01-01 02:30:17 +02:30
uint32 low ;
uint32 high ;
0001-01-01 02:30:17 +02:30
} DOM_LOGON_ID ;
0001-01-01 02:30:17 +02:30
/* OWF INFO */
typedef struct owf_info
0001-01-01 02:30:17 +02:30
{
0001-01-01 02:30:17 +02:30
uint8 data [ 16 ] ;
0001-01-01 02:30:17 +02:30
} OWF_INFO ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
/*
* A client connection ' s state , pipe name ,
* user credentials , etc . . .
*/
typedef struct _cli_auth_fns cli_auth_fns ;
struct user_creds ;
struct cli_connection {
char * srv_name ;
char * pipe_name ;
struct user_creds usr_creds ;
struct cli_state * pCli_state ;
cli_auth_fns * auth ;
void * auth_info ;
void * auth_creds ;
} ;
/*
* Associate a POLICY_HND with a cli_connection
*/
typedef struct rpc_hnd_node {
POLICY_HND hnd ;
struct cli_connection * cli ;
} RPC_HND_NODE ;
0001-01-01 02:30:17 +02:30
typedef struct uint64_s
{
uint32 low ;
uint32 high ;
} UINT64_S ;
0001-01-01 02:30:17 +02:30
2004-12-20 15:52:33 +03:00
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
# endif /* _RPC_MISC_H */