diff options
Diffstat (limited to 'app')
-rw-r--r-- | app/assets/javascripts/pages/clusters/create_gcp/index.js | 7 | ||||
-rw-r--r-- | app/assets/javascripts/pages/clusters/create_user/index.js | 7 | ||||
-rw-r--r-- | app/assets/javascripts/pages/clusters/new/index.js | 7 | ||||
-rw-r--r-- | app/assets/javascripts/pages/projects/clusters/destroy/index.js (renamed from app/assets/javascripts/pages/clusters/destroy/index.js) | 0 | ||||
-rw-r--r-- | app/assets/javascripts/pages/projects/clusters/index/index.js (renamed from app/assets/javascripts/pages/clusters/index/index.js) | 0 | ||||
-rw-r--r-- | app/assets/javascripts/pages/projects/clusters/show/index.js (renamed from app/assets/javascripts/pages/clusters/show/index.js) | 0 | ||||
-rw-r--r-- | app/assets/javascripts/pages/projects/clusters/update/index.js (renamed from app/assets/javascripts/pages/clusters/update/index.js) | 0 | ||||
-rw-r--r-- | app/assets/javascripts/pages/projects/index.js | 14 | ||||
-rw-r--r-- | app/controllers/clusters/base_controller.rb | 32 | ||||
-rw-r--r-- | app/controllers/clusters/clusters_controller.rb (renamed from app/controllers/clusters_controller.rb) | 22 | ||||
-rw-r--r-- | app/controllers/projects/clusters/applications_controller.rb | 17 | ||||
-rw-r--r-- | app/controllers/projects/clusters_controller.rb | 24 | ||||
-rw-r--r-- | app/helpers/clusters_helper.rb | 2 | ||||
-rw-r--r-- | app/presenters/project_clusterable_presenter.rb | 20 | ||||
-rw-r--r-- | app/views/clusters/clusters/_advanced_settings.html.haml (renamed from app/views/clusters/_advanced_settings.html.haml) | 2 | ||||
-rw-r--r-- | app/views/clusters/clusters/_banner.html.haml (renamed from app/views/clusters/_banner.html.haml) | 0 | ||||
-rw-r--r-- | app/views/clusters/clusters/_cluster.html.haml (renamed from app/views/clusters/_cluster.html.haml) | 2 | ||||
-rw-r--r-- | app/views/clusters/clusters/_empty_state.html.haml (renamed from app/views/clusters/_empty_state.html.haml) | 0 | ||||
-rw-r--r-- | app/views/clusters/clusters/_gcp_signup_offer_banner.html.haml (renamed from app/views/clusters/_gcp_signup_offer_banner.html.haml) | 0 | ||||
-rw-r--r-- | app/views/clusters/clusters/_integration_form.html.haml (renamed from app/views/clusters/_integration_form.html.haml) | 2 | ||||
-rw-r--r-- | app/views/clusters/clusters/_sidebar.html.haml (renamed from app/views/clusters/_sidebar.html.haml) | 0 | ||||
-rw-r--r-- | app/views/clusters/clusters/gcp/_form.html.haml (renamed from app/views/clusters/gcp/_form.html.haml) | 2 | ||||
-rw-r--r-- | app/views/clusters/clusters/gcp/_header.html.haml (renamed from app/views/clusters/gcp/_header.html.haml) | 0 | ||||
-rw-r--r-- | app/views/clusters/clusters/gcp/_show.html.haml (renamed from app/views/clusters/gcp/_show.html.haml) | 2 | ||||
-rw-r--r-- | app/views/clusters/clusters/index.html.haml (renamed from app/views/clusters/index.html.haml) | 0 | ||||
-rw-r--r-- | app/views/clusters/clusters/new.html.haml (renamed from app/views/clusters/new.html.haml) | 8 | ||||
-rw-r--r-- | app/views/clusters/clusters/show.html.haml (renamed from app/views/clusters/show.html.haml) | 16 | ||||
-rw-r--r-- | app/views/clusters/clusters/user/_form.html.haml (renamed from app/views/clusters/user/_form.html.haml) | 2 | ||||
-rw-r--r-- | app/views/clusters/clusters/user/_header.html.haml (renamed from app/views/clusters/user/_header.html.haml) | 0 | ||||
-rw-r--r-- | app/views/clusters/clusters/user/_show.html.haml (renamed from app/views/clusters/user/_show.html.haml) | 2 |
30 files changed, 109 insertions, 81 deletions
diff --git a/app/assets/javascripts/pages/clusters/create_gcp/index.js b/app/assets/javascripts/pages/clusters/create_gcp/index.js deleted file mode 100644 index e7c8cc4ab5f..00000000000 --- a/app/assets/javascripts/pages/clusters/create_gcp/index.js +++ /dev/null @@ -1,7 +0,0 @@ -import initDismissableCallout from '~/dismissable_callout'; -import initGkeDropdowns from '~/projects/gke_cluster_dropdowns'; - -document.addEventListener('DOMContentLoaded', () => { - initDismissableCallout('.gcp-signup-offer'); - initGkeDropdowns(); -}); diff --git a/app/assets/javascripts/pages/clusters/create_user/index.js b/app/assets/javascripts/pages/clusters/create_user/index.js deleted file mode 100644 index e7c8cc4ab5f..00000000000 --- a/app/assets/javascripts/pages/clusters/create_user/index.js +++ /dev/null @@ -1,7 +0,0 @@ -import initDismissableCallout from '~/dismissable_callout'; -import initGkeDropdowns from '~/projects/gke_cluster_dropdowns'; - -document.addEventListener('DOMContentLoaded', () => { - initDismissableCallout('.gcp-signup-offer'); - initGkeDropdowns(); -}); diff --git a/app/assets/javascripts/pages/clusters/new/index.js b/app/assets/javascripts/pages/clusters/new/index.js deleted file mode 100644 index e7c8cc4ab5f..00000000000 --- a/app/assets/javascripts/pages/clusters/new/index.js +++ /dev/null @@ -1,7 +0,0 @@ -import initDismissableCallout from '~/dismissable_callout'; -import initGkeDropdowns from '~/projects/gke_cluster_dropdowns'; - -document.addEventListener('DOMContentLoaded', () => { - initDismissableCallout('.gcp-signup-offer'); - initGkeDropdowns(); -}); diff --git a/app/assets/javascripts/pages/clusters/destroy/index.js b/app/assets/javascripts/pages/projects/clusters/destroy/index.js index 8001d2dd1da..8001d2dd1da 100644 --- a/app/assets/javascripts/pages/clusters/destroy/index.js +++ b/app/assets/javascripts/pages/projects/clusters/destroy/index.js diff --git a/app/assets/javascripts/pages/clusters/index/index.js b/app/assets/javascripts/pages/projects/clusters/index/index.js index e4b8baede58..e4b8baede58 100644 --- a/app/assets/javascripts/pages/clusters/index/index.js +++ b/app/assets/javascripts/pages/projects/clusters/index/index.js diff --git a/app/assets/javascripts/pages/clusters/show/index.js b/app/assets/javascripts/pages/projects/clusters/show/index.js index 8001d2dd1da..8001d2dd1da 100644 --- a/app/assets/javascripts/pages/clusters/show/index.js +++ b/app/assets/javascripts/pages/projects/clusters/show/index.js diff --git a/app/assets/javascripts/pages/clusters/update/index.js b/app/assets/javascripts/pages/projects/clusters/update/index.js index 8001d2dd1da..8001d2dd1da 100644 --- a/app/assets/javascripts/pages/clusters/update/index.js +++ b/app/assets/javascripts/pages/projects/clusters/update/index.js diff --git a/app/assets/javascripts/pages/projects/index.js b/app/assets/javascripts/pages/projects/index.js index 8e0af018b61..5659e13981a 100644 --- a/app/assets/javascripts/pages/projects/index.js +++ b/app/assets/javascripts/pages/projects/index.js @@ -1,7 +1,21 @@ +import initDismissableCallout from '~/dismissable_callout'; +import initGkeDropdowns from '~/projects/gke_cluster_dropdowns'; import Project from './project'; import ShortcutsNavigation from '../../behaviors/shortcuts/shortcuts_navigation'; document.addEventListener('DOMContentLoaded', () => { + const { page } = document.body.dataset; + const newClusterViews = [ + 'projects:clusters:new', + 'projects:clusters:create_gcp', + 'projects:clusters:create_user', + ]; + + if (newClusterViews.indexOf(page) > -1) { + initDismissableCallout('.gcp-signup-offer'); + initGkeDropdowns(); + } + new Project(); // eslint-disable-line no-new new ShortcutsNavigation(); // eslint-disable-line no-new }); diff --git a/app/controllers/clusters/base_controller.rb b/app/controllers/clusters/base_controller.rb index 3a8575769c4..ef42f7c4074 100644 --- a/app/controllers/clusters/base_controller.rb +++ b/app/controllers/clusters/base_controller.rb @@ -2,31 +2,25 @@ class Clusters::BaseController < ApplicationController include RoutableActions - include ProjectUnauthorized 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! - layout :determine_layout - helper_method :clusterable private - # We can extend to `#group_type?` in the future - def require_project_id - not_found unless project_type? + def cluster + @cluster ||= clusterable.clusters.find(params[:id]) + .present(current_user: current_user) end - def project - @project ||= find_routable!(Project, File.join(params[:namespace_id], params[:project_id]), not_found_or_authorized_proc: project_unauthorized_proc) + def authorize_update_cluster! + access_denied! unless can?(current_user, :update_cluster, cluster) end - def repository - @repository ||= project.repository + def authorize_admin_cluster! + access_denied! unless can?(current_user, :admin_cluster, cluster) end def authorize_read_cluster! @@ -37,17 +31,7 @@ class Clusters::BaseController < ApplicationController access_denied! unless can?(current_user, :create_cluster, clusterable) end - def determine_layout - if project_type? - 'project' - end - end - def clusterable - @clusterable ||= ClusterablePresenter.fabricate(project, current_user: current_user) - end - - def project_type? - params[:project_id].present? + raise NotImplementedError end end diff --git a/app/controllers/clusters_controller.rb b/app/controllers/clusters/clusters_controller.rb index 7aad70870ba..f6f2060ebb5 100644 --- a/app/controllers/clusters_controller.rb +++ b/app/controllers/clusters/clusters_controller.rb @@ -1,6 +1,8 @@ # frozen_string_literal: true -class ClustersController < Clusters::BaseController +class Clusters::ClustersController < Clusters::BaseController + include RoutableActions + before_action :cluster, except: [:index, :new, :create_gcp, :create_user] before_action :generate_gcp_authorize_url, only: [:new] before_action :validate_gcp_token, only: [:new] @@ -9,7 +11,7 @@ class ClustersController < Clusters::BaseController before_action :authorize_create_cluster!, only: [:new] before_action :authorize_update_cluster!, only: [:update] before_action :authorize_admin_cluster!, only: [:destroy] - before_action :update_applications_status, only: [:status] + before_action :update_applications_status, only: [:cluster_status] helper_method :token_in_session @@ -23,7 +25,8 @@ class ClustersController < Clusters::BaseController def new end - def status + # Overridding ActionController::Metal#status is NOT a good idea + def cluster_status respond_to do |format| format.json do Gitlab::PollingInterval.set_header(response, interval: STATUS_POLLING_INTERVAL) @@ -107,11 +110,6 @@ class ClustersController < Clusters::BaseController private - def cluster - @cluster ||= clusterable.clusters.find(params[:id]) - .present(current_user: current_user) - end - def update_params if cluster.managed? params.require(:cluster).permit( @@ -214,14 +212,6 @@ class ClustersController < Clusters::BaseController end end - def authorize_update_cluster! - access_denied! unless can?(current_user, :update_cluster, cluster) - end - - def authorize_admin_cluster! - access_denied! unless can?(current_user, :admin_cluster, cluster) - end - def update_applications_status @cluster.applications.each(&:schedule_status_update) end diff --git a/app/controllers/projects/clusters/applications_controller.rb b/app/controllers/projects/clusters/applications_controller.rb new file mode 100644 index 00000000000..c7b6218d007 --- /dev/null +++ b/app/controllers/projects/clusters/applications_controller.rb @@ -0,0 +1,17 @@ +# frozen_string_literal: true + +class Projects::Clusters::ApplicationsController < Clusters::ApplicationsController + include ProjectUnauthorized + + prepend_before_action :project + + private + + def clusterable + @clusterable ||= ClusterablePresenter.fabricate(project, current_user: current_user) + end + + def project + @project ||= find_routable!(Project, File.join(params[:namespace_id], params[:project_id]), not_found_or_authorized_proc: project_unauthorized_proc) + end +end diff --git a/app/controllers/projects/clusters_controller.rb b/app/controllers/projects/clusters_controller.rb new file mode 100644 index 00000000000..feda6deeaa6 --- /dev/null +++ b/app/controllers/projects/clusters_controller.rb @@ -0,0 +1,24 @@ +# frozen_string_literal: true + +class Projects::ClustersController < Clusters::ClustersController + include ProjectUnauthorized + + prepend_before_action :project + before_action :repository + + layout 'project' + + private + + def clusterable + @clusterable ||= ClusterablePresenter.fabricate(project, current_user: current_user) + end + + def project + @project ||= find_routable!(Project, File.join(params[:namespace_id], params[:project_id]), not_found_or_authorized_proc: project_unauthorized_proc) + end + + def repository + @repository ||= project.repository + end +end diff --git a/app/helpers/clusters_helper.rb b/app/helpers/clusters_helper.rb index 360885fe179..94042a2f560 100644 --- a/app/helpers/clusters_helper.rb +++ b/app/helpers/clusters_helper.rb @@ -11,7 +11,7 @@ module ClustersHelper return unless show_gcp_signup_offer? content_tag :section, class: 'no-animate expanded' do - render 'clusters/gcp_signup_offer_banner' + render 'clusters/clusters/gcp_signup_offer_banner' end end diff --git a/app/presenters/project_clusterable_presenter.rb b/app/presenters/project_clusterable_presenter.rb index f986b5584a3..bd149cdcc70 100644 --- a/app/presenters/project_clusterable_presenter.rb +++ b/app/presenters/project_clusterable_presenter.rb @@ -9,6 +9,26 @@ class ProjectClusterablePresenter < ClusterablePresenter new_project_cluster_path(clusterable) end + def create_user_clusters_path + create_user_project_clusters_path(clusterable) + end + + def create_gcp_clusters_path + create_gcp_project_clusters_path(clusterable) + end + + def cluster_status_cluster_path(cluster, params = {}) + cluster_status_project_cluster_path(clusterable, cluster, params) + end + + def install_applications_cluster_path(cluster, application) + install_applications_project_cluster_path(clusterable, cluster, application) + end + + def cluster_path(cluster, params = {}) + project_cluster_path(clusterable, cluster, params) + end + def clusterable_params { project_id: clusterable.to_param, namespace_id: clusterable.namespace.to_param } end diff --git a/app/views/clusters/_advanced_settings.html.haml b/app/views/clusters/clusters/_advanced_settings.html.haml index e25076248d2..7037c80aa6b 100644 --- a/app/views/clusters/_advanced_settings.html.haml +++ b/app/views/clusters/clusters/_advanced_settings.html.haml @@ -12,4 +12,4 @@ = s_('ClusterIntegration|Remove Kubernetes cluster integration') %p = s_("ClusterIntegration|Remove this Kubernetes cluster's configuration from this project. This will not delete your actual Kubernetes cluster.") - = link_to(s_('ClusterIntegration|Remove integration'), cluster_path(@cluster, clusterable.clusterable_params), method: :delete, class: 'btn btn-danger', data: { confirm: s_("ClusterIntegration|Are you sure you want to remove this Kubernetes cluster's integration? This will not delete your actual Kubernetes cluster.")}) + = link_to(s_('ClusterIntegration|Remove integration'), clusterable.cluster_path(@cluster), method: :delete, class: 'btn btn-danger', data: { confirm: s_("ClusterIntegration|Are you sure you want to remove this Kubernetes cluster's integration? This will not delete your actual Kubernetes cluster.")}) diff --git a/app/views/clusters/_banner.html.haml b/app/views/clusters/clusters/_banner.html.haml index 73cfea0ef92..73cfea0ef92 100644 --- a/app/views/clusters/_banner.html.haml +++ b/app/views/clusters/clusters/_banner.html.haml diff --git a/app/views/clusters/_cluster.html.haml b/app/views/clusters/clusters/_cluster.html.haml index 709d6711f33..facbcb7fc59 100644 --- a/app/views/clusters/_cluster.html.haml +++ b/app/views/clusters/clusters/_cluster.html.haml @@ -16,7 +16,7 @@ class: "#{'is-checked' if cluster.enabled?} #{'is-disabled' if !cluster.can_toggle_cluster?}", "aria-label": s_("ClusterIntegration|Toggle Kubernetes Cluster"), disabled: !cluster.can_toggle_cluster?, - data: { endpoint: cluster_path(cluster, clusterable.clusterable_params.merge(format: :json)) } } + data: { endpoint: clusterable.cluster_path(cluster, format: :json) } } %input.js-project-feature-toggle-input{ type: "hidden", value: cluster.enabled? } = icon("spinner spin", class: "loading-icon") %span.toggle-icon diff --git a/app/views/clusters/_empty_state.html.haml b/app/views/clusters/clusters/_empty_state.html.haml index 800e76d92ef..800e76d92ef 100644 --- a/app/views/clusters/_empty_state.html.haml +++ b/app/views/clusters/clusters/_empty_state.html.haml diff --git a/app/views/clusters/_gcp_signup_offer_banner.html.haml b/app/views/clusters/clusters/_gcp_signup_offer_banner.html.haml index 73b11d509d3..73b11d509d3 100644 --- a/app/views/clusters/_gcp_signup_offer_banner.html.haml +++ b/app/views/clusters/clusters/_gcp_signup_offer_banner.html.haml diff --git a/app/views/clusters/_integration_form.html.haml b/app/views/clusters/clusters/_integration_form.html.haml index 4b259f02abb..0792ad0085c 100644 --- a/app/views/clusters/_integration_form.html.haml +++ b/app/views/clusters/clusters/_integration_form.html.haml @@ -1,4 +1,4 @@ -= form_for @cluster, url: cluster_path(@cluster), as: :cluster do |field| += form_for @cluster, url: clusterable.cluster_path(@cluster), as: :cluster do |field| = form_errors(@cluster) = hidden_clusterable_fields .form-group diff --git a/app/views/clusters/_sidebar.html.haml b/app/views/clusters/clusters/_sidebar.html.haml index 3d10348212f..3d10348212f 100644 --- a/app/views/clusters/_sidebar.html.haml +++ b/app/views/clusters/clusters/_sidebar.html.haml diff --git a/app/views/clusters/gcp/_form.html.haml b/app/views/clusters/clusters/gcp/_form.html.haml index 56a5eb630cf..cff5cf335dc 100644 --- a/app/views/clusters/gcp/_form.html.haml +++ b/app/views/clusters/clusters/gcp/_form.html.haml @@ -12,7 +12,7 @@ %p= link_to('Select a different Google account', @authorize_url) -= form_for @gcp_cluster, html: { class: 'js-gke-cluster-creation prepend-top-20', data: { token: token_in_session } }, url: create_gcp_clusters_path, as: :cluster do |field| += form_for @gcp_cluster, html: { class: 'js-gke-cluster-creation prepend-top-20', data: { token: token_in_session } }, url: clusterable.create_gcp_clusters_path, as: :cluster do |field| = form_errors(@gcp_cluster) = hidden_clusterable_fields .form-group diff --git a/app/views/clusters/gcp/_header.html.haml b/app/views/clusters/clusters/gcp/_header.html.haml index a2ad3cd64df..a2ad3cd64df 100644 --- a/app/views/clusters/gcp/_header.html.haml +++ b/app/views/clusters/clusters/gcp/_header.html.haml diff --git a/app/views/clusters/gcp/_show.html.haml b/app/views/clusters/clusters/gcp/_show.html.haml index d5f9ec8ee66..e0159cee4a3 100644 --- a/app/views/clusters/gcp/_show.html.haml +++ b/app/views/clusters/clusters/gcp/_show.html.haml @@ -6,7 +6,7 @@ %span.input-group-append = clipboard_button(text: @cluster.name, title: s_('ClusterIntegration|Copy Kubernetes cluster name'), class: 'input-group-text btn-default') -= form_for @cluster, url: cluster_path(@cluster), as: :cluster do |field| += form_for @cluster, url: clusterable.cluster_path(@cluster), as: :cluster do |field| = form_errors(@cluster) = hidden_clusterable_fields diff --git a/app/views/clusters/index.html.haml b/app/views/clusters/clusters/index.html.haml index a55de84b5cd..a55de84b5cd 100644 --- a/app/views/clusters/index.html.haml +++ b/app/views/clusters/clusters/index.html.haml diff --git a/app/views/clusters/new.html.haml b/app/views/clusters/clusters/new.html.haml index 57cdbcd2d38..eeeef6bd824 100644 --- a/app/views/clusters/new.html.haml +++ b/app/views/clusters/clusters/new.html.haml @@ -19,9 +19,9 @@ .tab-content.gitlab-tab-content .tab-pane{ id: 'create-gcp-cluster-pane', class: active_when(active_tab == 'gcp'), role: 'tabpanel' } - = render 'clusters/gcp/header' + = render 'clusters/clusters/gcp/header' - if @valid_gcp_token - = render 'clusters/gcp/form' + = render 'clusters/clusters/gcp/form' - elsif @authorize_url .signin-with-google = link_to(image_tag('auth_buttons/signin_with_google.png', width: '191px'), @authorize_url) @@ -32,5 +32,5 @@ = s_('Google authentication is not %{link_to_documentation}. Ask your GitLab administrator if you want to use this service.').html_safe % { link_to_documentation: link } .tab-pane{ id: 'add-user-cluster-pane', class: active_when(active_tab == 'user'), role: 'tabpanel' } - = render 'clusters/user/header' - = render 'clusters/user/form' + = render 'clusters/clusters/user/header' + = render 'clusters/clusters/user/form' diff --git a/app/views/clusters/show.html.haml b/app/views/clusters/clusters/show.html.haml index c0169fbf5a2..1e1157c34bd 100644 --- a/app/views/clusters/show.html.haml +++ b/app/views/clusters/clusters/show.html.haml @@ -6,13 +6,13 @@ - expanded = Rails.env.test? -- status_path = status_cluster_path(@cluster.id, clusterable.clusterable_params.merge(format: :json)) if can?(current_user, :admin_cluster, @cluster) +- status_path = clusterable.cluster_status_cluster_path(@cluster.id, format: :json) if can?(current_user, :admin_cluster, @cluster) .edit-cluster-form.js-edit-cluster-form{ data: { status_path: status_path, - install_helm_path: install_applications_cluster_path(@cluster, :helm, clusterable.clusterable_params), - install_ingress_path: install_applications_cluster_path(@cluster, :ingress, clusterable.clusterable_params), - install_prometheus_path: install_applications_cluster_path(@cluster, :prometheus, clusterable.clusterable_params), - install_runner_path: install_applications_cluster_path(@cluster, :runner, clusterable.clusterable_params), - install_jupyter_path: install_applications_cluster_path(@cluster, :jupyter, clusterable.clusterable_params), + install_helm_path: clusterable.install_applications_cluster_path(@cluster, :helm), + install_ingress_path: clusterable.install_applications_cluster_path(@cluster, :ingress), + install_prometheus_path: clusterable.install_applications_cluster_path(@cluster, :prometheus), + install_runner_path: clusterable.install_applications_cluster_path(@cluster, :runner), + install_jupyter_path: clusterable.install_applications_cluster_path(@cluster, :jupyter), toggle_status: @cluster.enabled? ? 'true': 'false', cluster_status: @cluster.status_name, cluster_status_reason: @cluster.status_reason, @@ -39,9 +39,9 @@ %p= s_('ClusterIntegration|See and edit the details for your Kubernetes cluster') .settings-content - if @cluster.managed? - = render 'clusters/gcp/show' + = render 'clusters/clusters/gcp/show' - else - = render 'clusters/user/show' + = render 'clusters/clusters/user/show' %section.settings.no-animate#js-cluster-advanced-settings{ class: ('expanded' if expanded) } .settings-header diff --git a/app/views/clusters/user/_form.html.haml b/app/views/clusters/clusters/user/_form.html.haml index 05462d27b99..43c15274180 100644 --- a/app/views/clusters/user/_form.html.haml +++ b/app/views/clusters/clusters/user/_form.html.haml @@ -1,4 +1,4 @@ -= form_for @user_cluster, url: create_user_clusters_path, as: :cluster do |field| += form_for @user_cluster, url: clusterable.create_user_clusters_path, as: :cluster do |field| = form_errors(@user_cluster) = hidden_clusterable_fields .form-group diff --git a/app/views/clusters/user/_header.html.haml b/app/views/clusters/clusters/user/_header.html.haml index 749177fa6c1..749177fa6c1 100644 --- a/app/views/clusters/user/_header.html.haml +++ b/app/views/clusters/clusters/user/_header.html.haml diff --git a/app/views/clusters/user/_show.html.haml b/app/views/clusters/clusters/user/_show.html.haml index 57f6cd1f43d..4eae08d1250 100644 --- a/app/views/clusters/user/_show.html.haml +++ b/app/views/clusters/clusters/user/_show.html.haml @@ -1,4 +1,4 @@ -= form_for @cluster, url: cluster_path(@cluster), as: :cluster do |field| += form_for @cluster, url: clusterable.cluster_path(@cluster), as: :cluster do |field| = form_errors(@cluster) = hidden_clusterable_fields .form-group |