# Authors: # Rob Crittenden # Pavel Zuna # # Copyright (C) 2009 Red Hat # see file 'COPYING' for use and warranty information # # 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; version 2 only # # 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, write to the Free Software # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA """ Taskgroups """ from ipalib import api from ipalib.plugins.basegroup import * _container_dn = api.env.container_taskgroup _default_attributes = ['cn', 'description', 'member', 'memberOf'] class taskgroup(basegroup): """ Taskgroup object. """ container = _container_dn api.register(taskgroup) class taskgroup_add(basegroup_add): """ Create new taskgroup. """ api.register(taskgroup_add) class taskgroup_del(basegroup_del): """ Delete taskgroup. """ container = _container_dn api.register(taskgroup_del) class taskgroup_mod(basegroup_mod): """ Edit taskgroup. """ container = _container_dn api.register(taskgroup_mod) class taskgroup_find(basegroup_find): """ Search for taskgroups. """ container = _container_dn api.register(taskgroup_find) class taskgroup_show(basegroup_show): """ Display taskgroup. """ default_attributes = _default_attributes container = _container_dn api.register(taskgroup_show) class taskgroup_add_member(basegroup_add_member): """ Add member to taskgroup. """ container = _container_dn takes_options = basegroup_add_member.takes_options + ( List('rolegroups?', cli_name='rolegroups', doc='comma-separated list of role groups to add' ), ) def execute(self, cn, **kw): """ Execute the group-add-member operation. Returns the updated group entry :param cn: The group name to add new members to. :param kw: groups is a comma-separated list of groups to add :param kw: users is a comma-separated list of users to add :param kw: rolegroups is a comma-separated list of rolegroups to add """ assert self.container ldap = self.api.Backend.ldap2 (dn, entry_attrs) = ldap.find_entry_by_attr( 'cn', cn, self.filter_class, [''], self.container ) to_add = [] add_failed = {} completed = 0 members = kw.get('groups', []) (to_add, add_failed) = find_members( ldap, add_failed, members, 'cn', 'ipaUserGroup', self.api.env.container_group ) (completed, add_failed) = add_members( ldap, completed, to_add, add_failed, dn, 'member' ) members = kw.get('hosts', []) (to_add, add_failed) = find_members( ldap, add_failed, members, 'cn', 'ipaHost', self.api.env.container_host ) (completed, add_failed) = add_members( ldap, completed, to_add, add_failed, dn, 'member' ) members = kw.get('rolegroups', []) (to_add, add_failed) = find_members( ldap, add_failed, members, 'cn', self.filter_class, self.api.env.container_rolegroup ) (completed, add_failed) = add_members( ldap, completed, to_add, add_failed, dn, 'member' ) return ( completed, add_failed, ldap.get_entry(dn, _default_attributes) ) api.register(taskgroup_add_member) class taskgroup_remove_member(basegroup_remove_member): """ Remove member from taskgroup. """ container = _container_dn takes_options = basegroup_remove_member.takes_options + ( List('rolegroups?', cli_name='rolegroups', doc='comma-separated list of role groups to remove' ), ) def execute(self, cn, **kw): """ Execute the group-remove-member operation. Returns the updated group entry :param cn: The group name to remove new members from. :param kw: groups is a comma-separated list of groups to remove :param kw: users is a comma-separated list of users to remove :param kw: rolegroups is a comma-separated list of rolegroups to remove """ assert self.container ldap = self.api.Backend.ldap2 (dn, entry_attrs) = ldap.find_entry_by_attr( 'cn', cn, self.filter_class, [''], self.container ) to_remove = [] rem_failed = {} completed = 0 members = kw.get('groups', []) (to_remove, rem_failed) = find_members( ldap, rem_failed, members, 'cn', 'ipaUserGroup', self.api.env.container_group ) (completed, rem_failed) = del_members( ldap, completed, to_remove, rem_failed, dn, 'member' ) members = kw.get('hosts', []) (to_remove, rem_failed) = find_members( ldap, rem_failed, members, 'cn', 'ipaHost', self.api.env.container_host ) (completed, rem_failed) = del_members( ldap, completed, to_remove, rem_failed, dn, 'member' ) members = kw.get('rolegroups', []) (to_remove, rem_failed) = find_members( ldap, rem_failed, members, 'cn', self.filter_class, self.api.env.container_rolegroup ) (completed, rem_failed) = del_members( ldap, completed, to_remove, rem_failed, dn, 'member' ) return ( completed, rem_failed, ldap.get_entry(dn, _default_attributes) ) api.register(taskgroup_remove_member)