2011-03-23 01:20:49 +03:00
/*
2005-12-03 21:34:13 +03:00
Unix SMB / CIFS implementation .
Lookup routines for well - known SIDs
Copyright ( C ) Andrew Tridgell 1992 - 1998
Copyright ( C ) Luke Kenneth Caseson Leighton 1998 - 1999
Copyright ( C ) Jeremy Allison 1999
Copyright ( C ) Volker Lendecke 2005
2011-03-23 01:20:49 +03:00
2005-12-03 21:34:13 +03:00
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
2007-07-09 23:25:36 +04:00
the Free Software Foundation ; either version 3 of the License , or
2005-12-03 21:34:13 +03:00
( at your option ) any later version .
2011-03-23 01:20:49 +03:00
2005-12-03 21:34:13 +03:00
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 .
2011-03-23 01:20:49 +03:00
2005-12-03 21:34:13 +03:00
You should have received a copy of the GNU General Public License
2007-07-10 04:52:41 +04:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2005-12-03 21:34:13 +03:00
*/
# include "includes.h"
2010-10-12 08:27:50 +04:00
# include "../libcli/security/security.h"
2005-12-03 21:34:13 +03:00
struct rid_name_map {
2015-05-10 02:33:10 +03:00
uint32_t rid ;
2005-12-03 21:34:13 +03:00
const char * name ;
} ;
struct sid_name_map_info
{
2010-05-21 05:25:01 +04:00
const struct dom_sid * sid ;
2005-12-03 21:34:13 +03:00
const char * name ;
const struct rid_name_map * known_users ;
} ;
static const struct rid_name_map everyone_users [ ] = {
{ 0 , " Everyone " } ,
{ 0 , NULL } } ;
2011-09-01 18:09:01 +04:00
static const struct rid_name_map local_authority_users [ ] = {
{ 0 , " Local " } ,
{ 1 , " Console Logon " } ,
{ 0 , NULL } } ;
2005-12-03 21:34:13 +03:00
static const struct rid_name_map creator_owner_users [ ] = {
{ 0 , " Creator Owner " } ,
{ 1 , " Creator Group " } ,
2011-08-29 19:40:18 +04:00
{ 2 , " Creator Owner Server " } ,
{ 3 , " Creator Group Server " } ,
{ 4 , " Owner Rights " } ,
2005-12-03 21:34:13 +03:00
{ 0 , NULL } } ;
static const struct rid_name_map nt_authority_users [ ] = {
{ 1 , " Dialup " } ,
{ 2 , " Network " } ,
{ 3 , " Batch " } ,
{ 4 , " Interactive " } ,
{ 6 , " Service " } ,
2009-10-20 17:15:06 +04:00
{ 7 , " Anonymous Logon " } ,
2005-12-03 21:34:13 +03:00
{ 8 , " Proxy " } ,
2011-08-29 19:46:06 +04:00
{ 9 , " Enterprise Domain Controllers " } ,
2005-12-03 21:34:13 +03:00
{ 10 , " Self " } ,
{ 11 , " Authenticated Users " } ,
{ 12 , " Restricted " } ,
{ 13 , " Terminal Server User " } ,
{ 14 , " Remote Interactive Logon " } ,
{ 15 , " This Organization " } ,
2011-08-29 19:42:45 +04:00
{ 17 , " IUSR " } ,
2005-12-03 21:34:13 +03:00
{ 18 , " SYSTEM " } ,
{ 19 , " Local Service " } ,
{ 20 , " Network Service " } ,
{ 0 , NULL } } ;
static struct sid_name_map_info special_domains [ ] = {
{ & global_sid_World_Domain , " " , everyone_users } ,
2011-09-01 18:09:01 +04:00
{ & global_sid_Local_Authority , " " , local_authority_users } ,
2005-12-03 21:34:13 +03:00
{ & global_sid_Creator_Owner_Domain , " " , creator_owner_users } ,
{ & global_sid_NT_Authority , " NT Authority " , nt_authority_users } ,
{ NULL , NULL , NULL } } ;
2010-05-21 05:25:01 +04:00
bool sid_check_is_wellknown_domain ( const struct dom_sid * sid , const char * * name )
2006-02-04 01:19:41 +03:00
{
int i ;
for ( i = 0 ; special_domains [ i ] . sid ! = NULL ; i + + ) {
2010-08-26 17:48:50 +04:00
if ( dom_sid_equal ( sid , special_domains [ i ] . sid ) ) {
2006-02-04 01:19:41 +03:00
if ( name ! = NULL ) {
* name = special_domains [ i ] . name ;
}
return True ;
}
}
return False ;
}
2010-05-21 05:25:01 +04:00
bool sid_check_is_in_wellknown_domain ( const struct dom_sid * sid )
2006-03-02 21:33:43 +03:00
{
2010-05-21 05:25:01 +04:00
struct dom_sid dom_sid ;
2006-03-02 21:33:43 +03:00
sid_copy ( & dom_sid , sid ) ;
2011-03-10 18:19:17 +03:00
sid_split_rid ( & dom_sid , NULL ) ;
2006-03-02 21:33:43 +03:00
return sid_check_is_wellknown_domain ( & dom_sid , NULL ) ;
}
2005-12-03 21:34:13 +03:00
/**************************************************************************
Looks up a known username from one of the known domains .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2010-05-21 05:25:01 +04:00
bool lookup_wellknown_sid ( TALLOC_CTX * mem_ctx , const struct dom_sid * sid ,
2005-12-10 14:22:01 +03:00
const char * * domain , const char * * name )
2005-12-03 21:34:13 +03:00
{
int i ;
2010-05-21 05:25:01 +04:00
struct dom_sid dom_sid ;
2015-05-10 02:33:10 +03:00
uint32_t rid ;
2005-12-03 21:34:13 +03:00
const struct rid_name_map * users = NULL ;
2018-12-13 23:22:27 +03:00
struct dom_sid_buf buf ;
2005-12-03 21:34:13 +03:00
sid_copy ( & dom_sid , sid ) ;
if ( ! sid_split_rid ( & dom_sid , & rid ) ) {
DEBUG ( 2 , ( " Could not split rid from SID \n " ) ) ;
return False ;
}
for ( i = 0 ; special_domains [ i ] . sid ! = NULL ; i + + ) {
2010-08-26 17:48:50 +04:00
if ( dom_sid_equal ( & dom_sid , special_domains [ i ] . sid ) ) {
2005-12-03 21:34:13 +03:00
* domain = talloc_strdup ( mem_ctx ,
special_domains [ i ] . name ) ;
users = special_domains [ i ] . known_users ;
break ;
}
}
if ( users = = NULL ) {
2018-12-13 23:22:27 +03:00
DEBUG ( 10 , ( " SID %s is no special sid \n " ,
dom_sid_str_buf ( sid , & buf ) ) ) ;
2005-12-03 21:34:13 +03:00
return False ;
}
for ( i = 0 ; users [ i ] . name ! = NULL ; i + + ) {
if ( rid = = users [ i ] . rid ) {
* name = talloc_strdup ( mem_ctx , users [ i ] . name ) ;
return True ;
}
}
2018-12-13 23:22:27 +03:00
DEBUG ( 10 , ( " RID of special SID %s not found \n " ,
dom_sid_str_buf ( sid , & buf ) ) ) ;
2005-12-03 21:34:13 +03:00
return False ;
}
/**************************************************************************
Try and map a name to one of the well known SIDs .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-10-19 04:40:25 +04:00
bool lookup_wellknown_name ( TALLOC_CTX * mem_ctx , const char * name ,
2015-10-15 13:35:26 +03:00
struct dom_sid * sid , const char * * pdomain )
2005-12-03 21:34:13 +03:00
{
int i , j ;
2015-10-15 13:35:26 +03:00
const char * domain = * pdomain ;
2005-12-03 21:34:13 +03:00
2015-10-15 13:35:26 +03:00
DEBUG ( 10 , ( " map_name_to_wellknown_sid: looking up %s \\ %s \n " , domain , name ) ) ;
2005-12-03 21:34:13 +03:00
for ( i = 0 ; special_domains [ i ] . sid ! = NULL ; i + + ) {
const struct rid_name_map * users =
special_domains [ i ] . known_users ;
2015-10-15 13:35:26 +03:00
if ( domain [ 0 ] ! = ' \0 ' ) {
if ( ! strequal ( domain , special_domains [ i ] . name ) ) {
continue ;
}
}
2005-12-03 21:34:13 +03:00
if ( users = = NULL )
continue ;
for ( j = 0 ; users [ j ] . name ! = NULL ; j + + ) {
if ( strequal ( users [ j ] . name , name ) ) {
2010-01-10 19:39:27 +03:00
sid_compose ( sid , special_domains [ i ] . sid ,
users [ j ] . rid ) ;
2015-10-15 13:35:26 +03:00
* pdomain = talloc_strdup (
2005-12-03 21:34:13 +03:00
mem_ctx , special_domains [ i ] . name ) ;
return True ;
}
}
}
return False ;
}