#-- copyright # OpenProject is a project management system. # Copyright (C) 2012-2015 the OpenProject Foundation (OPF) # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License version 3. # # OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows: # Copyright (C) 2006-2013 Jean-Philippe Lang # Copyright (C) 2010-2013 the ChiliProject Team # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License # as published by the Free Software Foundation; either version 2 # of the License, or (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. # # See doc/COPYRIGHT.rdoc for more details. #++ source 'https://rubygems.org' gem 'rails', '4.1.13' gem 'protected_attributes' gem 'actionpack-action_caching' gem 'activerecord-session_store' gem 'rails-observers' gem 'coderay', '~> 1.1.0' gem 'rubytree', '~> 0.8.3' gem 'rdoc', '>= 2.4.2' gem 'globalize', '~> 4.0.3' gem 'omniauth' gem 'request_store', '~> 1.1.0' gem 'gravatar_image_tag', '~> 1.2.0' gem 'warden', '~> 1.2' gem 'warden-basic_auth', '~> 0.2.1' # TODO: adds #auto_link which was deprecated in rails 3.1 gem 'rails_autolink', '~> 1.1.6' gem 'will_paginate', '~> 3.0' gem 'acts_as_list', '~> 0.3.0' gem 'friendly_id', '~> 5.1.0' gem 'awesome_nested_set', github: 'finnlabs/awesome_nested_set', branch: 'v2.1.6-rails4' gem 'color-tools', '~> 1.3.0', require: 'color' gem 'ruby-progressbar' # to generate html-diffs (e.g. for wiki comparison) gem 'htmldiff' # generates SVG Graphs # used for statistics on svn repositories gem 'svg-graph' gem 'date_validator', '~> 0.7.1' gem 'ruby-duration', '~> 3.2.0' # provide compatible filesystem information for available storage gem 'sys-filesystem', '~> 1.1.4', require: false # We rely on this specific version, which is the latest as of now (end of 2013), # because we have to apply to it a bugfix which could break things in other versions. # This can be removed as soon as said bugfix is integrated into rabl itself. # See: config/initializers/rabl_hack.rb gem 'rabl', '0.9.3' gem 'multi_json', '~> 1.11.0' gem 'oj', '~> 2.11.4' gem 'delayed_job_active_record', '~> 4.0.2' gem 'daemons' # include custom rack-protection for now until rkh/rack-protection is fixed and released # (see https://community.openproject.org/work_packages/3029) gem 'rack-protection', git: 'https://github.com/finnlabs/rack-protection.git', ref: '5a7d1bd' # Rack::Attack is a rack middleware to protect your web app from bad clients. # It allows whitelisting, blacklisting, throttling, and tracking based on arbitrary properties of the request. # https://github.com/kickstarter/rack-attack gem 'rack-attack' gem "syck", '~> 1.0.5', require: false gem 'gon', '~> 4.0' # catch exceptions and send them to any airbrake compatible backend # don't require by default, instead load on-demand when actually configured gem 'airbrake', '~> 4.1.0', require: false group :production do # we use dalli as standard memcache client # requires memcached 1.4+ # see https://github.com/mperham/dalli gem 'dalli', '~> 2.7.2' end gem 'sprockets', '~> 2.12.3' gem 'non-stupid-digest-assets' gem 'sass-rails', '~> 5.0.3' gem 'sass', '~> 3.4.12' gem 'autoprefixer-rails' gem 'execjs', '~> 2.4.0' gem 'bourbon', '~> 4.2.0' gem 'prototype-rails' # remove once we no longer use the deprecated "link_to_remote", "remote_form_for" and alike methods # replace those with :remote => true gem 'prototype_legacy_helper', '0.0.0', git: 'https://github.com/rails/prototype_legacy_helper.git' # small wrapper around the command line gem 'cocaine' # required by Procfile, for deployment on heroku or packaging with packager.io. # also, better than thin since we can control worker concurrency. gem 'unicorn' # Security fixes # Gems we don't depend directly on, but specify here to make sure we don't use a vulnerable # version. Please add a link to a security advisory when adding a Gem here. gem 'rack', '~> 1.5.4' # CVE-2015-3225 gem 'nokogiri', '~> 1.6.6' gem 'carrierwave', '~> 0.10.0' gem 'fog', '~> 1.23.0', require: 'fog/aws/storage' group :test do gem 'rack-test', '~> 0.6.2' gem 'shoulda-context', '~> 1.2' gem 'object-daddy', '~> 1.1.0' gem 'launchy', '~> 2.3.0' gem 'factory_girl_rails', '~> 4.5' gem 'cucumber-rails', '~> 1.4.2', require: false gem 'rack_session_access' gem 'database_cleaner', '~> 1.4.1' gem 'rspec', '~> 3.3.0' # also add to development group, so "spec" rake task gets loaded gem 'rspec-rails', '~> 3.3.0', group: :development gem 'rspec-activemodel-mocks' gem 'rspec-example_disabler', git: 'https://github.com/finnlabs/rspec-example_disabler.git' gem 'rspec-legacy_formatters' gem 'capybara', '~> 2.4.4' gem 'capybara-screenshot', '~> 1.0.4' gem 'capybara-select2', github: 'goodwill/capybara-select2' gem 'capybara-ng', '~> 0.2.1' gem 'selenium-webdriver', '~> 2.47.1' gem 'timecop', '~> 0.7.1' gem 'rb-readline', '~> 0.5.1' # ruby on CI needs this # why in Gemfile? see: https://github.com/guard/guard-test gem 'ruby-prof' gem 'simplecov', '0.8.0.pre' gem 'shoulda-matchers', '~> 2.8', require: nil gem 'json_spec' gem 'activerecord-tableless', '~> 1.0' gem 'codecov', require: nil gem 'equivalent-xml', '~> 0.5.1' end group :ldap do gem 'net-ldap', '~> 0.8.0' end group :development do gem 'letter_opener', '~> 1.3.0' gem 'thin' gem 'faker' gem 'quiet_assets' gem 'rubocop', '~> 0.32' end group :development, :test do gem 'pry-rails' gem 'pry-stack_explorer' gem 'pry-rescue' gem 'pry-byebug', platforms: [:mri] gem 'pry-doc' end # API gems gem 'grape', '~> 0.10.1' gem 'roar', '~> 1.0.0' gem 'reform', '~> 1.2.6', require: false # Use the commented pure ruby gems, if you have not the needed prerequisites on # board to compile the native ones. Note, that their use is discouraged, since # their integration is propbably not that well tested and their are slower in # orders of magnitude compared to their native counterparts. You have been # warned. platforms :mri, :mingw, :x64_mingw do group :mysql2 do gem 'mysql2', '~> 0.3.11' end group :postgres do gem 'pg', '~> 0.17.1' end end platforms :jruby do gem 'jruby-openssl' group :mysql do gem 'activerecord-jdbcmysql-adapter' end group :postgres do gem 'activerecord-jdbcpostgresql-adapter' end end group :opf_plugins do gem 'openproject-translations', git: 'https://github.com/opf/openproject-translations.git', branch: 'dev' end # Load Gemfile.local, Gemfile.plugins and plugins' Gemfiles Dir.glob File.expand_path('../{Gemfile.local,Gemfile.plugins,lib/plugins/*/Gemfile}', __FILE__) do |file| next unless File.readable?(file) eval_gemfile(file) end