application.rb 9.9 KB
Newer Older
L
Lin Jen-Shin 已提交
1
require File.expand_path('boot', __dir__)
G
gitlabhq 已提交
2 3

require 'rails/all'
4

5
Bundler.require(:default, Rails.env)
G
gitlabhq 已提交
6 7

module Gitlab
J
Jan Provaznik 已提交
8 9 10
  # This method is used for smooth upgrading from the current Rails 4.x to Rails 5.0.
  # https://gitlab.com/gitlab-org/gitlab-ce/issues/14286
  def self.rails5?
J
Jan Provaznik 已提交
11
    !%w[0 false].include?(ENV["RAILS5"])
J
Jan Provaznik 已提交
12 13
  end

G
gitlabhq 已提交
14
  class Application < Rails::Application
15
    require_dependency Rails.root.join('lib/gitlab/redis/wrapper')
16 17 18
    require_dependency Rails.root.join('lib/gitlab/redis/cache')
    require_dependency Rails.root.join('lib/gitlab/redis/queues')
    require_dependency Rails.root.join('lib/gitlab/redis/shared_state')
19
    require_dependency Rails.root.join('lib/gitlab/request_context')
20
    require_dependency Rails.root.join('lib/gitlab/current_settings')
21
    require_dependency Rails.root.join('lib/gitlab/middleware/read_only')
J
Jan Provaznik 已提交
22
    require_dependency Rails.root.join('lib/gitlab/middleware/basic_health_check')
23

J
Jan Provaznik 已提交
24 25 26 27 28
    # This needs to be loaded before DB connection is made
    # to make sure that all connections have NO_ZERO_DATE
    # setting disabled
    require_dependency Rails.root.join('lib/mysql_zero_date')

G
gitlabhq 已提交
29 30 31 32
    # Settings in config/environments/* take precedence over those specified here.
    # Application configuration should go into files in config/initializers
    # -- all .rb files in that directory are automatically loaded.

33 34 35 36 37 38 39 40
    # Sidekiq uses eager loading, but directories not in the standard Rails
    # directories must be added to the eager load paths:
    # https://github.com/mperham/sidekiq/wiki/FAQ#why-doesnt-sidekiq-autoload-my-rails-application-code
    # Also, there is no need to add `lib` to autoload_paths since autoloading is
    # configured to check for eager loaded paths:
    # https://github.com/rails/rails/blob/v4.2.6/railties/lib/rails/engine.rb#L687
    # This is a nice reference article on autoloading/eager loading:
    # http://blog.arkency.com/2014/11/dont-forget-about-eager-load-when-extending-autoload
