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
0001-01-01 02:30:17 +02:30
Copyright ( C ) Andrew Tridgell 1992 - 1997
Copyright ( C ) Luke Kenneth Casson Leighton 1996 - 1997
Copyright ( C ) Paul Ashton 1997
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
0001-01-01 02:30:17 +02:30
2005-03-24 02:26:33 +03:00
# define PRS_POINTER_CAST BOOL (*)(const char*, prs_struct*, int, void*)
0001-01-01 02:30:17 +02:30
/* well-known RIDs - Relative IDs */
/* 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
0001-01-01 02:30:17 +02:30
/*
* Masks for mappings between unix uid and gid types and
* NT RIDS .
*/
0001-01-01 02:30:17 +02:30
# define BASE_RID (0x000003E8L)
0001-01-01 02:30:17 +02:30
/* Take the bottom bit. */
# 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. */
# define USER_RID_TYPE 0
# define GROUP_RID_TYPE 1
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
/* ENUM_HND */
typedef struct enum_hnd_info
{
uint32 ptr_hnd ; /* pointer to enumeration handle */
uint32 handle ; /* enumeration handle */
} ENUM_HND ;
/* DOM_SID2 - security id */
typedef struct sid_info_2
{
uint32 num_auths ; /* length, bytes, including length of len :-) */
DOM_SID sid ;
} DOM_SID2 ;
/* STRHDR - string header */
typedef struct header_info
{
0001-01-01 02:30:17 +02:30
uint16 str_str_len ;
uint16 str_max_len ;
uint32 buffer ; /* non-zero */
0001-01-01 02:30:17 +02:30
} STRHDR ;
/* UNIHDR - unicode string header */
typedef struct unihdr_info
{
0001-01-01 02:30:17 +02:30
uint16 uni_str_len ;
uint16 uni_max_len ;
uint32 buffer ; /* usually has a value of 4 */
0001-01-01 02:30:17 +02:30
} UNIHDR ;
/* UNIHDR2 - unicode string header and undocumented buffer */
typedef struct unihdr2_info
{
0001-01-01 02:30:17 +02:30
UNIHDR unihdr ;
uint32 buffer ; /* 32 bit buffer pointer */
0001-01-01 02:30:17 +02:30
} UNIHDR2 ;
/* UNISTR - unicode string size and buffer */
typedef struct unistr_info
{
0001-01-01 02:30:17 +02:30
/* unicode characters. ***MUST*** be little-endian. ***MUST*** be null-terminated */
uint16 * buffer ;
0001-01-01 02:30:17 +02:30
} UNISTR ;
0001-01-01 02:30:17 +02:30
/* BUFHDR - buffer header */
typedef struct bufhdr_info
{
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-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 ;
/* unicode characters. ***MUST*** be little-endian. **NOT** necessarily null-terminated */
uint16 * buffer ;
2005-03-24 02:26:33 +03:00
} REGVAL_BUFFER ;
0001-01-01 02:30:17 +02:30
/* BUFFER3 */
typedef struct buffer3_info
{
0001-01-01 02:30:17 +02:30
uint32 buf_max_len ;
uint8 * buffer ; /* Data */
uint32 buf_len ;
0001-01-01 02:30:17 +02:30
} BUFFER3 ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
/* BUFFER5 */
typedef struct buffer5_info
{
0001-01-01 02:30:17 +02:30
uint32 buf_len ;
uint16 * buffer ; /* data */
0001-01-01 02:30:17 +02:30
} BUFFER5 ;
0001-01-01 02:30:17 +02:30
/* UNISTR2 - unicode string size (in uint16 unicode chars) and buffer */
typedef struct unistr2_info
{
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 ;
/* unicode characters. ***MUST*** be little-endian.
* * must * * be null - terminated and the uni_str_len should include
the NULL character */
uint16 * buffer ;
0001-01-01 02:30:17 +02:30
} UNISTR2 ;
2005-03-24 02:26:33 +03:00
/* UNIHDR + UNISTR2* */
typedef struct {
uint16 length ; /* number of bytes not counting NULL terminatation */
uint16 size ; /* number of bytes including NULL terminatation */
UNISTR2 * string ;
} UNISTR4 ;
0001-01-01 02:30:17 +02:30
/* STRING2 - string size (in uint8 chars) and buffer */
typedef struct string2_info
{
0001-01-01 02:30:17 +02:30
uint32 str_max_len ;
0001-01-01 02:30:17 +02:30
uint32 offset ;
0001-01-01 02:30:17 +02:30
uint32 str_str_len ;
uint8 * buffer ; /* uint8 characters. **NOT** necessarily null-terminated */
0001-01-01 02:30:17 +02:30
} STRING2 ;
0001-01-01 02:30:17 +02:30
/* UNISTR3 - XXXX not sure about this structure */
typedef struct unistr3_info
{
uint32 uni_str_len ;
UNISTR str ;
} UNISTR3 ;
0001-01-01 02:30:17 +02:30
/* an element in a unicode string array */
typedef struct
{
uint16 length ;
uint16 size ;
uint32 ref_id ;
UNISTR2 string ;
0001-01-01 02:30:17 +02:30
} UNISTR2_ARRAY_EL ;
0001-01-01 02:30:17 +02:30
/* an array of unicode strings */
typedef struct
{
uint32 ref_id ;
uint32 count ;
0001-01-01 02:30:17 +02:30
UNISTR2_ARRAY_EL * strings ;
} UNISTR2_ARRAY ;
0001-01-01 02:30:17 +02:30
0001-01-01 02:30:17 +02:30
/* an element in a sid array */
typedef struct
{
uint32 ref_id ;
DOM_SID2 sid ;
} SID_ARRAY_EL ;
/* an array of sids */
typedef struct
{
uint32 ref_id ;
uint32 count ;
SID_ARRAY_EL * sids ;
} SID_ARRAY ;
0001-01-01 02:30:17 +02:30
/* DOM_RID2 - domain RID structure for ntlsa pipe */
typedef struct domrid2_info
{
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 ;
/* DOM_RID3 - domain RID structure for samr pipe */
typedef struct domrid3_info
{
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 ;
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
/* DOM_GID - group id + user attributes */
typedef struct gid_info
{
0001-01-01 02:30:17 +02:30
uint32 g_rid ; /* a group RID */
uint32 attr ;
0001-01-01 02:30:17 +02:30
} DOM_GID ;
/* POLICY_HND */
typedef struct lsa_policy_info
{
0001-01-01 02:30:17 +02:30
uint32 data1 ;
uint32 data2 ;
uint16 data3 ;
uint16 data4 ;
uint8 data5 [ 8 ] ;
0001-01-01 02:30:17 +02:30
# ifdef __INSURE__
/* 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 . */
char * marker ;
# endif
0001-01-01 02:30:17 +02:30
} POLICY_HND ;
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
/* BUFHDR2 - another buffer header, with info level */
typedef struct bufhdr2_info
{
uint32 info_level ;
uint32 length ; /* uint8 chars */
uint32 buffer ;
}
BUFHDR2 ;
2004-12-20 15:52:33 +03:00
/* BUFHDR4 - another buffer header */
typedef struct bufhdr4_info
{
uint32 size ;
uint32 buffer ;
}
BUFHDR4 ;
0001-01-01 02:30:17 +02:30
/* BUFFER4 - simple length and buffer */
typedef struct buffer4_info
{
uint32 buf_len ;
2005-01-08 03:51:12 +03:00
uint8 * buffer ;
0001-01-01 02:30:17 +02:30
}
BUFFER4 ;
0001-01-01 02:30:17 +02:30
enum unistr2_term_codes { UNI_FLAGS_NONE = 0 , UNI_STR_TERMINATE = 1 , UNI_MAXLEN_TERMINATE = 2 , UNI_BROKEN_NON_NULL = 3 } ;
0001-01-01 02:30:17 +02:30
# endif /* _RPC_MISC_H */