2006-02-04 01:19:41 +03:00
/*
Unix SMB / CIFS implementation .
Translate unix - defined names to SIDs and vice versa
Copyright ( C ) Volker Lendecke 2005
2009-10-04 18:52:08 +04:00
2006-02-04 01:19:41 +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
2006-02-04 01:19:41 +03:00
( at your option ) any later version .
2009-10-04 18:52:08 +04:00
2006-02-04 01:19:41 +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 .
2009-10-04 18:52:08 +04:00
2006-02-04 01:19:41 +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/>.
2006-02-04 01:19:41 +03:00
*/
# include "includes.h"
2010-08-26 17:48:50 +04:00
# include "../libcli/security/dom_sid.h"
2006-02-04 01:19:41 +03:00
2010-05-21 05:25:01 +04:00
bool sid_check_is_unix_users ( const struct dom_sid * sid )
2006-02-04 01:19:41 +03:00
{
2010-08-26 17:48:50 +04:00
return dom_sid_equal ( sid , & global_sid_Unix_Users ) ;
2006-02-04 01:19:41 +03:00
}
2010-05-21 05:25:01 +04:00
bool sid_check_is_in_unix_users ( const struct dom_sid * sid )
2006-02-04 01:19:41 +03:00
{
2010-05-21 05:25:01 +04:00
struct dom_sid dom_sid ;
2006-02-04 01:19:41 +03:00
uint32 rid ;
sid_copy ( & dom_sid , sid ) ;
sid_split_rid ( & dom_sid , & rid ) ;
2009-10-04 18:52:08 +04:00
2006-02-04 01:19:41 +03:00
return sid_check_is_unix_users ( & dom_sid ) ;
}
2010-07-11 19:30:53 +04:00
void uid_to_unix_users_sid ( uid_t uid , struct dom_sid * sid )
2006-07-07 22:53:19 +04:00
{
2010-07-11 19:30:53 +04:00
/*
* This can never fail , we know that global_sid_Unix_Users is
* short enough for a domain sid .
*/
sid_compose ( sid , & global_sid_Unix_Users , uid ) ;
2006-07-07 22:53:19 +04:00
}
2010-07-11 19:30:53 +04:00
void gid_to_unix_groups_sid ( gid_t gid , struct dom_sid * sid )
2006-08-22 00:04:01 +04:00
{
2010-07-11 19:30:53 +04:00
/*
* This can never fail , we know that global_sid_Unix_Groups is
* short enough for a domain sid .
*/
sid_compose ( sid , & global_sid_Unix_Groups , gid ) ;
2006-08-22 00:04:01 +04:00
}
2006-02-04 01:19:41 +03:00
const char * unix_users_domain_name ( void )
{
return " Unix User " ;
}
2010-05-21 05:25:01 +04:00
bool lookup_unix_user_name ( const char * name , struct dom_sid * sid )
2006-02-04 01:19:41 +03:00
{
struct passwd * pwd ;
2010-01-10 19:39:27 +03:00
bool ret ;
2006-02-04 01:19:41 +03:00
2010-09-26 03:24:16 +04:00
pwd = getpwnam_alloc ( talloc_tos ( ) , name ) ;
2006-02-04 01:19:41 +03:00
if ( pwd = = NULL ) {
return False ;
}
2010-01-10 19:39:27 +03:00
/*
* For 64 - bit uid ' s we have enough space in the whole SID ,
* should they become necessary
*/
ret = sid_compose ( sid , & global_sid_Unix_Users , pwd - > pw_uid ) ;
2006-02-20 20:59:58 +03:00
TALLOC_FREE ( pwd ) ;
2010-01-10 19:39:27 +03:00
return ret ;
2006-02-04 01:19:41 +03:00
}
2010-05-21 05:25:01 +04:00
bool sid_check_is_unix_groups ( const struct dom_sid * sid )
2006-02-04 01:19:41 +03:00
{
2010-08-26 17:48:50 +04:00
return dom_sid_equal ( sid , & global_sid_Unix_Groups ) ;
2006-02-04 01:19:41 +03:00
}
2010-05-21 05:25:01 +04:00
bool sid_check_is_in_unix_groups ( const struct dom_sid * sid )
2006-02-04 01:19:41 +03:00
{
2010-05-21 05:25:01 +04:00
struct dom_sid dom_sid ;
2006-02-04 01:19:41 +03:00
uint32 rid ;
sid_copy ( & dom_sid , sid ) ;
sid_split_rid ( & dom_sid , & rid ) ;
2009-10-04 18:52:08 +04:00
2006-02-04 01:19:41 +03:00
return sid_check_is_unix_groups ( & dom_sid ) ;
}
const char * unix_groups_domain_name ( void )
{
return " Unix Group " ;
}
2010-05-21 05:25:01 +04:00
bool lookup_unix_group_name ( const char * name , struct dom_sid * sid )
2006-02-04 01:19:41 +03:00
{
struct group * grp ;
2008-07-24 22:56:49 +04:00
grp = sys_getgrnam ( name ) ;
2006-02-04 01:19:41 +03:00
if ( grp = = NULL ) {
return False ;
}
2010-01-10 19:39:27 +03:00
/*
* For 64 - bit gid ' s we have enough space in the whole SID ,
* should they become necessary
*/
return sid_compose ( sid , & global_sid_Unix_Groups , grp - > gr_gid ) ;
2006-02-04 01:19:41 +03:00
}