BigW Consortium Gitlab

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

require 'rails/all'
4
require 'devise'
5
I18n.config.enforce_available_locales = false
6
Bundler.require(:default, Rails.env)
gitlabhq committed
7 8 9 10 11 12 13 14

module Gitlab
  class Application < Rails::Application
    # 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.

    # Custom directories with classes and modules you want to be autoloadable.
15 16 17 18 19
    config.autoload_paths.push(*%W(#{config.root}/lib
                                   #{config.root}/app/models/hooks
                                   #{config.root}/app/models/concerns
                                   #{config.root}/app/models/project_services
                                   #{config.root}/app/models/members))
gitlabhq committed
20 21 22 23 24 25 26 27

    # 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
28
    config.i18n.enforce_available_locales = false
gitlabhq committed
29 30 31 32 33

    # 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.
34
    config.filter_parameters.push(:password, :password_confirmation, :private_token, :otp_attempt)
gitlabhq committed
35

Riyad Preukschas committed
36 37 38 39 40 41 42 43
    # 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
44 45
    # Enable the asset pipeline
    config.assets.enabled = true
46 47
    config.assets.paths << Emoji.images_path
    config.assets.precompile << "emoji/*.png"
48
    config.assets.precompile << "print.css"
49

gitlabhq committed
50 51
    # Version of your assets, change this if you want to expire all your assets
    config.assets.version = '1.0'
52

53 54
    config.action_view.sanitized_allowed_protocols = %w(smb)

55
    # Relative url support
56
    # Uncomment and customize the last line to run in a non-root path
Sytse Sijbrandij committed
57
    # WARNING: We recommend creating a FQDN to host GitLab in a root path instead of this.
58
    # Note that following settings need to be changed for this to work.
59 60
    # 1) In your application.rb file: config.relative_url_root = "/gitlab"
    # 2) In your gitlab.yml file: relative_url_root: /gitlab
61
    # 3) In your unicorn.rb: ENV['RAILS_RELATIVE_URL_ROOT'] = "/gitlab"
62
    # 4) In ../gitlab-shell/config.yml: gitlab_url: "http://127.0.0.1/gitlab"
63 64
    # 5) In lib/support/nginx/gitlab : do not use asset gzipping, remove block starting with "location ~ ^/(assets)/"
    #
65
    # To update the path, run: sudo -u git -H bundle exec rake assets:precompile RAILS_ENV=production
66 67
    #
    # config.relative_url_root = "/gitlab"
68

69
    config.middleware.use Rack::Attack
70 71 72 73 74

    # Allow access to GitLab API from other domains
    config.middleware.use Rack::Cors do
      allow do
        origins '*'
Fred Chasen committed
75 76 77 78
        resource '/api/*',
          headers: :any,
          methods: [:get, :post, :options, :put, :delete],
          expose: ['Link']
79 80
      end
    end
81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99

    # Use Redis caching across all environments
    redis_config_file = Rails.root.join('config', 'resque.yml')

    redis_url_string = if File.exists?(redis_config_file)
                         YAML.load_file(redis_config_file)[Rails.env]
                       else
                         "redis://localhost:6379"
                       end

    # Redis::Store does not handle Unix sockets well, so let's do it for them
    redis_config_hash = Redis::Store::Factory.extract_host_options_from_uri(redis_url_string)
    redis_uri = URI.parse(redis_url_string)
    if redis_uri.scheme == 'unix'
      redis_config_hash[:path] = redis_uri.path
    end

    redis_config_hash[:namespace] = 'cache:gitlab'
    config.cache_store = :redis_store, redis_config_hash
100 101 102

    # This is needed for gitlab-shell
    ENV['GITLAB_PATH_OUTSIDE_HOOK'] = ENV['PATH']
gitlabhq committed
103 104
  end
end