FIX: Logs api scope not working (#25215)

This commit is contained in:
Blake Erickson 2024-01-10 19:30:10 -07:00 committed by GitHub
parent c569107872
commit 6ebe61ecec
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 31 additions and 0 deletions

View File

@ -48,6 +48,9 @@ class RouteMatcher
# message_bus is not a rails route, special handling
return true if actions.include?("message_bus") && request.fullpath =~ %r{\A/message-bus/.*/poll}
# logster is not a rails route, special handling
return true if actions.include?(Logster::Web) && request.fullpath =~ %r{\A/logs/.*\.json\z}
path_params = path_params_from_request(request)
actions.include? "#{path_params[:controller]}##{path_params[:action]}"
end

View File

@ -7,5 +7,12 @@ RSpec.describe ApiKeyScope do
"/posts (POST)",
)
end
it "should return logster urls" do
expect(ApiKeyScope.find_urls(actions: [Logster::Web], methods: [])).to contain_exactly(
"/logs/messages.json (POST)",
"/logs/show/:id.json (GET)",
)
end
end
end

View File

@ -290,6 +290,27 @@ RSpec.describe Admin::ApiController do
expect(scope.allowed_parameters["topic_id"]).to contain_exactly("55")
end
it "creates an scope for /logs" do
post "/admin/api/keys.json",
params: {
key: {
description: "logs",
scopes: [{ scope_id: "logs:messages" }],
},
}
expect(response.status).to eq(200)
data = response.parsed_body
scope = ApiKeyScope.find_by(api_key_id: data.dig("key", "id"))
expect(scope.resource).to eq("logs")
expect(scope.action).to eq("messages")
api_key = data.dig("key", "key")
post "/logs/messages.json", headers: { "Api-Key": api_key, "Api-Username": "system" }
expect(response.status).to eq(200)
end
it "allows multiple parameters separated by a comma" do
post "/admin/api/keys.json",
params: {