120 lines
4.7 KiB
Ruby
120 lines
4.7 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
constraints(::Constraints::GroupUrlConstrainer.new) do
|
|
scope(path: 'groups/*id',
|
|
controller: :groups,
|
|
constraints: { id: Gitlab::PathRegex.full_namespace_route_regex, format: /(html|json|atom|ics)/ }) do
|
|
scope(path: '-') do
|
|
# These routes are legit and the cop rule will be improved in
|
|
# https://gitlab.com/gitlab-org/gitlab/-/issues/230703
|
|
get :edit, as: :edit_group # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
get :issues, as: :issues_group_calendar, action: :issues_calendar, constraints: lambda { |req| req.format == :ics } # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
get :issues, as: :issues_group # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
get :merge_requests, as: :merge_requests_group # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
get :projects, as: :projects_group # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
get :details, as: :details_group # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
get :activity, as: :activity_group # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
put :transfer, as: :transfer_group # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
post :export, as: :export_group # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
get :download_export, as: :download_export_group # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
|
|
# TODO: Remove as part of refactor in https://gitlab.com/gitlab-org/gitlab-foss/issues/49693
|
|
get 'shared', action: :show, as: :group_shared # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
get 'archived', action: :show, as: :group_archived # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
end
|
|
|
|
# These routes are legit and the cop rule will be improved in
|
|
# https://gitlab.com/gitlab-org/gitlab/-/issues/230703
|
|
get '/', action: :show, as: :group_canonical # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
end
|
|
|
|
scope(path: 'groups/*group_id/-',
|
|
module: :groups,
|
|
as: :group,
|
|
constraints: { group_id: Gitlab::PathRegex.full_namespace_route_regex }) do
|
|
namespace :settings do
|
|
resource :ci_cd, only: [:show, :update], controller: 'ci_cd' do
|
|
put :reset_registration_token
|
|
patch :update_auto_devops
|
|
post :create_deploy_token, path: 'deploy_token/create', to: 'repository#create_deploy_token'
|
|
end
|
|
|
|
resource :repository, only: [:show], controller: 'repository' do
|
|
post :create_deploy_token, path: 'deploy_token/create'
|
|
end
|
|
|
|
resources :integrations, only: [:index, :edit, :update] do
|
|
member do
|
|
put :test
|
|
end
|
|
end
|
|
end
|
|
|
|
resource :variables, only: [:show, :update]
|
|
|
|
resources :children, only: [:index]
|
|
resources :shared_projects, only: [:index]
|
|
|
|
resources :labels, except: [:show] do
|
|
post :toggle_subscription, on: :member
|
|
end
|
|
|
|
resources :packages, only: [:index]
|
|
|
|
resources :milestones, constraints: { id: %r{[^/]+} } do
|
|
member do
|
|
get :merge_requests
|
|
get :participants
|
|
get :labels
|
|
end
|
|
end
|
|
|
|
resources :deploy_tokens, constraints: { id: /\d+/ }, only: [] do
|
|
member do
|
|
put :revoke
|
|
end
|
|
end
|
|
|
|
resource :avatar, only: [:destroy]
|
|
resource :import, only: [:show]
|
|
|
|
concerns :clusterable
|
|
|
|
resources :group_members, only: [:index, :create, :update, :destroy], concerns: :access_requestable do
|
|
post :resend_invite, on: :member
|
|
delete :leave, on: :collection
|
|
end
|
|
|
|
resources :group_links, only: [:create, :update, :destroy], constraints: { id: /\d+/ }
|
|
|
|
resources :uploads, only: [:create] do
|
|
collection do
|
|
get ":secret/:filename", action: :show, as: :show, constraints: { filename: %r{[^/]+} }, format: false, defaults: { format: nil }
|
|
post :authorize
|
|
end
|
|
end
|
|
|
|
resources :boards, only: [:index, :show], constraints: { id: /\d+/ }
|
|
|
|
resources :runners, only: [:index, :edit, :update, :destroy, :show] do
|
|
member do
|
|
post :resume
|
|
post :pause
|
|
end
|
|
end
|
|
|
|
resources :container_registries, only: [:index, :show], controller: 'registry/repositories'
|
|
end
|
|
|
|
scope(path: '*id',
|
|
as: :group,
|
|
constraints: { id: Gitlab::PathRegex.full_namespace_route_regex, format: /(html|json|atom)/ },
|
|
controller: :groups) do
|
|
# These routes are legit and the cop rule will be improved in
|
|
# https://gitlab.com/gitlab-org/gitlab/-/issues/230703
|
|
get '/', action: :show # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
patch '/', action: :update # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
put '/', action: :update # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
delete '/', action: :destroy # rubocop:disable Cop/PutGroupRoutesUnderScope
|
|
end
|
|
end
|