X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/783b5e3729228908d7404ae7404af1023501a906..309bd95c571a672bed953ef1e77df6936b2c19f8:/Gemfile diff --git a/Gemfile b/Gemfile index c2bb066b7..277346b83 100644 --- a/Gemfile +++ b/Gemfile @@ -1,13 +1,8 @@ source "https://rubygems.org" # Require rails -gem "rails", "5.2.3" - -# Require things which have moved to gems in ruby 1.9 -gem "bigdecimal", "~> 1.1.0", :platforms => :ruby_19 - -# Require things which have moved to gems in ruby 2.0 -gem "psych", :platforms => :ruby_20 +gem "rails", "~> 7.2.0" +gem "turbo-rails" # Require json for multi_json gem "json" @@ -16,67 +11,84 @@ gem "json" gem "pg" # Use SCSS for stylesheets -gem "sassc-rails" - -# Use Uglifier as compressor for JavaScript assets -gem "uglifier", ">= 1.3.0" +gem "dartsass-sprockets" +# Pin the dependentent sass-embedded to avoid deprecation warnings in bootstrap +gem "sass-embedded", "~> 1.64.0" -# Use CoffeeScript for .js.coffee assets and views -gem "coffee-rails", "~> 4.2" +# Use Terser as compressor for JavaScript assets +gem "terser" # Use jquery as the JavaScript library gem "jquery-rails" # Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder -# gem 'jbuilder', '~> 2.0' -gem "jsonify-rails" +gem "jbuilder", "~> 2.7" # Reduces boot times through caching; required in config/boot.rb -gem "bootsnap", ">= 1.1.0", :require => false +gem "bootsnap", ">= 1.4.2", :require => false -# Use R2 for RTL conversion -gem "r2", "~> 0.2.7" +# Use rtlcss for RTL conversion +gem "mini_racer", "~> 0.9.0" +gem "rtlcss" # Use autoprefixer to generate CSS prefixes -gem "autoprefixer-rails", "~> 8.6.3" +gem "autoprefixer-rails" # Use image_optim to optimise images gem "image_optim_rails" +# Use argon2 for password hashing +gem "argon2" + +# Support brotli compression for assets +gem "sprockets-exporters_pack" + +# Restore File.exists? for oauth gem +gem "file_exists" + # Load rails plugins -gem "actionpack-page_caching" -gem "active_record_union" +gem "actionpack-page_caching", ">= 1.2.0" gem "activerecord-import" +gem "active_record_union" +gem "bootstrap", "~> 5.3.2" +gem "bootstrap_form", "~> 5.0" gem "cancancan" -gem "composite_primary_keys", "~> 11.1.0" gem "config" gem "delayed_job_active_record" -gem "dynamic_form" -gem "http_accept_language", "~> 2.0.0" -gem "i18n-js", ">= 3.0.0" -gem "oauth-plugin", ">= 0.5.1" -gem "openstreetmap-deadlock_retry", ">= 1.3.0", :require => "deadlock_retry" +gem "dry-validation" +gem "frozen_record" +gem "http_accept_language", "~> 2.1.1" +gem "i18n-js", "~> 3.9.2" +gem "openstreetmap-deadlock_retry", ">= 1.3.1", :require => "deadlock_retry" gem "rack-cors" -gem "rails-i18n", "~> 4.0.0" -gem "record_tag_helper" +gem "rails-i18n", "~> 7.0.0" +gem "rails_param" gem "rinku", ">= 2.0.6", :require => "rails_rinku" -gem "strong_migrations" +gem "strong_migrations", "< 2.0.0" gem "validates_email_format_of", ">= 1.5.1" # Native OSM extensions gem "quad_tile", "~> 1.0.1" # Sanitise URIs +gem "addressable", "~> 2.8" gem "rack-uri_sanitizer" # Omniauth for authentication -gem "omniauth" +gem "multi_json" +gem "omniauth", "~> 2.0.2" gem "omniauth-facebook" gem "omniauth-github" gem "omniauth-google-oauth2", ">= 0.6.0" gem "omniauth-mediawiki", ">= 0.0.4" +gem "omniauth-microsoft_graph" gem "omniauth-openid" -gem "omniauth-windowslive" +gem "omniauth-rails_csrf_protection", "~> 1.0" + +# Doorkeeper for OAuth2 +gem "doorkeeper" +gem "doorkeeper-i18n" +gem "doorkeeper-openid_connect" # Markdown formatting support gem "kramdown" @@ -91,25 +103,20 @@ gem "libxml-ruby", ">= 2.0.5", :require => "libxml" gem "htmlentities" gem "sanitize" -# Load SystemTimer for implementing request timeouts -gem "SystemTimer", ">= 1.1.3", :require => "system_timer", :platforms => :ruby_18 - # Load faraday for mockable HTTP client gem "faraday" -# Load geoip for querying Maxmind GeoIP database -gem "geoip" +# Load maxminddb for querying Maxmind GeoIP database +gem "maxminddb" # Load rotp to generate TOTP tokens gem "rotp" # Load memcache client in case we are using it +gem "connection_pool" gem "dalli" gem "kgio" -# Load secure_headers for Content-Security-Policy support -gem "secure_headers" - # Load canonical-rails to generate canonical URLs gem "canonical-rails" @@ -120,43 +127,65 @@ gem "logstasher" gem "bzip2-ffi" gem "ffi-libarchive" gem "gd2-ffij", ">= 0.4.0" -gem "mimemagic" +gem "marcel" # Used for browser detection -gem "browser" +gem "browser", "< 6" # for ruby 3.1 support # Used for S3 object storage gem "aws-sdk-s3" # Used to resize user images -gem "mini_magick" +gem "image_processing" + +# Used to validate widths +gem "unicode-display_width" + +# Lock some modules to old versions for ruby 3.1 support +gem "zeitwerk", "< 2.7" # Gems useful for development group :development do - gem "annotate" gem "better_errors" gem "binding_of_caller" + gem "danger" + gem "danger-auto_label" + gem "debug_inspector" + gem "i18n-tasks" gem "listen" + gem "overcommit" gem "vendorer" end # Gems needed for running tests group :test do - gem "fakefs", :require => "fakefs/safe" - gem "minitest", "~> 5.1", :platforms => [:ruby_19, :ruby_20] + gem "brakeman" + gem "capybara", ">= 2.15" + gem "erb_lint", :require => false + gem "factory_bot_rails" + gem "jwt" + gem "minitest", "~> 5.1" + gem "minitest-focus", :require => false + gem "puma", "~> 5.6" gem "rails-controller-testing" gem "rubocop" + gem "rubocop-capybara" + gem "rubocop-factory_bot" + gem "rubocop-minitest" gem "rubocop-performance" gem "rubocop-rails" + gem "rubocop-rake" + gem "selenium-webdriver" + gem "simplecov", :require => false + gem "simplecov-lcov", :require => false gem "webmock" end -# Needed in development as well so rake can see konacha tasks group :development, :test do - gem "capybara", "~> 2.13" - gem "coveralls", :require => false - gem "erb_lint", :require => false - gem "factory_bot_rails" - gem "poltergeist" - gem "puma", "~> 3.7" + gem "annotate" + gem "teaspoon" + gem "teaspoon-mocha", "~> 2.3.3" + + # See https://guides.rubyonrails.org/debugging_rails_applications.html#debugging-with-the-debug-gem + gem "debug", :require => "debug/prelude" end