/usr/lib/ruby/vendor_ruby/chef_zero/endpoints/acl_endpoint.rb is in chef-zero 4.5.0-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 | require 'ffi_yajl'
require 'chef_zero/rest_base'
require 'chef_zero/chef_data/acl_path'
module ChefZero
module Endpoints
# /organizations/ORG/<thing>/NAME/_acl/PERM
# Where thing is:
# clients, data, containers, cookbooks, environments
# groups, roles, nodes, users
# or
# /organizations/ORG/organization/_acl/PERM
# or
# /users/NAME/_acl/PERM
#
# Where PERM is create,read,update,delete,grant
class AclEndpoint < RestBase
def validate_request(request)
path = request.rest_path[0..-3] # Strip off _acl/PERM
path = path[0..1] if path.size == 3 && path[0] == 'organizations' && %w(organization organizations).include?(path[2])
acl_path = ChefData::AclPath.get_acl_data_path(path)
perm = request.rest_path[-1]
if !acl_path || !%w(read create update delete grant).include?(perm)
raise RestErrorResponse.new(404, "Object not found: #{build_uri(request.base_uri, request.rest_path)}")
end
[acl_path, perm]
end
def put(request)
path, perm = validate_request(request)
acls = FFI_Yajl::Parser.parse(get_data(request, path), :create_additions => false)
acls[perm] = FFI_Yajl::Parser.parse(request.body, :create_additions => false)[perm]
set_data(request, path, FFI_Yajl::Encoder.encode(acls, :pretty => true))
json_response(200, {'uri' => "#{build_uri(request.base_uri, request.rest_path)}"})
end
end
end
end
|