mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2024-12-22 23:23:30 -06:00
47fbe05f7f
I don't know why this wasn't always multi-value but if one wanted to set multiple options they needed to call add-option multiple times. The LDAP attribute is already multi-value. This shouldn't cause API issues as it understood the attribute as multi-value just didn't expose it. Client output on the CLI will look a bit different: Added option "('one', 'two')" to Sudo Rule "test" or Added option "(u'one', u'Two')" to Sudo Rule "test" instead of with this change: Added option "one,two" to Sudo Rule "test" Removing an option works in a similar way. The value is normalized on the client side in order to ensure that the option value is always a tuple. https://pagure.io/freeipa/issue/2278 Signed-off-by: Rob Crittenden <rcritten@redhat.com> Reviewed-By: Florence Blanc-Renaud <flo@redhat.com>
62 lines
2.3 KiB
Python
62 lines
2.3 KiB
Python
# Authors:
|
|
# Jr Aquino <jr.aquino@citrixonline.com>
|
|
#
|
|
# Copyright (C) 2010-2014 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, 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/>.
|
|
|
|
from ipaclient.frontend import MethodOverride
|
|
from ipalib.plugable import Registry
|
|
from ipalib import _
|
|
|
|
register = Registry()
|
|
|
|
|
|
@register(override=True, no_fail=True)
|
|
class sudorule_enable(MethodOverride):
|
|
def output_for_cli(self, textui, result, cn, **options):
|
|
textui.print_dashed(_('Enabled Sudo Rule "%s"') % cn)
|
|
|
|
|
|
@register(override=True, no_fail=True)
|
|
class sudorule_disable(MethodOverride):
|
|
def output_for_cli(self, textui, result, cn, **options):
|
|
textui.print_dashed(_('Disabled Sudo Rule "%s"') % cn)
|
|
|
|
|
|
@register(override=True, no_fail=True)
|
|
class sudorule_add_option(MethodOverride):
|
|
def output_for_cli(self, textui, result, cn, **options):
|
|
opts = self.normalize(**options)
|
|
textui.print_dashed(
|
|
_('Added option "%(option)s" to Sudo Rule "%(rule)s"')
|
|
% dict(option=','.join(opts['ipasudoopt']), rule=cn)
|
|
)
|
|
|
|
super(sudorule_add_option, self).output_for_cli(textui, result, cn,
|
|
**options)
|
|
|
|
|
|
@register(override=True, no_fail=True)
|
|
class sudorule_remove_option(MethodOverride):
|
|
def output_for_cli(self, textui, result, cn, **options):
|
|
opts = self.normalize(**options)
|
|
textui.print_dashed(
|
|
_('Removed option "%(option)s" from Sudo Rule "%(rule)s"')
|
|
% dict(option=','.join(opts['ipasudoopt']), rule=cn)
|
|
)
|
|
super(sudorule_remove_option, self).output_for_cli(textui, result, cn,
|
|
**options)
|