5b3c096c9e
In preparation so that we can create both cluster attached to project and cluster attached to group. - Move ClustersController to top level - Move Clusters::ApplicationsController to top-level too - Creates a Clusters::BaseController to share common functions - Do not rely on @project ivar. Anything could set the ivar. - Fix Vue page components due to new data-page value Because of the controller change we have gone from `projects:clusters:new` to `clusters:new`, so we need to update the file location of the page components. There is somewhere a function that will convert data-page to a file location. On that note, projects/clusters/gcp/new/, translate to Projects::Clusters::Gcp#new doesn't exist so replace that with clusters/create_gcp/ and clusters/create_user/
42 lines
974 B
Ruby
42 lines
974 B
Ruby
# frozen_string_literal: true
|
|
|
|
class Clusters::BaseController < ApplicationController
|
|
include RoutableActions
|
|
|
|
skip_before_action :authenticate_user!
|
|
before_action :require_project_id
|
|
before_action :project, if: :project_type?
|
|
before_action :repository, if: :project_type?
|
|
before_action :authorize_read_cluster!
|
|
|
|
private
|
|
|
|
# We can extend to `#group_type?` in the future
|
|
def require_project_id
|
|
not_found unless project_type?
|
|
end
|
|
|
|
def project
|
|
@project ||= find_routable!(Project, File.join(params[:namespace_id], params[:project_id]))
|
|
end
|
|
|
|
def repository
|
|
@repository ||= project.repository
|
|
end
|
|
|
|
def authorize_read_cluster!
|
|
access_denied! unless can?(current_user, :read_cluster, clusterable)
|
|
end
|
|
|
|
def authorize_create_cluster!
|
|
access_denied! unless can?(current_user, :create_cluster, clusterable)
|
|
end
|
|
|
|
def clusterable
|
|
project if project_type?
|
|
end
|
|
|
|
def project_type?
|
|
params[:project_id].present?
|
|
end
|
|
end
|