diff options
author | Sumit Bose <sbose@redhat.com> | 2009-09-17 11:11:54 +0200 |
---|---|---|
committer | Simo Sorce <ssorce@redhat.com> | 2009-11-07 13:15:53 -0500 |
commit | 6922197ba66b8d8806d95179312821901f7de085 (patch) | |
tree | 7ccc194e90cf208cb6ac9e17c455a9931dd785e2 /server/providers/ipa/ipa_access.h | |
parent | 2baa90f92dce1cb5b71c7a0b7b8e2ed93f704e77 (diff) | |
download | sssd-6922197ba66b8d8806d95179312821901f7de085.tar.gz sssd-6922197ba66b8d8806d95179312821901f7de085.tar.bz2 sssd-6922197ba66b8d8806d95179312821901f7de085.zip |
added access module of IPA provider
Diffstat (limited to 'server/providers/ipa/ipa_access.h')
-rw-r--r-- | server/providers/ipa/ipa_access.h | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/server/providers/ipa/ipa_access.h b/server/providers/ipa/ipa_access.h new file mode 100644 index 00000000..e4903cb7 --- /dev/null +++ b/server/providers/ipa/ipa_access.h @@ -0,0 +1,55 @@ +/* + SSSD + + IPA Backend Module -- Access control + + Authors: + Sumit Bose <sbose@redhat.com> + + Copyright (C) 2009 Red Hat + + 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/>. +*/ + +#ifndef _IPA_ACCESS_H_ +#define _IPA_ACCESS_H_ + +#include "providers/ldap/ldap_common.h" + +enum ipa_access_mode { + IPA_ACCESS_DENY = 0, + IPA_ACCESS_ALLOW +}; + +struct ipa_access_ctx { + struct sdap_id_ctx *sdap_ctx; + struct dp_option *ipa_options; +}; + +struct hbac_ctx { + struct sdap_id_ctx *sdap_ctx; + struct dp_option *ipa_options; + struct be_req *be_req; + struct pam_data *pd; + struct hbac_host_info **hbac_host_info; + struct sysdb_attrs **hbac_rule_list; + size_t hbac_rule_count; + const char *user_dn; + size_t groups_count; + const char **groups; +}; + +void ipa_access_handler(struct be_req *be_req); + +#endif /* _IPA_ACCESS_H_ */ |