L
Lin Jen-Shin 已提交
41
    config.eager_load_paths.push(*%W[#{config.root}/lib
42
                                     #{config.root}/app/models/badges
43
                                     #{config.root}/app/models/hooks
44
                                     #{config.root}/app/models/members
45
                                     #{config.root}/app/models/project_services
46
                                     #{config.root}/app/workers/concerns
47
                                     #{config.root}/app/policies/concerns
48
                                     #{config.root}/app/services/concerns
49
                                     #{config.root}/app/serializers/concerns
B
Bob Van Landuyt 已提交
50
                                     #{config.root}/app/finders/concerns
51 52
                                     #{config.root}/app/graphql/resolvers/concerns
                                     #{config.root}/app/graphql/mutations/concerns])
G
gitlabhq 已提交
53

54 55
    config.generators.templates.push("#{config.root}/generator_templates")

56 57 58 59
    # Rake tasks ignore the eager loading settings, so we need to set the
    # autoload paths explicitly
    config.autoload_paths = config.eager_load_paths.dup

G
gitlabhq 已提交
60 61 62 63 64 65 66
    # Only load the plugins named here, in the order given (default is alphabetical).
    # :all can be used as a placeholder for all plugins not explicitly named.
    # config.plugins = [ :exception_notification, :ssl_requirement, :all ]

    # The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
    # config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
    # config.i18n.default_locale = :de
67
    config.i18n.enforce_available_locales = false
G
gitlabhq 已提交
68

69 70 71
    # Translation for AR attrs is not working well for POROs like WikiPage
    config.gettext_i18n_rails.use_for_active_record_attributes = false

G
gitlabhq 已提交
72 73 74
    # Configure the default encoding used in templates for Ruby 1.9.
    config.encoding = "utf-8"

75 76 77 78 79
    # ActionCable mount point.
    # The default Rails' mount point is `/cable` which may conflict with existing
    # namespaces/users.
    # https://github.com/rails/rails/blob/5-0-stable/actioncable/lib/action_cable.rb#L38
    # Please change this value when configuring ActionCable for real usage.
80
    config.action_cable.mount_path = "/-/cable" if rails5?
81

G
gitlabhq 已提交
82
    # Configure sensitive parameters which will be filtered from the log file.
83
    #
84
    # Parameters filtered:
85
    # - Any parameter ending with `token`
86 87
    # - Any parameter containing `password`
    # - Any parameter containing `secret`
88
    # - Any parameter ending with `key`
89 90
    # - Two-factor tokens (:otp_attempt)
    # - Repo/Project Import URLs (:import_url)
91
    # - Build traces (:trace)
92 93 94 95
    # - Build variables (:variables)
    # - GitLab Pages SSL cert/key info (:certificate, :encrypted_key)
    # - Webhook URLs (:hook)
    # - Sentry DSN (:sentry_dsn)
96
    # - File content from Web Editor (:content)
97
    config.filter_parameters += [/token$/, /password/, /secret/, /key$/]
98 99 100 101 102 103 104
    config.filter_parameters += %i(
      certificate
      encrypted_key
      hook
      import_url
      otp_attempt
      sentry_dsn
105
      trace
106
      variables
107
      content
108
    )
G
gitlabhq 已提交
109

R
Riyad Preukschas 已提交
110 111 112 113 114 115 116 117
    # Enable escaping HTML in JSON.
    config.active_support.escape_html_entities_in_json = true

    # Use SQL instead of Active Record's schema dumper when creating the database.
    # This is necessary if your schema can't be completely dumped by the schema dumper,
    # like if you have constraints or database-specific column types
    # config.active_record.schema_format = :sql

118 119 120 121
    # Configure webpack
    config.webpack.config_file = "config/webpack.config.js"
    config.webpack.output_dir  = "public/assets/webpack"
    config.webpack.public_path = "assets/webpack"
122 123

    # Webpack dev server configuration is handled in initializers/static_files.rb
124
    config.webpack.dev_server.enabled = false
125

G
gitlabhq 已提交
126 127
    # Enable the asset pipeline
    config.assets.enabled = true
128

129 130
    # Support legacy unicode file named img emojis, `1F939.png`
    config.assets.paths << Gemojione.images_path
131 132
    config.assets.paths << "#{config.root}/vendor/assets/fonts"

133
    config.assets.precompile << "print.css"
D
Douwe Maan 已提交
134
    config.assets.precompile << "notify.css"
R
Robert Speicher 已提交
135
    config.assets.precompile << "mailers/*.css"
136
    config.assets.precompile << "page_bundles/ide.css"
F
Filipa Lacerda 已提交
137
    config.assets.precompile << "page_bundles/xterm.css"
138
    config.assets.precompile << "performance_bar.css"
139
    config.assets.precompile << "lib/ace.js"
140
    config.assets.precompile << "test.css"
H
haseeb 已提交
141
    config.assets.precompile << "snippets.css"
142
    config.assets.precompile << "locale/**/app.js"
T
Tim Zallmann 已提交
143
    config.assets.precompile << "emoji_sprites.css"
P
Paul Slaughter 已提交
144
    config.assets.precompile << "errors.css"
145

146
    # Import gitlab-svgs directly from vendored directory
147
    config.assets.paths << "#{config.root}/node_modules/@gitlab/svgs/dist"
148 149 150 151
    config.assets.precompile << "icons.svg"
    config.assets.precompile << "icons.json"
    config.assets.precompile << "illustrations/*.svg"

F
Filipa Lacerda 已提交
152 153
    # Import css for xterm
    config.assets.paths << "#{config.root}/node_modules/xterm/src/"
154 155
    config.assets.precompile << "xterm.css"

G
gitlabhq 已提交
156 157
    # Version of your assets, change this if you want to expire all your assets
    config.assets.version = '1.0'
158

159 160
    config.action_view.sanitized_allowed_protocols = %w(smb)

161 162 163
    # Nokogiri is significantly faster and uses less memory than REXML
    ActiveSupport::XmlMini.backend = 'Nokogiri'

164 165
    # This middleware needs to precede ActiveRecord::QueryCache and other middlewares that
    # connect to the database.
J
Jan Provaznik 已提交
166
    config.middleware.insert_after Rails::Rack::Logger, ::Gitlab::Middleware::BasicHealthCheck
167

M
Michael Kozono 已提交
168
    config.middleware.insert_after Warden::Manager, Rack::Attack
169 170

    # Allow access to GitLab API from other domains
171
    config.middleware.insert_before Warden::Manager, Rack::Cors do
172 173 174 175 176 177
      allow do
        origins Gitlab.config.gitlab.url
        resource '/api/*',
          credentials: true,
          headers: :any,
          methods: :any,
178
          expose: ['Link', 'X-Total', 'X-Total-Pages', 'X-Per-Page', 'X-Page', 'X-Next-Page', 'X-Prev-Page']
179 180 181
      end

      # Cross-origin requests must not have the session cookie available
182 183
      allow do
        origins '*'
F
Fred Chasen 已提交
184
        resource '/api/*',
185
          credentials: false,
F
Fred Chasen 已提交
186
          headers: :any,
187
          methods: :any,
188
          expose: ['Link', 'X-Total', 'X-Total-Pages', 'X-Per-Page', 'X-Page', 'X-Next-Page', 'X-Prev-Page']
189 190
      end
    end
191

192 193 194 195
    # Use caching across all environments
    caching_config_hash = Gitlab::Redis::Cache.params
    caching_config_hash[:namespace] = Gitlab::Redis::Cache::CACHE_NAMESPACE
    caching_config_hash[:expires_in] = 2.weeks # Cache should not grow forever
196
    if Sidekiq.server? # threaded context
197 198
      caching_config_hash[:pool_size] = Sidekiq.options[:concurrency] + 5
      caching_config_hash[:pool_timeout] = 1
199
    end
200

201
    config.cache_store = :redis_store, caching_config_hash
D
Dmitriy Zaporozhets 已提交
202

J
Jan Provaznik 已提交
203
    config.active_record.raise_in_transactional_callbacks = true unless rails5?
V
Valery Sizov 已提交
204 205 206

    config.active_job.queue_adapter = :sidekiq

D
Dmitriy Zaporozhets 已提交
207 208
    # This is needed for gitlab-shell
    ENV['GITLAB_PATH_OUTSIDE_HOOK'] = ENV['PATH']
209
    ENV['GIT_TERMINAL_PROMPT'] = '0'
210

211
    # GitLab Read-only middleware support
212
    config.middleware.insert_after ActionDispatch::Flash, ::Gitlab::Middleware::ReadOnly
T
Toon Claes 已提交
213

214
    config.generators do |g|
215
      g.factory_bot false
216
    end
217 218 219 220 221

    config.after_initialize do
      Rails.application.reload_routes!

      project_url_helpers = Module.new do
222 223 224
        extend ActiveSupport::Concern

        Gitlab::Application.routes.named_routes.helper_names.each do |name|
225 226 227
          next unless name.include?('namespace_project')

          define_method(name.sub('namespace_project', 'project')) do |project, *args|
L
Lin Jen-Shin 已提交
228
            send(name, project&.namespace, project, *args)
229 230 231 232
          end
        end
      end

233 234 235
      # We add the MilestonesRoutingHelper because we know that this does not
      # conflict with the methods defined in `project_url_helpers`, and we want
      # these methods available in the same places.
236
      Gitlab::Routing.add_helpers(project_url_helpers)
237
      Gitlab::Routing.add_helpers(MilestonesRoutingHelper)
238
    end
G
gitlabhq 已提交
239 240
  end
end