diff options
author | Tim Smith <tsmith84@gmail.com> | 2020-01-28 10:58:35 -0800 |
---|---|---|
committer | Tim Smith <tsmith84@gmail.com> | 2020-01-29 12:24:52 -0800 |
commit | a46aa60353503387dd5089d74754ff8e8b56a361 (patch) | |
tree | 142a654bc30b0d23e8dd3d104f6b94e64a2723fa /lib/chef/knife/acl_remove.rb | |
parent | 7b9a24982efb8f8c4f02ec70d0219e8ab7ada59a (diff) | |
download | chef-a46aa60353503387dd5089d74754ff8e8b56a361.tar.gz |
Move knife-acl gem commands into chef in their own namespacesknife_acl
Ship these knife commands so we can kill off knife-acl, but move them under their own namespaces.
Signed-off-by: Tim Smith <tsmith@chef.io>
Diffstat (limited to 'lib/chef/knife/acl_remove.rb')
-rw-r--r-- | lib/chef/knife/acl_remove.rb | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/lib/chef/knife/acl_remove.rb b/lib/chef/knife/acl_remove.rb new file mode 100644 index 0000000000..0f5dceeaff --- /dev/null +++ b/lib/chef/knife/acl_remove.rb @@ -0,0 +1,62 @@ +# +# Author:: Steven Danna (steve@chef.io) +# Author:: Jeremiah Snapp (jeremiah@chef.io) +# Copyright:: Copyright 2011-2020 Chef Software, Inc. +# License:: Apache License, Version 2.0 +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# + +require_relative "../knife" + +class Chef + class Knife + class AclRemove < Chef::Knife + category "acl" + banner "knife acl remove MEMBER_TYPE MEMBER_NAME OBJECT_TYPE OBJECT_NAME PERMS" + + deps do + require_relative "acl_base" + include Chef::Knife::AclBase + end + + def run + member_type, member_name, object_type, object_name, perms = name_args + + if name_args.length != 5 + show_usage + ui.fatal "You must specify the member type [client|group|user], member name, object type, object name and perms" + exit 1 + end + + if member_name == "pivotal" && %w{client user}.include?(member_type) + ui.fatal "ERROR: 'pivotal' is a system user so knife-acl will not remove it from an ACL." + exit 1 + end + if member_name == "admins" && member_type == "group" && perms.to_s.split(",").include?("grant") + ui.fatal "ERROR: knife-acl will not remove the 'admins' group from the 'grant' ACE." + ui.fatal " Removal could prevent future attempts to modify permissions." + exit 1 + end + validate_perm_type!(perms) + validate_member_type!(member_type) + validate_member_name!(member_name) + validate_object_name!(object_name) + validate_object_type!(object_type) + validate_member_exists!(member_type, member_name) + + remove_from_acl!(member_type, member_name, object_type, object_name, perms) + end + end + end +end |