2021-03-11 19:13:27 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2014-09-02 18:07:02 +05:30
|
|
|
require 'sidekiq/web'
|
2015-12-23 02:04:40 +05:30
|
|
|
require 'sidekiq/cron/web'
|
2016-06-02 11:05:42 +05:30
|
|
|
|
2023-04-23 21:23:45 +05:30
|
|
|
InitializerConnections.raise_if_new_database_connection do
|
2022-08-13 15:12:31 +05:30
|
|
|
Rails.application.routes.draw do
|
|
|
|
concern :access_requestable do
|
|
|
|
post :request_access, on: :collection
|
|
|
|
post :approve_access_request, on: :member
|
|
|
|
end
|
2016-06-16 23:09:34 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
concern :awardable do
|
|
|
|
post :toggle_award_emoji, on: :member
|
|
|
|
end
|
2016-09-29 09:46:39 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
favicon_redirect = redirect do |_params, _request|
|
|
|
|
ActionController::Base.helpers.asset_url(Gitlab::Favicon.main)
|
|
|
|
end
|
|
|
|
get 'favicon.png', to: favicon_redirect
|
|
|
|
get 'favicon.ico', to: favicon_redirect
|
2018-11-08 19:23:39 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
draw :development
|
2015-09-25 12:07:36 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
use_doorkeeper do
|
|
|
|
controllers applications: 'oauth/applications',
|
2023-06-20 00:43:36 +05:30
|
|
|
authorized_applications: 'oauth/authorized_applications',
|
|
|
|
authorizations: 'oauth/authorizations',
|
|
|
|
token_info: 'oauth/token_info',
|
|
|
|
tokens: 'oauth/tokens'
|
2022-08-13 15:12:31 +05:30
|
|
|
end
|
2023-05-27 22:25:52 +05:30
|
|
|
put '/oauth/applications/:id/renew(.:format)' => 'oauth/applications#renew', as: :renew_oauth_application
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
# This prefixless path is required because Jira gets confused if we set it up with a path
|
|
|
|
# More information: https://gitlab.com/gitlab-org/gitlab/issues/6752
|
|
|
|
scope path: '/login/oauth', controller: 'oauth/jira_dvcs/authorizations', as: :oauth_jira_dvcs do
|
|
|
|
get :authorize, action: :new
|
|
|
|
get :callback
|
|
|
|
post :access_token
|
2019-09-30 21:07:59 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
match '*all', via: [:get, :post], to: proc { [404, {}, ['']] }
|
|
|
|
end
|
2018-11-20 20:47:30 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
draw :oauth
|
2018-12-13 13:39:08 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
use_doorkeeper_openid_connect do
|
|
|
|
controllers discovery: 'jwks'
|
|
|
|
end
|
2021-12-11 22:18:48 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
# Add OPTIONS method for CORS preflight requests
|
|
|
|
match '/oauth/userinfo' => 'doorkeeper/openid_connect/userinfo#show', via: :options
|
|
|
|
match '/oauth/discovery/keys' => 'jwks#keys', via: :options
|
|
|
|
match '/.well-known/openid-configuration' => 'jwks#provider', via: :options
|
|
|
|
match '/.well-known/webfinger' => 'jwks#webfinger', via: :options
|
2021-09-04 01:27:46 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
match '/oauth/token' => 'oauth/tokens#create', via: :options
|
|
|
|
match '/oauth/revoke' => 'oauth/tokens#revoke', via: :options
|
2017-08-17 22:00:37 +05:30
|
|
|
|
2023-03-04 22:38:38 +05:30
|
|
|
match '/-/jira_connect/oauth_application_id' => 'jira_connect/oauth_application_ids#show', via: :options
|
|
|
|
match '/-/jira_connect/subscriptions(.:format)' => 'jira_connect/subscriptions#index', via: :options
|
|
|
|
match '/-/jira_connect/subscriptions/:id' => 'jira_connect/subscriptions#delete', via: :options
|
2022-08-13 15:12:31 +05:30
|
|
|
|
|
|
|
# Sign up
|
|
|
|
scope path: '/users/sign_up', module: :registrations, as: :users_sign_up do
|
2023-04-23 21:23:45 +05:30
|
|
|
resource :welcome, only: [:show, :update], controller: 'welcome'
|
2021-03-08 18:12:59 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
Gitlab.ee do
|
|
|
|
resource :company, only: [:new, :create], controller: 'company'
|
|
|
|
resources :groups_projects, only: [:new, :create] do
|
2023-07-09 08:55:56 +05:30
|
|
|
post :import, on: :collection
|
2022-05-07 20:08:51 +05:30
|
|
|
end
|
2022-08-13 15:12:31 +05:30
|
|
|
draw :verification
|
2021-11-11 11:23:49 +05:30
|
|
|
end
|
2020-06-23 00:09:42 +05:30
|
|
|
end
|
2019-12-21 20:55:43 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
# Search
|
|
|
|
get 'search' => 'search#show', as: :search
|
|
|
|
get 'search/autocomplete' => 'search#autocomplete', as: :search_autocomplete
|
|
|
|
get 'search/count' => 'search#count', as: :search_count
|
|
|
|
get 'search/opensearch' => 'search#opensearch', as: :search_opensearch
|
2014-09-02 18:07:02 +05:30
|
|
|
|
2022-08-27 11:52:29 +05:30
|
|
|
Gitlab.ee do
|
|
|
|
get 'search/aggregations' => 'search#aggregations', as: :search_aggregations
|
|
|
|
end
|
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
# JSON Web Token
|
|
|
|
get 'jwt/auth' => 'jwt#auth'
|
2023-05-27 22:25:52 +05:30
|
|
|
post 'jwt/auth', to: proc { [404, {}, ['']] }
|
2016-06-02 11:05:42 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
# Health check
|
|
|
|
get 'health_check(/:checks)' => 'health_check#index', as: :health_check
|
2016-06-02 11:05:42 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
# Terraform service discovery
|
|
|
|
get '.well-known/terraform.json' => 'terraform/services#index', as: :terraform_services
|
2021-06-08 01:23:25 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
# Begin of the /-/ scope.
|
|
|
|
# Use this scope for all new global routes.
|
|
|
|
scope path: '-' do
|
|
|
|
# Autocomplete
|
|
|
|
get '/autocomplete/users' => 'autocomplete#users'
|
|
|
|
get '/autocomplete/users/:id' => 'autocomplete#user'
|
|
|
|
get '/autocomplete/projects' => 'autocomplete#projects'
|
|
|
|
get '/autocomplete/award_emojis' => 'autocomplete#award_emojis'
|
|
|
|
get '/autocomplete/merge_request_target_branches' => 'autocomplete#merge_request_target_branches'
|
|
|
|
get '/autocomplete/deploy_keys_with_owners' => 'autocomplete#deploy_keys_with_owners'
|
2020-05-24 23:13:21 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
Gitlab.ee do
|
|
|
|
get '/autocomplete/project_groups' => 'autocomplete#project_groups'
|
|
|
|
get '/autocomplete/project_routes' => 'autocomplete#project_routes'
|
|
|
|
get '/autocomplete/namespace_routes' => 'autocomplete#namespace_routes'
|
|
|
|
get '/autocomplete/group_subgroups' => 'autocomplete#group_subgroups'
|
|
|
|
end
|
2020-05-24 23:13:21 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
# sandbox
|
|
|
|
get '/sandbox/mermaid' => 'sandbox#mermaid'
|
2022-11-25 23:54:43 +05:30
|
|
|
get '/sandbox/swagger' => 'sandbox#swagger'
|
2022-03-02 08:16:31 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
get '/whats_new' => 'whats_new#index'
|
2021-01-03 14:25:43 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
get 'offline' => "pwa#offline"
|
|
|
|
get 'manifest' => "pwa#manifest", constraints: lambda { |req| req.format == :json }
|
2022-07-16 23:28:13 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
# '/-/health' implemented by BasicHealthCheck middleware
|
|
|
|
get 'liveness' => 'health#liveness'
|
|
|
|
get 'readiness' => 'health#readiness'
|
|
|
|
controller :metrics do
|
|
|
|
get 'metrics', action: :index
|
|
|
|
get 'metrics/system', action: :system
|
|
|
|
end
|
|
|
|
mount Peek::Railtie => '/peek', as: 'peek_routes'
|
2018-03-17 18:26:18 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
get 'runner_setup/platforms' => 'runner_setup#platforms'
|
2021-01-03 14:25:43 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
get 'acme-challenge/' => 'acme_challenges#show'
|
2021-04-17 20:07:23 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
scope :ide, as: :ide, format: false do
|
2021-04-17 20:07:23 +05:30
|
|
|
get '/', to: 'ide#index'
|
2022-08-13 15:12:31 +05:30
|
|
|
get '/project', to: 'ide#index'
|
|
|
|
|
|
|
|
scope path: 'project/:project_id', as: :project, constraints: { project_id: Gitlab::PathRegex.full_namespace_route_regex } do
|
|
|
|
%w[edit tree blob].each do |action|
|
|
|
|
get "/#{action}", to: 'ide#index'
|
|
|
|
get "/#{action}/*branch/-/*path", to: 'ide#index'
|
|
|
|
get "/#{action}/*branch/-", to: 'ide#index'
|
|
|
|
get "/#{action}/*branch", to: 'ide#index'
|
|
|
|
end
|
|
|
|
|
|
|
|
get '/merge_requests/:merge_request_id', to: 'ide#index', constraints: { merge_request_id: /\d+/ }
|
|
|
|
get '/', to: 'ide#index'
|
|
|
|
end
|
2023-03-04 22:38:38 +05:30
|
|
|
|
|
|
|
# Remote host can contain "." characters so it needs a constraint
|
|
|
|
post 'remote/:remote_host(/*remote_path)',
|
2023-06-20 00:43:36 +05:30
|
|
|
as: :remote,
|
|
|
|
to: 'web_ide/remote_ide#index',
|
|
|
|
constraints: { remote_host: %r{[^/?]+} }
|
2021-04-17 20:07:23 +05:30
|
|
|
end
|
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
draw :operations
|
|
|
|
draw :jira_connect
|
2018-12-13 13:39:08 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
Gitlab.ee do
|
2023-06-20 00:43:36 +05:30
|
|
|
draw :remote_development
|
2022-08-13 15:12:31 +05:30
|
|
|
draw :security
|
|
|
|
draw :smartcard
|
|
|
|
draw :trial
|
|
|
|
draw :trial_registration
|
|
|
|
draw :country
|
|
|
|
draw :country_state
|
|
|
|
draw :subscription
|
|
|
|
|
|
|
|
scope '/push_from_secondary/:geo_node_id' do
|
|
|
|
draw :git_http
|
|
|
|
end
|
2020-04-22 19:07:51 +05:30
|
|
|
end
|
2020-05-24 23:13:21 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
Gitlab.jh do
|
|
|
|
draw :global_jh
|
|
|
|
end
|
2021-09-30 23:02:18 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
if ENV['GITLAB_CHAOS_SECRET'] || Rails.env.development? || Rails.env.test?
|
|
|
|
resource :chaos, only: [] do
|
|
|
|
get :leakmem
|
|
|
|
get :cpu_spin
|
|
|
|
get :db_spin
|
|
|
|
get :sleep
|
|
|
|
get :kill
|
|
|
|
get :quit
|
|
|
|
post :gc
|
|
|
|
end
|
2019-09-30 21:07:59 +05:30
|
|
|
end
|
2020-04-08 14:13:33 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
resources :invites, only: [:show], constraints: { id: /[A-Za-z0-9_-]+/ } do
|
|
|
|
member do
|
|
|
|
post :accept
|
|
|
|
match :decline, via: [:get, :post]
|
|
|
|
end
|
2020-04-22 19:07:51 +05:30
|
|
|
end
|
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
resources :sent_notifications, only: [], constraints: { id: /\h{32}/ } do
|
|
|
|
member do
|
|
|
|
get :unsubscribe
|
|
|
|
end
|
2020-04-22 19:07:51 +05:30
|
|
|
end
|
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
# Spam reports
|
2023-07-07 10:43:13 +05:30
|
|
|
resources :abuse_reports, only: [:create] do
|
2023-03-17 16:20:25 +05:30
|
|
|
collection do
|
|
|
|
post :add_category
|
|
|
|
end
|
|
|
|
end
|
2020-04-22 19:07:51 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
# JWKS (JSON Web Key Set) endpoint
|
|
|
|
# Used by third parties to verify CI_JOB_JWT
|
|
|
|
get 'jwks' => 'jwks#index'
|
2020-07-28 23:09:34 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
draw :snippets
|
|
|
|
draw :profile
|
2022-07-23 23:45:48 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
post '/mailgun/webhooks' => 'mailgun/webhooks#process_webhook'
|
2022-07-23 23:45:48 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
# Deprecated route for permanent failures
|
|
|
|
# https://gitlab.com/gitlab-org/gitlab/-/issues/362606
|
|
|
|
post '/members/mailgun/permanent_failures' => 'mailgun/webhooks#process_webhook'
|
2023-06-20 00:43:36 +05:30
|
|
|
|
|
|
|
get '/timelogs' => 'time_tracking/timelogs#index'
|
2022-08-13 15:12:31 +05:30
|
|
|
end
|
|
|
|
# End of the /-/ scope.
|
2018-12-13 13:39:08 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
concern :clusterable do
|
|
|
|
resources :clusters, only: [:index, :show, :update, :destroy] do
|
2021-04-29 21:17:54 +05:30
|
|
|
collection do
|
2022-08-13 15:12:31 +05:30
|
|
|
get :connect
|
|
|
|
get :new_cluster_docs
|
|
|
|
post :create_user
|
2021-04-29 21:17:54 +05:30
|
|
|
end
|
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
resource :integration, controller: 'clusters/integrations', only: [] do
|
|
|
|
collection do
|
|
|
|
post :create_or_update
|
|
|
|
end
|
2019-09-30 21:07:59 +05:30
|
|
|
end
|
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
member do
|
|
|
|
Gitlab.ee do
|
|
|
|
get :metrics, format: :json
|
|
|
|
get :environments, format: :json
|
|
|
|
end
|
|
|
|
|
|
|
|
get :metrics_dashboard
|
|
|
|
get :'/prometheus/api/v1/*proxy_path', to: 'clusters#prometheus_proxy', as: :prometheus_api
|
|
|
|
get :cluster_status, format: :json
|
|
|
|
delete :clear_cache
|
|
|
|
end
|
2018-12-13 13:39:08 +05:30
|
|
|
end
|
|
|
|
end
|
2016-09-13 17:45:13 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
resources :groups, only: [:index, :new, :create] do
|
|
|
|
post :preview_markdown
|
|
|
|
end
|
2020-03-13 15:44:24 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
draw :group
|
|
|
|
|
|
|
|
resources :projects, only: [:index, :new, :create]
|
|
|
|
|
|
|
|
get '/projects/:id' => 'projects/redirect#redirect_from_id'
|
|
|
|
|
|
|
|
draw :git_http
|
|
|
|
draw :api
|
|
|
|
draw :customers_dot
|
|
|
|
draw :sidekiq
|
|
|
|
draw :help
|
|
|
|
draw :google_api
|
|
|
|
draw :import
|
|
|
|
draw :uploads
|
|
|
|
draw :explore
|
|
|
|
draw :admin
|
|
|
|
draw :dashboard
|
|
|
|
draw :user
|
|
|
|
draw :project
|
|
|
|
draw :unmatched_project
|
|
|
|
|
|
|
|
# Issue https://gitlab.com/gitlab-org/gitlab/-/issues/210024
|
|
|
|
scope as: 'deprecated' do
|
|
|
|
# Issue https://gitlab.com/gitlab-org/gitlab/-/issues/223719
|
|
|
|
get '/snippets/:id/raw',
|
|
|
|
to: 'snippets#raw',
|
|
|
|
format: false,
|
|
|
|
constraints: { id: /\d+/ }
|
|
|
|
|
|
|
|
Gitlab::Routing.redirect_legacy_paths(self, :snippets)
|
|
|
|
end
|
2020-07-28 23:09:34 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
Gitlab.ee do
|
|
|
|
get '/sitemap' => 'sitemap#show', format: :xml
|
|
|
|
end
|
2021-01-03 14:25:43 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
# Creates shorthand helper methods for project resources.
|
|
|
|
# For example; for the `namespace_project_path` this also creates `project_path`.
|
|
|
|
#
|
|
|
|
# TODO: We don't need the `Gitlab::Routing` module at all as we can use
|
|
|
|
# the `direct` DSL method of Rails to define url helpers. Move all the
|
|
|
|
# custom url helpers to use the `direct` DSL method and remove the `Gitlab::Routing`.
|
2023-04-23 21:23:45 +05:30
|
|
|
# For more information: https://gitlab.com/groups/gitlab-org/-/epics/9866
|
2022-08-13 15:12:31 +05:30
|
|
|
Gitlab::Application.routes.set.filter_map { |route| route.name if route.name&.include?('namespace_project') }.each do |name|
|
|
|
|
new_name = name.sub('namespace_project', 'project')
|
|
|
|
|
|
|
|
direct(new_name) do |project, *args|
|
|
|
|
# This is due to a bug I've found in Rails.
|
|
|
|
# For more information: https://gitlab.com/gitlab-org/gitlab/-/issues/299591
|
|
|
|
args.pop if args.last == {}
|
|
|
|
|
|
|
|
send("#{name}_url", project&.namespace, project, *args)
|
|
|
|
end
|
2021-03-11 19:13:27 +05:30
|
|
|
end
|
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
root to: "root#index"
|
2016-11-03 12:29:30 +05:30
|
|
|
|
2022-08-13 15:12:31 +05:30
|
|
|
get '*unmatched_route', to: 'application#route_not_found', format: false
|
2021-03-11 19:13:27 +05:30
|
|
|
|
2023-04-23 21:23:45 +05:30
|
|
|
# Load all custom URLs definitions via `direct' after the last route
|
|
|
|
# definition.
|
|
|
|
draw :directs
|
|
|
|
end
|
2022-08-13 15:12:31 +05:30
|
|
|
end
|