1998-03-12 00:11:04 +03:00
/*
2002-01-30 09:08:46 +03:00
Unix SMB / CIFS implementation .
1998-03-12 00:11:04 +03:00
SMB parameters and setup
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 .
*/
2000-07-18 09:16:30 +04:00
# include "ntdomain.h"
# include "rpc_dce.h"
1998-03-12 00:11:04 +03:00
# ifndef _RPC_MISC_H /* _RPC_MISC_H */
# define _RPC_MISC_H
/* well-known RIDs - Relative IDs */
/* RIDs - Well-known users ... */
# define DOMAIN_USER_RID_ADMIN (0x000001F4L)
# define DOMAIN_USER_RID_GUEST (0x000001F5L)
2002-03-19 16:57:53 +03:00
# define DOMAIN_USER_RID_KRBTGT (0x000001F6L)
1998-03-12 00:11:04 +03:00
/* RIDs - well-known groups ... */
# define DOMAIN_GROUP_RID_ADMINS (0x00000200L)
# define DOMAIN_GROUP_RID_USERS (0x00000201L)
# define DOMAIN_GROUP_RID_GUESTS (0x00000202L)
2002-03-19 16:57:53 +03:00
# 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)
*/
1998-03-12 00:11:04 +03:00
/* RIDs - well-known aliases ... */
1998-06-09 06:26:26 +04:00
# 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)
1999-12-13 16:27:58 +03:00
1998-06-09 06:26:26 +04:00
# 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)
1999-12-13 16:27:58 +03:00
1998-06-09 06:26:26 +04:00
# define BUILTIN_ALIAS_RID_REPLICATOR (0x00000228L)
2002-03-19 16:57:53 +03:00
# define BUILTIN_ALIAS_RID_RAS_SERVERS (0x00000229L)
1998-03-12 00:11:04 +03:00
1998-06-01 22:50:27 +04:00
/*
* Masks for mappings between unix uid and gid types and
* NT RIDS .
*/
2002-03-19 16:57:53 +03:00
# define BASE_RID (0x000003E8L)
1999-12-13 16:27:58 +03:00
/* Take the bottom bit. */
# define RID_TYPE_MASK 1
# define RID_MULTIPLIER 2
1999-04-08 09:35:53 +04:00
1999-12-13 16:27:58 +03:00
/* The two common types. */
# define USER_RID_TYPE 0
# define GROUP_RID_TYPE 1
1999-04-08 09:35:53 +04:00
1998-03-12 00:11:04 +03:00
/* ENUM_HND */
typedef struct enum_hnd_info
{
uint32 ptr_hnd ; /* pointer to enumeration handle */
uint32 handle ; /* enumeration handle */
} ENUM_HND ;
/* LOOKUP_LEVEL - switch value */
typedef struct lookup_level_info
{
uint16 value ;
} LOOKUP_LEVEL ;
/* 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
{
uint16 str_str_len ;
1998-11-10 22:05:00 +03:00
uint16 str_max_len ;
1998-03-12 00:11:04 +03:00
uint32 buffer ; /* non-zero */
} STRHDR ;
/* UNIHDR - unicode string header */
typedef struct unihdr_info
{
uint16 uni_str_len ;
1998-11-10 22:05:00 +03:00
uint16 uni_max_len ;
1998-03-12 00:11:04 +03:00
uint32 buffer ; /* usually has a value of 4 */
} UNIHDR ;
/* UNIHDR2 - unicode string header and undocumented buffer */
typedef struct unihdr2_info
{
UNIHDR unihdr ;
uint32 buffer ; /* 32 bit buffer pointer */
} UNIHDR2 ;
/* clueless as to what maximum length should be */
# define MAX_UNISTRLEN 256
# define MAX_STRINGLEN 256
1998-11-10 22:05:00 +03:00
# define MAX_BUFFERLEN 512
1998-03-12 00:11:04 +03:00
/* UNISTR - unicode string size and buffer */
typedef struct unistr_info
{
1999-12-13 16:27:58 +03:00
/* unicode characters. ***MUST*** be little-endian. ***MUST*** be null-terminated */
2000-07-27 04:47:19 +04:00
uint16 * buffer ;
1998-03-12 00:11:04 +03:00
} UNISTR ;
1998-11-10 22:05:00 +03:00
/* BUFHDR - buffer header */
typedef struct bufhdr_info
{
uint32 buf_max_len ;
uint32 buf_len ;
} BUFHDR ;
/* BUFFER2 - unicode string, size (in uint8 ascii chars) and buffer */
1998-03-12 00:11:04 +03:00
/* pathetic. some stupid team of \PIPE\winreg writers got the concept */
/* of a unicode string different from the other \PIPE\ writers */
1998-11-10 22:05:00 +03:00
typedef struct buffer2_info
1998-03-12 00:11:04 +03:00
{
1998-11-10 22:05:00 +03:00
uint32 buf_max_len ;
1998-03-12 00:11:04 +03:00
uint32 undoc ;
1998-11-10 22:05:00 +03:00
uint32 buf_len ;
1999-12-13 16:27:58 +03:00
/* unicode characters. ***MUST*** be little-endian. **NOT** necessarily null-terminated */
2000-07-27 04:47:19 +04:00
uint16 * buffer ;
1998-03-12 00:11:04 +03:00
1998-11-10 22:05:00 +03:00
} BUFFER2 ;
/* BUFFER3 */
typedef struct buffer3_info
{
uint32 buf_max_len ;
2000-07-27 04:47:19 +04:00
uint8 * buffer ; /* Data */
1998-11-10 22:05:00 +03:00
uint32 buf_len ;
} BUFFER3 ;
1998-03-12 00:11:04 +03:00
2000-02-07 19:27:03 +03:00
/* BUFFER5 */
typedef struct buffer5_info
{
uint32 buf_len ;
uint16 * buffer ; /* data */
} BUFFER5 ;
1998-03-12 00:11:04 +03:00
/* UNISTR2 - unicode string size (in uint16 unicode chars) and buffer */
typedef struct unistr2_info
{
uint32 uni_max_len ;
uint32 undoc ;
uint32 uni_str_len ;
2000-08-04 16:42:19 +04:00
/* unicode characters. ***MUST*** be little-endian.
* * must * * be null - terminated and the uni_str_len should include
the NULL character */
2000-07-27 04:47:19 +04:00
uint16 * buffer ;
1998-03-12 00:11:04 +03:00
} UNISTR2 ;
/* STRING2 - string size (in uint8 chars) and buffer */
typedef struct string2_info
{
uint32 str_max_len ;
uint32 undoc ;
uint32 str_str_len ;
2000-07-27 04:47:19 +04:00
uint8 * buffer ; /* uint8 characters. **NOT** necessarily null-terminated */
1998-03-12 00:11:04 +03:00
} STRING2 ;
1998-11-10 22:05:00 +03:00
/* UNISTR3 - XXXX not sure about this structure */
typedef struct unistr3_info
{
uint32 uni_str_len ;
UNISTR str ;
} UNISTR3 ;
2003-01-15 20:22:48 +03:00
/* an element in a unicode string array */
typedef struct
{
uint16 length ;
uint16 size ;
uint32 ref_id ;
UNISTR2 string ;
} UNISTR_ARRAY_EL ;
/* an array of unicode strings */
typedef struct
{
uint32 ref_id ;
uint32 count ;
UNISTR_ARRAY_EL * strings ;
} UNISTR_ARRAY ;
1998-03-12 00:11:04 +03:00
/* DOM_RID2 - domain RID structure for ntlsa pipe */
typedef struct domrid2_info
{
1998-11-25 22:57:04 +03:00
uint8 type ; /* value is SID_NAME_USE enum */
uint32 rid ;
uint32 rid_idx ; /* referenced domain index */
1998-03-12 00:11:04 +03:00
} DOM_RID2 ;
/* DOM_RID3 - domain RID structure for samr pipe */
typedef struct domrid3_info
{
1998-11-25 22:57:04 +03:00
uint32 rid ; /* domain-relative (to a SID) id */
uint32 type1 ; /* value is 0x1 */
uint32 ptr_type ; /* undocumented pointer */
uint32 type2 ; /* value is 0x1 */
1998-12-02 04:13:02 +03:00
uint32 unk ; /* value is 0x2 */
1998-03-12 00:11:04 +03:00
} DOM_RID3 ;
1999-12-13 16:27:58 +03:00
/* DOM_RID4 - rid + user attributes */
typedef struct domrid4_info
{
uint32 unknown ;
uint16 attr ;
uint32 rid ; /* user RID */
} DOM_RID4 ;
1998-03-12 00:11:04 +03:00
/* DOM_CLNT_SRV - client / server names */
typedef struct clnt_srv_info
{
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 */
} DOM_CLNT_SRV ;
/* DOM_LOG_INFO - login info */
typedef struct log_info
{
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 */
} DOM_LOG_INFO ;
2001-03-12 01:26:28 +03:00
/* DOM_CHAL - challenge info */
typedef struct chal_info
{
uchar data [ 8 ] ; /* credentials */
} DOM_CHAL ;
/* DOM_CREDs - timestamped client or server credentials */
typedef struct cred_info
{
DOM_CHAL challenge ; /* credentials */
UTIME timestamp ; /* credential time-stamp */
} DOM_CRED ;
1998-03-12 00:11:04 +03:00
/* DOM_CLNT_INFO - client info */
typedef struct clnt_info
{
DOM_LOG_INFO login ;
DOM_CRED cred ;
} DOM_CLNT_INFO ;
/* DOM_CLNT_INFO2 - client info */
typedef struct clnt_info2
{
DOM_CLNT_SRV login ;
uint32 ptr_cred ;
DOM_CRED cred ;
} DOM_CLNT_INFO2 ;
/* DOM_LOGON_ID - logon id */
typedef struct logon_info
{
uint32 low ;
uint32 high ;
} DOM_LOGON_ID ;
1998-03-24 03:37:53 +03:00
/* OWF INFO */
typedef struct owf_info
1998-03-12 00:11:04 +03:00
{
uint8 data [ 16 ] ;
1998-03-24 03:37:53 +03:00
} OWF_INFO ;
1998-03-12 00:11:04 +03:00
/* DOM_GID - group id + user attributes */
typedef struct gid_info
{
uint32 g_rid ; /* a group RID */
uint32 attr ;
} DOM_GID ;
/* POLICY_HND */
typedef struct lsa_policy_info
{
2001-03-08 02:59:13 +03:00
uint32 data1 ;
uint32 data2 ;
uint16 data3 ;
uint16 data4 ;
uint8 data5 [ 8 ] ;
2002-04-04 10:55:32 +04:00
# 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
1998-03-12 00:11:04 +03:00
} POLICY_HND ;
2000-07-18 09:16:30 +04:00
/*
* 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 ;
2000-05-12 18:28:46 +04:00
typedef struct uint64_s
{
uint32 low ;
uint32 high ;
} UINT64_S ;
2001-08-28 10:43:43 +04:00
/* BUFHDR2 - another buffer header, with info level */
typedef struct bufhdr2_info
{
uint32 info_level ;
uint32 length ; /* uint8 chars */
uint32 buffer ;
}
BUFHDR2 ;
/* BUFFER4 - simple length and buffer */
typedef struct buffer4_info
{
uint32 buf_len ;
uint8 buffer [ MAX_BUFFERLEN ] ;
}
BUFFER4 ;
2000-11-14 02:03:34 +03:00
1998-03-12 00:11:04 +03:00
# endif /* _RPC_MISC_H */