mirror of
https://github.com/samba-team/samba.git
synced 2024-12-28 07:21:54 +03:00
a4276507e4
ipc.c: Caused samba password changing not to be done if UNIX password
changing requested and not successful.
util.c: Added string_to_sid() and sid_to_string() functions.
lib/rpc/client/cli_samr.c:
lib/rpc/include/rpc_misc.h:
lib/rpc/parse/parse_lsa.c:
lib/rpc/parse/parse_misc.c:
lib/rpc/parse/parse_net.c:
lib/rpc/parse/parse_samr.c:
lib/rpc/server/srv_lsa.c:
lib/rpc/server/srv_lsa_hnd.c:
lib/rpc/server/srv_netlog.c:
lib/rpc/server/srv_samr.c:
lib/rpc/server/srv_util.c: Changes so that instead of passing SIDs
around as char *, they are converted to DOM_SID at the earliest
opportunity, and passed around as that. Also added dynamic memory
allocation of group sids. Preparing to auto-generate machine sid.
Jeremy.
(This used to be commit 134d6fa79c
)
277 lines
6.8 KiB
C
277 lines
6.8 KiB
C
/*
|
|
Unix SMB/Netbios implementation.
|
|
Version 1.9.
|
|
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.
|
|
*/
|
|
|
|
#ifndef _RPC_MISC_H /* _RPC_MISC_H */
|
|
#define _RPC_MISC_H
|
|
|
|
|
|
#include "rpc_dce.h"
|
|
|
|
/* pipe string names */
|
|
#define PIPE_SRVSVC "\\PIPE\\srvsvc"
|
|
#define PIPE_SAMR "\\PIPE\\samr"
|
|
#define PIPE_WINREG "\\PIPE\\winreg"
|
|
#define PIPE_WKSSVC "\\PIPE\\wkssvc"
|
|
#define PIPE_NETLOGON "\\PIPE\\NETLOGON"
|
|
#define PIPE_NTLSA "\\PIPE\\ntlsa"
|
|
#define PIPE_NTSVCS "\\PIPE\\ntsvcs"
|
|
#define PIPE_LSASS "\\PIPE\\lsass"
|
|
#define PIPE_LSARPC "\\PIPE\\lsarpc"
|
|
|
|
/* well-known RIDs - Relative IDs */
|
|
|
|
/* RIDs - Well-known users ... */
|
|
#define DOMAIN_USER_RID_ADMIN (0x000001F4L)
|
|
#define DOMAIN_USER_RID_GUEST (0x000001F5L)
|
|
|
|
/* RIDs - well-known groups ... */
|
|
#define DOMAIN_GROUP_RID_ADMINS (0x00000200L)
|
|
#define DOMAIN_GROUP_RID_USERS (0x00000201L)
|
|
#define DOMAIN_GROUP_RID_GUESTS (0x00000202L)
|
|
|
|
/* RIDs - well-known aliases ... */
|
|
#define DOMAIN_ALIAS_RID_ADMINS (0x00000220L)
|
|
#define DOMAIN_ALIAS_RID_USERS (0x00000221L)
|
|
#define DOMAIN_ALIAS_RID_GUESTS (0x00000222L)
|
|
#define DOMAIN_ALIAS_RID_POWER_USERS (0x00000223L)
|
|
|
|
#define DOMAIN_ALIAS_RID_ACCOUNT_OPS (0x00000224L)
|
|
#define DOMAIN_ALIAS_RID_SYSTEM_OPS (0x00000225L)
|
|
#define DOMAIN_ALIAS_RID_PRINT_OPS (0x00000226L)
|
|
#define DOMAIN_ALIAS_RID_BACKUP_OPS (0x00000227L)
|
|
|
|
#define DOMAIN_ALIAS_RID_REPLICATOR (0x00000228L)
|
|
|
|
/* 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;
|
|
|
|
#define MAXSUBAUTHS 15 /* max sub authorities in a SID */
|
|
|
|
/* DOM_SID - security id */
|
|
typedef struct sid_info
|
|
{
|
|
uint8 sid_rev_num; /* SID revision number */
|
|
uint8 num_auths; /* number of sub-authorities */
|
|
uint8 id_auth[6]; /* Identifier Authority */
|
|
/*
|
|
* Note that the values in these uint32's are in *native* byteorder,
|
|
* not neccessarily little-endian...... JRA.
|
|
*/
|
|
uint32 sub_auths[MAXSUBAUTHS]; /* pointer to sub-authorities. */
|
|
|
|
} DOM_SID;
|
|
|
|
/* 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_max_len;
|
|
uint16 str_str_len;
|
|
uint32 buffer; /* non-zero */
|
|
|
|
} STRHDR;
|
|
|
|
/* UNIHDR - unicode string header */
|
|
typedef struct unihdr_info
|
|
{
|
|
uint16 uni_max_len;
|
|
uint16 uni_str_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
|
|
|
|
/* UNISTR - unicode string size and buffer */
|
|
typedef struct unistr_info
|
|
{
|
|
uint16 buffer[MAX_UNISTRLEN]; /* unicode characters. ***MUST*** be null-terminated */
|
|
|
|
} UNISTR;
|
|
|
|
/* UNINOTSTR2 - 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 uninotstr2_info
|
|
{
|
|
uint32 uni_max_len;
|
|
uint32 undoc;
|
|
uint32 uni_buf_len;
|
|
uint16 buffer[MAX_UNISTRLEN]; /* unicode characters. **NOT** necessarily null-terminated */
|
|
|
|
} UNINOTSTR2;
|
|
|
|
/* UNISTR2 - unicode string size (in uint16 unicode chars) and buffer */
|
|
typedef struct unistr2_info
|
|
{
|
|
uint32 uni_max_len;
|
|
uint32 undoc;
|
|
uint32 uni_str_len;
|
|
uint16 buffer[MAX_UNISTRLEN]; /* unicode characters. **NOT** necessarily null-terminated */
|
|
|
|
} UNISTR2;
|
|
|
|
/* STRING2 - string size (in uint8 chars) and buffer */
|
|
typedef struct string2_info
|
|
{
|
|
uint32 str_max_len;
|
|
uint32 undoc;
|
|
uint32 str_str_len;
|
|
uint8 buffer[MAX_STRINGLEN]; /* uint8 characters. **NOT** necessarily null-terminated */
|
|
|
|
} STRING2;
|
|
|
|
|
|
/* DOM_RID2 - domain RID structure for ntlsa pipe */
|
|
typedef struct domrid2_info
|
|
{
|
|
uint32 type; /* value is 5 */
|
|
uint32 undoc; /* value is non-zero */
|
|
uint32 rid;
|
|
uint32 rid_idx; /* don't know what this is */
|
|
|
|
} 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 */
|
|
|
|
} 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_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;
|
|
|
|
#define POL_HND_SIZE 20
|
|
|
|
/* POLICY_HND */
|
|
typedef struct lsa_policy_info
|
|
{
|
|
uint8 data[POL_HND_SIZE]; /* policy handle */
|
|
|
|
} POLICY_HND;
|
|
|
|
#endif /* _RPC_MISC_H */
|
|
|