From fecdf48aaf514e6cda5cd0412d7407319a3ff89f Mon Sep 17 00:00:00 2001 From: Michael Adam Date: Fri, 30 Nov 2012 12:27:00 +0100 Subject: [PATCH] s3:lib: add utility function sid_check_is_for_passdb() This function checks whether the given sid should be treated by passdb (e.g. for id mapping). Signed-off-by: Michael Adam Reviewed-by: Stefan Metzmacher --- source3/lib/util_sid_passdb.c | 72 +++++++++++++++++++++++++++++++++++++++++++ source3/lib/util_sid_passdb.h | 30 ++++++++++++++++++ 2 files changed, 102 insertions(+) create mode 100644 source3/lib/util_sid_passdb.c create mode 100644 source3/lib/util_sid_passdb.h diff --git a/source3/lib/util_sid_passdb.c b/source3/lib/util_sid_passdb.c new file mode 100644 index 00000000000..4378d0fc1ed --- /dev/null +++ b/source3/lib/util_sid_passdb.c @@ -0,0 +1,72 @@ +/* + 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 . + */ + +#include "includes.h" +#include "lib/util_sid_passdb.h" +#include "passdb/machine_sid.h" + +/** + * 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) +{ + if (sid_check_is_our_sam(sid)) { + return true; + } + + if (sid_check_is_in_our_sam(sid)) { + return true; + } + + if (sid_check_is_builtin(sid)) { + return true; + } + + if (sid_check_is_in_builtin(sid)) { + return true; + } + + if (sid_check_is_wellknown_domain(sid, NULL)) { + return true; + } + + if (sid_check_is_in_wellknown_domain(sid)) { + return true; + } + + if (sid_check_is_unix_users(sid)) { + return true; + } + + if (sid_check_is_in_unix_users(sid)) { + return true; + } + + if (sid_check_is_unix_groups(sid)) { + return true; + } + + if (sid_check_is_in_unix_groups(sid)) { + return true; + } + + return false; +} diff --git a/source3/lib/util_sid_passdb.h b/source3/lib/util_sid_passdb.h new file mode 100644 index 00000000000..bd62e9e4977 --- /dev/null +++ b/source3/lib/util_sid_passdb.h @@ -0,0 +1,30 @@ +/* + 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 . + */ + +#ifndef __LIB_UTIL_SID_PASSDB_H__ +#define __LIB_UTIL_SID_PASSDB_H__ + +/** + * 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); + +#endif /* __LIB_UTIL_SID_PASSDB_H__ */ -- 2.11.4.GIT