2012-11-30 15:27:00 +04:00
/*
Unix SMB / CIFS implementation .
sid utility functions
Copyright ( C ) Michael Adam 2012
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 3 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 , see < http : //www.gnu.org/licenses/>.
*/
# include "includes.h"
# include "lib/util_sid_passdb.h"
2016-12-27 15:52:00 +03:00
# include "lib/util_unixsids.h"
2012-11-30 15:27:00 +04:00
# include "passdb/machine_sid.h"
2013-06-18 12:39:10 +04:00
# include "passdb.h"
2012-11-30 15:27:00 +04:00
2012-12-03 04:40:37 +04:00
/**
* check whether this is an object - sid that should
* be treated by the passdb , e . g . for id - mapping .
*/
bool sid_check_object_is_for_passdb ( const struct dom_sid * sid )
{
2013-06-18 12:39:10 +04:00
if ( sid_check_is_in_our_sam ( sid ) & & pdb_is_responsible_for_our_sam ( ) ) {
2012-12-03 04:40:37 +04:00
return true ;
}
2013-06-18 12:39:10 +04:00
if ( sid_check_is_in_builtin ( sid ) & & pdb_is_responsible_for_builtin ( ) ) {
2012-12-03 04:40:37 +04:00
return true ;
}
2013-06-18 12:39:10 +04:00
if ( sid_check_is_in_wellknown_domain ( sid ) & &
pdb_is_responsible_for_wellknown ( ) )
{
2012-12-03 04:40:37 +04:00
return true ;
}
2013-06-18 12:39:10 +04:00
if ( sid_check_is_in_unix_users ( sid ) & &
pdb_is_responsible_for_unix_users ( ) )
{
2012-12-03 04:40:37 +04:00
return true ;
}
2013-06-18 12:39:10 +04:00
if ( sid_check_is_in_unix_groups ( sid ) & &
pdb_is_responsible_for_unix_groups ( ) )
{
2012-12-03 04:40:37 +04:00
return true ;
}
2014-03-28 06:36:22 +04:00
if ( pdb_is_responsible_for_everything_else ( ) )
{
return true ;
}
2012-12-03 04:40:37 +04:00
return false ;
}
2015-01-19 10:14:44 +03:00
2012-11-30 15:27:00 +04:00
/**
* check whether this is an object - or domain - sid that should
* be treated by the passdb , e . g . for id - mapping .
*/
bool sid_check_is_for_passdb ( const struct dom_sid * sid )
{
2013-06-18 12:39:10 +04:00
if ( sid_check_is_our_sam ( sid ) & & pdb_is_responsible_for_our_sam ( ) ) {
2012-11-30 15:27:00 +04:00
return true ;
}
2013-06-18 12:39:10 +04:00
if ( sid_check_is_in_our_sam ( sid ) & & pdb_is_responsible_for_our_sam ( ) ) {
2012-11-30 15:27:00 +04:00
return true ;
}
2013-06-18 12:39:10 +04:00
if ( sid_check_is_builtin ( sid ) & & pdb_is_responsible_for_builtin ( ) ) {
2012-11-30 15:27:00 +04:00
return true ;
}
2013-06-18 12:39:10 +04:00
if ( sid_check_is_in_builtin ( sid ) & & pdb_is_responsible_for_builtin ( ) ) {
2012-11-30 15:27:00 +04:00
return true ;
}
2013-06-18 12:39:10 +04:00
if ( sid_check_is_wellknown_domain ( sid , NULL ) & &
pdb_is_responsible_for_wellknown ( ) )
{
2012-11-30 15:27:00 +04:00
return true ;
}
2013-06-18 12:39:10 +04:00
if ( sid_check_is_in_wellknown_domain ( sid ) & &
pdb_is_responsible_for_wellknown ( ) )
{
2012-11-30 15:27:00 +04:00
return true ;
}
2013-06-18 12:39:10 +04:00
if ( sid_check_is_unix_users ( sid ) & &
pdb_is_responsible_for_unix_users ( ) )
{
2012-11-30 15:27:00 +04:00
return true ;
}
2013-06-18 12:39:10 +04:00
if ( sid_check_is_in_unix_users ( sid ) & &
pdb_is_responsible_for_unix_users ( ) )
{
2012-11-30 15:27:00 +04:00
return true ;
}
2013-06-18 12:39:10 +04:00
if ( sid_check_is_unix_groups ( sid ) & &
pdb_is_responsible_for_unix_groups ( ) )
{
2012-11-30 15:27:00 +04:00
return true ;
}
2013-06-18 12:39:10 +04:00
if ( sid_check_is_in_unix_groups ( sid ) & &
pdb_is_responsible_for_unix_groups ( ) )
{
2012-11-30 15:27:00 +04:00
return true ;
}
2014-03-28 06:36:22 +04:00
if ( pdb_is_responsible_for_everything_else ( ) )
{
return true ;
}
2012-11-30 15:27:00 +04:00
return false ;
}