mirror of
https://github.com/samba-team/samba.git
synced 2024-12-27 03:21:53 +03:00
d3b9384308
but a flags field. We were assuming that 2*strlen(mb_string) == length of ucs2-le string.
This is not the case. Count it after conversion.
Jeremy.
(This used to be commit f82c273a42
)
408 lines
9.4 KiB
C
408 lines
9.4 KiB
C
/*
|
|
Unix SMB/CIFS implementation.
|
|
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 02139, USA.
|
|
*/
|
|
|
|
#include "ntdomain.h"
|
|
#include "rpc_dce.h"
|
|
|
|
#ifndef _RPC_MISC_H /* _RPC_MISC_H */
|
|
#define _RPC_MISC_H
|
|
|
|
#define SMB_RPC_INTERFACE_VERSION 1
|
|
|
|
/* well-known RIDs - Relative IDs */
|
|
|
|
/* RIDs - Well-known users ... */
|
|
#define DOMAIN_USER_RID_ADMIN (0x000001F4L)
|
|
#define DOMAIN_USER_RID_GUEST (0x000001F5L)
|
|
#define DOMAIN_USER_RID_KRBTGT (0x000001F6L)
|
|
|
|
/* RIDs - well-known groups ... */
|
|
#define DOMAIN_GROUP_RID_ADMINS (0x00000200L)
|
|
#define DOMAIN_GROUP_RID_USERS (0x00000201L)
|
|
#define DOMAIN_GROUP_RID_GUESTS (0x00000202L)
|
|
#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)
|
|
*/
|
|
|
|
/* RIDs - well-known aliases ... */
|
|
#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)
|
|
|
|
#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)
|
|
|
|
#define BUILTIN_ALIAS_RID_REPLICATOR (0x00000228L)
|
|
#define BUILTIN_ALIAS_RID_RAS_SERVERS (0x00000229L)
|
|
|
|
/*
|
|
* Masks for mappings between unix uid and gid types and
|
|
* NT RIDS.
|
|
*/
|
|
|
|
|
|
#define BASE_RID (0x000003E8L)
|
|
|
|
/* Take the bottom bit. */
|
|
#define RID_TYPE_MASK 1
|
|
#define RID_MULTIPLIER 2
|
|
|
|
/* The two common types. */
|
|
#define USER_RID_TYPE 0
|
|
#define GROUP_RID_TYPE 1
|
|
|
|
/* 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;
|
|
uint16 str_max_len;
|
|
uint32 buffer; /* non-zero */
|
|
} STRHDR;
|
|
|
|
/* UNIHDR - unicode string header */
|
|
typedef struct unihdr_info
|
|
{
|
|
uint16 uni_str_len;
|
|
uint16 uni_max_len;
|
|
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
|
|
#define MAX_BUFFERLEN 512
|
|
|
|
/* UNISTR - unicode string size and buffer */
|
|
typedef struct unistr_info
|
|
{
|
|
/* unicode characters. ***MUST*** be little-endian. ***MUST*** be null-terminated */
|
|
uint16 *buffer;
|
|
} UNISTR;
|
|
|
|
/* 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 */
|
|
/* pathetic. some stupid team of \PIPE\winreg writers got the concept */
|
|
/* of a unicode string different from the other \PIPE\ writers */
|
|
typedef struct buffer2_info
|
|
{
|
|
uint32 buf_max_len;
|
|
uint32 offset;
|
|
uint32 buf_len;
|
|
/* unicode characters. ***MUST*** be little-endian. **NOT** necessarily null-terminated */
|
|
uint16 *buffer;
|
|
} BUFFER2;
|
|
|
|
/* BUFFER3 */
|
|
typedef struct buffer3_info
|
|
{
|
|
uint32 buf_max_len;
|
|
uint8 *buffer; /* Data */
|
|
uint32 buf_len;
|
|
} BUFFER3;
|
|
|
|
/* BUFFER5 */
|
|
typedef struct buffer5_info
|
|
{
|
|
uint32 buf_len;
|
|
uint16 *buffer; /* data */
|
|
} BUFFER5;
|
|
|
|
/* UNISTR2 - unicode string size (in uint16 unicode chars) and buffer */
|
|
typedef struct unistr2_info
|
|
{
|
|
uint32 uni_max_len;
|
|
uint32 offset;
|
|
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;
|
|
} UNISTR2;
|
|
|
|
/* STRING2 - string size (in uint8 chars) and buffer */
|
|
typedef struct string2_info
|
|
{
|
|
uint32 str_max_len;
|
|
uint32 offset;
|
|
uint32 str_str_len;
|
|
uint8 *buffer; /* uint8 characters. **NOT** necessarily null-terminated */
|
|
} STRING2;
|
|
|
|
/* UNISTR3 - XXXX not sure about this structure */
|
|
typedef struct unistr3_info
|
|
{
|
|
uint32 uni_str_len;
|
|
UNISTR str;
|
|
|
|
} UNISTR3;
|
|
|
|
/* an element in a unicode string array */
|
|
typedef struct
|
|
{
|
|
uint16 length;
|
|
uint16 size;
|
|
uint32 ref_id;
|
|
UNISTR2 string;
|
|
} UNISTR2_ARRAY_EL;
|
|
|
|
/* an array of unicode strings */
|
|
typedef struct
|
|
{
|
|
uint32 ref_id;
|
|
uint32 count;
|
|
UNISTR2_ARRAY_EL *strings;
|
|
} UNISTR2_ARRAY;
|
|
|
|
|
|
/* 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;
|
|
|
|
/* DOM_RID2 - domain RID structure for ntlsa pipe */
|
|
typedef struct domrid2_info
|
|
{
|
|
uint8 type; /* value is SID_NAME_USE enum */
|
|
uint32 rid;
|
|
uint32 rid_idx; /* referenced domain index */
|
|
|
|
} DOM_RID2;
|
|
|
|
/* DOM_RID3 - domain RID structure for samr pipe */
|
|
typedef struct domrid3_info
|
|
{
|
|
uint32 rid; /* domain-relative (to a SID) id */
|
|
uint32 type1; /* value is 0x1 */
|
|
uint32 ptr_type; /* undocumented pointer */
|
|
uint32 type2; /* value is 0x1 */
|
|
uint32 unk; /* value is 0x2 */
|
|
|
|
} DOM_RID3;
|
|
|
|
/* DOM_RID4 - rid + user attributes */
|
|
typedef struct domrid4_info
|
|
{
|
|
uint32 unknown;
|
|
uint16 attr;
|
|
uint32 rid; /* user RID */
|
|
} DOM_RID4;
|
|
|
|
/* 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;
|
|
|
|
/* 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;
|
|
|
|
/* 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;
|
|
|
|
/* OWF INFO */
|
|
typedef struct owf_info
|
|
{
|
|
uint8 data[16];
|
|
} OWF_INFO;
|
|
|
|
|
|
/* 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
|
|
{
|
|
uint32 data1;
|
|
uint32 data2;
|
|
uint16 data3;
|
|
uint16 data4;
|
|
uint8 data5[8];
|
|
#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
|
|
} POLICY_HND;
|
|
|
|
/*
|
|
* 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;
|
|
|
|
typedef struct uint64_s
|
|
{
|
|
uint32 low;
|
|
uint32 high;
|
|
} UINT64_S;
|
|
|
|
/* 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;
|
|
|
|
enum unistr2_term_codes { UNI_FLAGS_NONE = 0, UNI_STR_TERMINATE = 1, UNI_MAXLEN_TERMINATE = 2 };
|
|
#endif /* _RPC_MISC_H */
|