diff options
-rw-r--r-- | app/controllers/projects/registry/tags_controller.rb | 6 | ||||
-rw-r--r-- | lib/container_registry/path.rb | 8 |
2 files changed, 8 insertions, 6 deletions
diff --git a/app/controllers/projects/registry/tags_controller.rb b/app/controllers/projects/registry/tags_controller.rb index 7a9f290e946..d689cade3ab 100644 --- a/app/controllers/projects/registry/tags_controller.rb +++ b/app/controllers/projects/registry/tags_controller.rb @@ -15,15 +15,13 @@ module Projects private - def repository + def image @image ||= project.container_repositories .find(params[:repository_id]) end def tag - return render_404 unless params[:id].present? - - @tag ||= repository.tag(params[:id]) + @tag ||= image.tag(params[:id]) end end end diff --git a/lib/container_registry/path.rb b/lib/container_registry/path.rb index 89973b2e7b8..a4b5f2aba6c 100644 --- a/lib/container_registry/path.rb +++ b/lib/container_registry/path.rb @@ -1,6 +1,6 @@ module ContainerRegistry ## - # Class reponsible for extracting project and repository name from + # Class responsible for extracting project and repository name from # image repository path provided by a containers registry API response. # # Example: @@ -12,6 +12,8 @@ module ContainerRegistry class Path InvalidRegistryPathError = Class.new(StandardError) + LEVELS_SUPPORTED = 3 + def initialize(path) @path = path end @@ -50,7 +52,9 @@ module ContainerRegistry end def repository_project - @project ||= Project.where_full_path_in(nodes.first(3)).first + @project ||= Project + .where_full_path_in(nodes.first(LEVELS_SUPPORTED)) + .first end def repository_name |