BigW Consortium Gitlab

application.rb 5.98 KB
Newer Older
gitlabhq committed
1 2 3
require File.expand_path('../boot', __FILE__)

require 'rails/all'
4

5
Bundler.require(:default, Rails.env)
gitlabhq committed
6 7 8

module Gitlab
  class Application < Rails::Application
9 10
    require_dependency Rails.root.join('lib/gitlab/redis')

gitlabhq committed
11 12 13 14
    # 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.

15 16 17 18 19 20 21 22 23
    # 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
    config.eager_load_paths.push(*%W(#{config.root}/lib
24
                                     #{config.root}/app/models/ci
25
                                     #{config.root}/app/models/hooks
26
                                     #{config.root}/app/models/members
27 28
                                     #{config.root}/app/models/project_services
                                     #{config.root}/app/workers/concerns))
gitlabhq committed
29

30 31
    config.generators.templates.push("#{config.root}/generator_templates")

gitlabhq committed
32 33 34 35 36 37 38
    # 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
39
    config.i18n.enforce_available_locales = false
gitlabhq committed
40 41 42 43 44

    # Configure the default encoding used in templates for Ruby 1.9.
    config.encoding = "utf-8"

    # Configure sensitive parameters which will be filtered from the log file.
45
    #
46 47 48 49 50 51 52 53
    # Parameters filtered:
    # - Password (:password, :password_confirmation)
    # - Private tokens (:private_token)
    # - Two-factor tokens (:otp_attempt)
    # - Repo/Project Import URLs (:import_url)
    # - Build variables (:variables)
    # - GitLab Pages SSL cert/key info (:certificate, :encrypted_key)
    # - Webhook URLs (:hook)
54
    # - GitLab-shell secret token (:secret_token)
55 56 57 58 59 60 61 62 63 64 65 66
    # - Sentry DSN (:sentry_dsn)
    # - Deploy keys (:key)
    config.filter_parameters += %i(
      certificate
      encrypted_key
      hook
      import_url
      key
      otp_attempt
      password
      password_confirmation
      private_token
67
      secret_token
68 69 70
      sentry_dsn
      variables
    )
gitlabhq committed
71

Riyad Preukschas committed
72 73 74 75 76 77 78 79
    # 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

gitlabhq committed
80 81
    # Enable the asset pipeline
    config.assets.enabled = true
82
    config.assets.paths << Gemojione.images_path
83
    config.assets.precompile << "*.png"
84
    config.assets.precompile << "print.css"
85
    config.assets.precompile << "notify.css"
86
    config.assets.precompile << "mailers/*.css"
87 88 89 90
    config.assets.precompile << "graphs/graphs_bundle.js"
    config.assets.precompile << "users/users_bundle.js"
    config.assets.precompile << "network/network_bundle.js"
    config.assets.precompile << "profile/profile_bundle.js"
91
    config.assets.precompile << "protected_branches/protected_branches_bundle.js"
92
    config.assets.precompile << "diff_notes/diff_notes_bundle.js"
93
    config.assets.precompile << "boards/boards_bundle.js"
94
    config.assets.precompile << "cycle_analytics/cycle_analytics_bundle.js"
Alfredo Sumaran committed
95
    config.assets.precompile << "merge_conflicts/merge_conflicts_bundle.js"
96
    config.assets.precompile << "boards/test_utils/simulate_drag.js"
97 98
    config.assets.precompile << "blob_edit/blob_edit_bundle.js"
    config.assets.precompile << "snippet/snippet_bundle.js"
99 100
    config.assets.precompile << "lib/utils/*.js"
    config.assets.precompile << "lib/*.js"
101
    config.assets.precompile << "u2f.js"
102

gitlabhq committed
103 104
    # Version of your assets, change this if you want to expire all your assets
    config.assets.version = '1.0'
105

106 107
    config.action_view.sanitized_allowed_protocols = %w(smb)

108
    config.middleware.insert_before Warden::Manager, Rack::Attack
109 110

    # Allow access to GitLab API from other domains
111
    config.middleware.insert_before Warden::Manager, Rack::Cors do
112 113 114 115 116 117 118 119 120 121
      allow do
        origins Gitlab.config.gitlab.url
        resource '/api/*',
          credentials: true,
          headers: :any,
          methods: :any,
          expose: ['Link']
      end

      # Cross-origin requests must not have the session cookie available
122 123
      allow do
        origins '*'
Fred Chasen committed
124
        resource '/api/*',
125
          credentials: false,
Fred Chasen committed
126
          headers: :any,
127
          methods: :any,
Fred Chasen committed
128
          expose: ['Link']
129 130
      end
    end
131

132 133
    # Use Redis caching across all environments
    redis_config_hash = Gitlab::Redis.params
134
    redis_config_hash[:namespace] = Gitlab::Redis::CACHE_NAMESPACE
135
    redis_config_hash[:expires_in] = 2.weeks # Cache should not grow forever
136 137 138 139
    if Sidekiq.server? # threaded context
      redis_config_hash[:pool_size] = Sidekiq.options[:concurrency] + 5
      redis_config_hash[:pool_timeout] = 1
    end
140
    config.cache_store = :redis_store, redis_config_hash
141

142 143 144 145
    config.active_record.raise_in_transactional_callbacks = true

    config.active_job.queue_adapter = :sidekiq

146 147
    # This is needed for gitlab-shell
    ENV['GITLAB_PATH_OUTSIDE_HOOK'] = ENV['PATH']
148 149 150 151

    config.generators do |g|
      g.factory_girl false
    end
gitlabhq committed
152 153
  end
end