Commit 3e501971 authored by Robert May's avatar Robert May Committed by Douglas Barbosa Alexandre

Updated cache key calculation

Improves cache key generation to correctly fetch latest
commits for the from/to branches.
parent 2cd7de99
...@@ -42,6 +42,26 @@ module API ...@@ -42,6 +42,26 @@ module API
not_found! 'Blob' unless @blob not_found! 'Blob' unless @blob
end end
def fetch_target_project(current_user, user_project, params)
return user_project unless params[:from_project_id].present?
MergeRequestTargetProjectFinder
.new(current_user: current_user, source_project: user_project, project_feature: :repository)
.execute(include_routes: true).find_by_id(params[:from_project_id])
end
def compare_cache_key(current_user, user_project, target_project, params)
[
user_project,
target_project,
current_user,
:repository_compare,
target_project.repository.commit(params[:from]),
user_project.repository.commit(params[:to]),
params
]
end
end end
desc 'Get a project repository tree' do desc 'Get a project repository tree' do
...@@ -126,21 +146,15 @@ module API ...@@ -126,21 +146,15 @@ module API
end end
get ':id/repository/compare' do get ':id/repository/compare' do
ff_enabled = Feature.enabled?(:api_caching_rate_limit_repository_compare, user_project, default_enabled: :yaml) ff_enabled = Feature.enabled?(:api_caching_rate_limit_repository_compare, user_project, default_enabled: :yaml)
cache_key = [user_project, user_project.repository.commit, :repository_compare, current_user, declared_params] target_project = fetch_target_project(current_user, user_project, params)
cache_action_if(ff_enabled, cache_key, expires_in: 1.minute) do if target_project.blank?
if params[:from_project_id].present? render_api_error!("Target project id:#{params[:from_project_id]} is not a fork of project id:#{params[:id]}", 400)
target_project = MergeRequestTargetProjectFinder end
.new(current_user: current_user, source_project: user_project, project_feature: :repository)
.execute(include_routes: true).find_by_id(params[:from_project_id])
if target_project.blank?
render_api_error!("Target project id:#{params[:from_project_id]} is not a fork of project id:#{params[:id]}", 400)
end
else
target_project = user_project
end
cache_key = compare_cache_key(current_user, user_project, target_project, declared_params)
cache_action_if(ff_enabled, cache_key, expires_in: 1.minute) do
compare = CompareService.new(user_project, params[:to]).execute(target_project, params[:from], straight: params[:straight]) compare = CompareService.new(user_project, params[:to]).execute(target_project, params[:from], straight: params[:straight])
if compare if compare
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment