at master 760 lines 32 kB view raw
1# frozen_string_literal: true 2 3def next? 4 File.basename(__FILE__) == "Gemfile.next" 5end 6 7source 'https://rubygems.org' 8 9if ENV.fetch('BUNDLER_CHECKSUM_VERIFICATION_OPT_IN', 'false') != 'false' # this verification is still experimental 10 $LOAD_PATH.unshift(File.expand_path("gems/bundler-checksum/lib", __dir__)) 11 require 'bundler-checksum' 12 BundlerChecksum.patch! 13end 14 15# Please see https://docs.gitlab.com/ee/development/feature_categorization/#gemfile 16ignore_feature_category = Module.new do 17 def gem(*arguments, feature_category: nil, **keyword_arguments) # rubocop:disable Lint/UnusedMethodArgument -- Ignoring feature_category intentionally 18 super(*arguments, **keyword_arguments) 19 end 20end 21 22extend ignore_feature_category 23 24gem 'bundler-checksum', '~> 0.1.0', path: 'gems/bundler-checksum', require: false, feature_category: :shared 25 26# See https://docs.gitlab.com/ee/development/gemfile.html#upgrade-rails for guidelines when upgrading Rails 27 28if next? 29 gem 'rails', '~> 7.2.2.2', feature_category: :shared 30else 31 gem 'rails', '~> 7.1.5.2', feature_category: :shared 32end 33 34gem 'activerecord-gitlab', path: 'gems/activerecord-gitlab', feature_category: :shared 35# This can be dropped after upgrading to Rails 7.2: https://github.com/rails/rails/pull/49674 36gem 'mutex_m', '~> 0.3', feature_category: :shared 37# Need by Rails 38gem 'drb', '~> 2.2', feature_category: :shared 39 40gem 'bootsnap', '~> 1.18.6', require: false, feature_category: :shared 41 42# Avoid the precompiled native gems because Omnibus needs to build this to ensure 43# LD_LIBRARY_PATH is correct: https://gitlab.com/gitlab-org/omnibus-gitlab/-/merge_requests/7730 44if RUBY_PLATFORM.include?('darwin') 45 gem 'ffi', '~> 1.17.2', feature_category: :shared 46else 47 gem 'ffi', '~> 1.17.2', force_ruby_platform: true, feature_category: :shared 48end 49 50gem 'openssl', '~> 3.0', feature_category: :shared 51 52gem 'gitlab-safe_request_store', path: 'gems/gitlab-safe_request_store', feature_category: :shared 53 54# GitLab Monorepo Gems 55group :monorepo do 56 gem 'gitlab-utils', path: 'gems/gitlab-utils', feature_category: :shared 57end 58 59gem 'gitlab-backup-cli', path: 'gems/gitlab-backup-cli', require: 'gitlab/backup/cli', feature_category: :backup_restore 60 61gem 'gitlab-secret_detection', '< 1.0', feature_category: :secret_detection 62 63# Responders respond_to and respond_with 64gem 'responders', '~> 3.0', feature_category: :shared 65 66gem 'sprockets', '~> 3.7.0', feature_category: :shared 67gem 'sprockets-rails', '~> 3.5.1', feature_category: :shared 68 69gem 'view_component', '~> 3.23.2', feature_category: :shared 70 71# Supported DBs 72gem 'pg', '~> 1.6.1', feature_category: :database 73 74gem 'rugged', '~> 1.6', feature_category: :gitaly 75 76gem 'faraday', '~> 2', feature_category: :shared 77gem 'faraday-retry', '~> 2', feature_category: :shared 78# Logger is a dependency of Faraday, but Logger 1.6.0 does not work with Chef. 79gem 'logger', '~> 1.7.0', feature_category: :shared 80 81gem 'marginalia', '~> 1.11.1', feature_category: :database 82 83# Authorization 84gem 'declarative_policy', '~> 2.0.1', feature_category: :shared 85 86# For source code paths mapping 87gem 'coverband', '6.1.5', require: false, feature_category: :shared 88 89# Authentication libraries 90gem 'devise', '~> 4.9.3', feature_category: :system_access 91gem 'devise-pbkdf2-encryptable', '~> 0.0.0', path: 'vendor/gems/devise-pbkdf2-encryptable', 92 feature_category: :system_access 93gem 'bcrypt', '~> 3.1', '>= 3.1.14', feature_category: :system_access 94gem 'doorkeeper', '~> 5.8', '>= 5.8.1', feature_category: :system_access 95gem 'doorkeeper-openid_connect', '~> 1.8.10', feature_category: :system_access 96gem 'doorkeeper-device_authorization_grant', '~> 1.0.0', feature_category: :system_access 97gem 'rexml', '~> 3.4.0', feature_category: :shared 98gem 'ruby-saml', '~> 1.18', feature_category: :system_access 99gem 'omniauth-saml', '~> 2.2.1', feature_category: :system_access 100gem 'omniauth', '~> 2.1.0', feature_category: :system_access 101gem 'omniauth-auth0', '~> 3.1', feature_category: :system_access 102gem 'omniauth-azure-activedirectory-v2', '~> 2.0', feature_category: :system_access 103gem 'omniauth-alicloud', '~> 3.0.0', feature_category: :system_access 104gem 'omniauth-github', '2.0.1', feature_category: :system_access 105# See vendor/gems/omniauth-gitlab/README.md 106gem 'omniauth-gitlab', '~> 4.0.0', path: 'vendor/gems/omniauth-gitlab', feature_category: :system_access 107gem 'omniauth-google-oauth2', '~> 1.1', feature_category: :system_access 108gem 'omniauth-oauth2-generic', '~> 0.2.2', feature_category: :system_access 109gem 'omniauth-shibboleth-redux', '~> 2.0', require: 'omniauth-shibboleth', feature_category: :system_access 110# See vendor/gems/omniauth_crowd/README.md 111gem 'omniauth_crowd', '~> 2.4.0', path: 'vendor/gems/omniauth_crowd', feature_category: :system_access 112gem 'omniauth_openid_connect', '~> 0.8.0', feature_category: :system_access 113# Locked until Ruby 3.0 upgrade since upgrading will pull in an updated net-smtp gem. 114# See https://docs.gitlab.com/ee/development/emails.html#rationale. 115gem 'openid_connect', '~> 2.3.0', feature_category: :system_access 116# See gem README.md 117gem 'omniauth-salesforce', '~> 1.0.5', path: 'vendor/gems/omniauth-salesforce', feature_category: :system_access 118gem 'omniauth-atlassian-oauth2', '~> 0.2.0', feature_category: :system_access 119gem 'rack-oauth2', '~> 2.2.1', feature_category: :system_access 120gem 'jwt', '~> 2.10.0', feature_category: :system_access 121 122# Kerberos authentication. EE-only 123gem 'gssapi', '~> 1.3.1', group: :kerberos, feature_category: :system_access 124gem 'timfel-krb5-auth', '~> 0.8', group: :kerberos, feature_category: :system_access 125 126# Spam and anti-bot protection 127gem 'recaptcha', '~> 5.12', require: 'recaptcha/rails', feature_category: :insider_threat 128gem 'akismet', '~> 3.0', feature_category: :insider_threat 129gem 'invisible_captcha', '~> 2.3.0', feature_category: :insider_threat 130 131# Two-factor authentication 132gem 'devise-two-factor', '~> 4.1.1', feature_category: :system_access 133gem 'rqrcode', '~> 2.2', feature_category: :system_access 134 135gem 'attr_encrypted', '~> 4.2', feature_category: :shared 136 137# GitLab Pages 138gem 'validates_hostname', '~> 1.0.13', feature_category: :pages 139gem 'rubyzip', '~> 2.4.0', require: 'zip', feature_category: :pages 140# GitLab Pages letsencrypt support 141gem 'acme-client', '~> 2.0.19', feature_category: :pages 142 143# Browser detection 144gem 'browser', '~> 5.3.1', feature_category: :shared 145 146# OS detection for usage ping 147gem 'ohai', '~> 18.1', feature_category: :product_analytics 148 149# GPG 150gem 'gpgme', '~> 2.0.24', feature_category: :source_code_management 151 152# LDAP Auth 153# GitLab fork with several improvements to original library. For full list of changes 154# see https://github.com/intridea/omniauth-ldap/compare/master...gitlabhq:master 155gem 'gitlab_omniauth-ldap', '~> 2.3.0', require: 'omniauth-ldap', feature_category: :system_access 156gem 'net-ldap', '~> 0.17.1', feature_category: :system_access 157 158# API 159gem 'grape', '~> 2.0.0', feature_category: :api 160gem 'grape-entity', '~> 1.0.1', feature_category: :api 161gem 'grape-swagger', '~> 2.1.2', group: [:development, :test], feature_category: :api 162gem 'grape-swagger-entity', '~> 0.5.5', group: [:development, :test], feature_category: :api 163gem 'grape-path-helpers', '~> 2.0.1', feature_category: :api 164gem 'rack-cors', '~> 2.0.1', require: 'rack/cors', feature_category: :shared 165 166# GraphQL API 167gem 'graphql', '2.5.11', feature_category: :api 168gem 'graphql-docs', '~> 5.2.0', group: [:development, :test], feature_category: :api 169gem 'apollo_upload_server', '~> 2.1.6', feature_category: :api 170 171# Cells 172gem 'gitlab-topology-service-client', '~> 0.1', 173 path: 'vendor/gems/gitlab-topology-service-client', 174 require: 'gitlab/cells/topology_service', 175 feature_category: :cell 176 177# Duo Workflow 178gem 'gitlab-duo-workflow-service-client', '~> 0.3', 179 path: 'vendor/gems/gitlab-duo-workflow-service-client', 180 feature_category: :agent_foundations 181 182# Generate Fake data 183gem 'ffaker', '~> 2.24', feature_category: :shared 184 185gem 'hashie', '~> 5.0.0', feature_category: :shared 186 187# Pagination 188gem 'kaminari', '~> 1.2.2', feature_category: :shared 189 190# HAML 191gem 'hamlit', '~> 3.0.0', feature_category: :shared 192 193# Files attachments 194gem 'carrierwave', '~> 1.3', feature_category: :shared 195gem 'mini_magick', '~> 4.12', feature_category: :shared 196gem 'marcel', '~> 1.0.4', feature_category: :shared 197 198# PDF generation 199gem 'prawn', feature_category: :vulnerability_management 200gem 'prawn-svg', feature_category: :vulnerability_management 201 202# for backups 203gem 'fog-aws', '~> 3.26', feature_category: :shared 204gem 'fog-core', '~> 2.5', feature_category: :shared 205gem 'fog-google', '~> 1.25', require: 'fog/google', feature_category: :shared 206gem 'fog-local', '~> 0.8', feature_category: :shared 207# NOTE: 208# the fog-aliyun gem since v0.4 pulls in aliyun-sdk transitively, which monkey-patches 209# the rest-client gem to drop the Content-Length header field for chunked transfers, 210# which may have knock-on effects on other features using `RestClient`. 211# We may want to update this dependency if this is ever addressed upstream, e.g. via 212# https://github.com/aliyun/aliyun-oss-ruby-sdk/pull/93 213gem 'fog-aliyun', '~> 0.4', feature_category: :shared 214gem 'gitlab-fog-azure-rm', '~> 2.3.0', require: 'fog/azurerm', feature_category: :shared 215 216# for Google storage 217 218# Need this specific version of google-apis-storage_v1 so that fog-google will utilize the updated list_objects with 219# match_glob support in google-apis-core 0.11.1. Because of this we also have to bump google-cloud-storage to 1.45.0. 220gem 'google-apis-storage_v1', '~> 0.29', feature_category: :shared 221gem 'google-cloud-storage', '~> 1.57.0', feature_category: :shared 222# We need >= 0.11.1 because that's when match_glob support is added to list_objects 223gem 'google-apis-core', '~> 0.18.0', '>= 0.18.0', feature_category: :shared 224gem 'google-apis-compute_v1', '~> 0.129.0', feature_category: :shared 225gem 'google-apis-container_v1', '~> 0.100.0', feature_category: :shared 226gem 'google-apis-container_v1beta1', '~> 0.90.0', feature_category: :shared 227gem 'google-apis-cloudbilling_v1', '~> 0.22.0', feature_category: :shared 228gem 'google-apis-cloudresourcemanager_v1', '~> 0.31.0', feature_category: :shared 229gem 'google-apis-iam_v1', '~> 0.73.0', feature_category: :shared 230gem 'google-apis-serviceusage_v1', '~> 0.28.0', feature_category: :shared 231gem 'google-apis-sqladmin_v1beta4', '~> 0.41.0', feature_category: :shared 232gem 'google-apis-androidpublisher_v3', '~> 0.86.0', feature_category: :shared 233 234gem 'googleauth', '~> 1.14', feature_category: :shared 235gem 'google-cloud-artifact_registry-v1', '~> 0.11.0', feature_category: :shared 236gem 'google-cloud-compute-v1', '~> 2.6.0', feature_category: :shared 237 238# Seed data 239gem 'seed-fu', '~> 2.3.7', feature_category: :shared 240 241# Search 242gem 'elasticsearch-model', '~> 7.2', feature_category: :global_search 243gem 'elasticsearch-rails', '~> 7.2', require: 'elasticsearch/rails/instrumentation', feature_category: :global_search 244gem 'elasticsearch-api', '7.17.11', feature_category: :global_search 245gem 'aws-sdk-core', '~> 3.226.0', feature_category: :global_search 246gem 'aws-sdk-cloudformation', '~> 1', feature_category: :global_search 247gem 'aws-sdk-s3', '~> 1.193.0', feature_category: :global_search 248gem 'faraday-typhoeus', '~> 1.1', feature_category: :global_search 249gem 'faraday_middleware-aws-sigv4', '~> 1.0.1', feature_category: :global_search 250# Used with Elasticsearch to support http keep-alive connections 251gem 'typhoeus', '~> 1.4.0', feature_category: :global_search 252 253gem 'gitlab-active-context', path: 'gems/gitlab-active-context', require: 'active_context', 254 feature_category: :global_search 255 256# Markdown and HTML processing 257gem 'html-pipeline', '~> 2.14.3', feature_category: :markdown 258gem 'deckar01-task_list', '2.3.4', feature_category: :markdown 259gem 'gitlab-markup', '~> 2.0.0', require: 'github/markup', feature_category: :markdown 260gem 'commonmarker', '~> 0.23.10', feature_category: :markdown 261gem 'kramdown', '~> 2.5.0', feature_category: :markdown 262gem 'RedCloth', '~> 4.3.3', feature_category: :markdown 263gem 'org-ruby', '~> 0.9.12', feature_category: :markdown 264gem 'creole', '~> 0.5.0', feature_category: :markdown 265gem 'wikicloth', '0.8.1', feature_category: :markdown 266gem 'asciidoctor', '~> 2.0.18', feature_category: :markdown 267gem 'asciidoctor-include-ext', '~> 0.4.0', require: false, feature_category: :markdown 268gem 'asciidoctor-plantuml', '~> 0.0.16', feature_category: :markdown 269gem 'asciidoctor-kroki', '~> 0.10.0', require: false, feature_category: :markdown 270gem 'rouge', '~> 4.6.0', feature_category: :shared 271gem 'truncato', '~> 0.7.13', feature_category: :team_planning 272gem 'nokogiri', '~> 1.18', feature_category: :shared 273gem 'gitlab-glfm-markdown', '~> 0.0.33', feature_category: :markdown 274gem 'tanuki_emoji', '~> 0.13', feature_category: :markdown 275gem 'unicode-emoji', '~> 4.0', feature_category: :markdown 276 277# Calendar rendering 278gem 'icalendar', '~> 2.10.1', feature_category: :team_planning 279 280# Diffs 281gem 'diffy', '~> 3.4', feature_category: :shared 282gem 'diff_match_patch', '~> 0.1.0', path: 'vendor/gems/diff_match_patch', feature_category: :team_planning 283 284# Application server 285gem 'rack', '~> 2.2.9', feature_category: :shared 286# https://github.com/zombocom/rack-timeout/blob/master/README.md#rails-apps-manually 287gem 'rack-timeout', '~> 0.7.0', require: 'rack/timeout/base', feature_category: :shared 288 289group :puma do 290 gem 'puma', '= 6.6.1', require: false, feature_category: :shared 291 gem 'sd_notify', '~> 0.1.0', require: false, feature_category: :shared 292end 293 294# State machine 295gem 'state_machines-activerecord', '~> 0.8.0', feature_category: :shared 296 297# Background jobs 298gem 'sidekiq', '~> 7.3.9', feature_category: :scalability 299gem 'sidekiq-cron', '~> 1.12.0', feature_category: :scalability 300gem 'gitlab-sidekiq-fetcher', 301 path: 'vendor/gems/sidekiq-reliable-fetch', 302 require: 'sidekiq-reliable-fetch', 303 feature_category: :scalability 304 305# Cron Parser 306gem 'fugit', '~> 1.11.1', feature_category: :continuous_integration 307 308# HTTP requests 309gem 'httparty', '~> 0.23.0', feature_category: :shared 310 311# Colored output to console 312gem 'rainbow', '~> 3.0', feature_category: :shared 313 314# Progress bar 315gem 'ruby-progressbar', '~> 1.10', feature_category: :shared 316 317# Linear-time regex library for untrusted regular expressions 318gem 're2', '~> 2.15', feature_category: :shared 319 320# Misc 321 322gem 'semver_dialects', '~> 3.7', feature_category: :software_composition_analysis 323gem 'version_sorter', '~> 2.3', feature_category: :shared 324gem 'csv_builder', path: 'gems/csv_builder', feature_category: :shared 325 326# Export Ruby Regex to Javascript 327gem 'js_regex', '~> 3.8', feature_category: :shared 328 329# User agent parsing 330gem 'device_detector', feature_category: :shared 331 332# Redis 333gem 'redis', '~> 5.4.0', feature_category: :redis 334gem 'redis-client', '~> 0.25', feature_category: :redis 335gem 'redis-cluster-client', '~> 0.13', feature_category: :redis 336gem 'redis-clustering', '~> 5.4.0', feature_category: :redis 337gem 'connection_pool', '~> 2.5.3', feature_category: :shared 338 339# Redis session store 340gem 'redis-actionpack', '~> 5.5.0', feature_category: :redis 341 342# Jira integration 343gem 'jira-ruby', '~> 2.3.0', feature_category: :integrations 344gem 'atlassian-jwt', '~> 0.2.1', feature_category: :integrations 345 346# Slack integration 347gem 'slack-messenger', '~> 2.3.5', feature_category: :integrations 348 349# Kubernetes integration 350gem 'kubeclient', '~> 4.12.0', feature_category: :shared 351 352# AI 353gem 'circuitbox', '2.0.0', feature_category: :shared 354 355# Sanitize user input 356gem 'sanitize', '~> 6.0.2', feature_category: :shared 357gem 'babosa', '~> 2.0', feature_category: :shared 358 359# Sanitizes SVG input 360gem 'loofah', '~> 2.24.0', feature_category: :shared 361 362# Used to provide license templates 363gem 'licensee', '~> 9.16', feature_category: :shared 364 365# Detect and convert string character encoding 366gem 'charlock_holmes', '~> 0.7.9', feature_category: :shared 367 368# Detect mime content type from content 369gem 'ruby-magic', '~> 0.6', feature_category: :shared 370 371# Faster blank 372gem 'fast_blank', '~> 1.0.1', feature_category: :shared 373 374# Parse time & duration 375gem 'gitlab-chronic', '~> 0.10.5', feature_category: :shared 376gem 'gitlab_chronic_duration', '~> 0.12', feature_category: :shared 377 378gem 'rack-proxy', '~> 0.7.7', feature_category: :shared 379 380gem 'cssbundling-rails', '1.4.3', feature_category: :shared 381gem 'terser', '1.0.2', feature_category: :shared 382 383gem 'click_house-client', '0.5.1', feature_category: :database 384gem 'addressable', '~> 2.8', feature_category: :shared 385gem 'gon', '~> 6.5.0', feature_category: :shared 386gem 'request_store', '~> 1.7.0', feature_category: :shared 387gem 'base32', '~> 0.3.0', feature_category: :shared 388gem 'gitlab-license', '~> 2.6', feature_category: :shared 389 390# Protect against bruteforcing 391gem 'rack-attack', '~> 6.7.0', feature_category: :shared 392 393# Sentry integration 394gem 'sentry-ruby', '~> 5.23.0', feature_category: :observability 395gem 'sentry-rails', '~> 5.23.0', feature_category: :observability 396gem 'sentry-sidekiq', '~> 5.23.0', feature_category: :observability 397 398# PostgreSQL query parsing 399# 400gem 'pg_query', '~> 6.1.0', feature_category: :database 401 402gem 'gitlab-schema-validation', path: 'gems/gitlab-schema-validation', feature_category: :shared 403gem 'gitlab-http', path: 'gems/gitlab-http', feature_category: :shared 404 405gem 'premailer-rails', '~> 1.12.0', feature_category: :notifications 406gem 'gitlab-labkit', '~> 0.40.0', feature_category: :shared 407gem 'thrift', '~> 0.22.0', feature_category: :shared 408 409# I18n 410gem 'rails-i18n', '~> 7.0', '>= 7.0.9', feature_category: :internationalization 411gem 'gettext_i18n_rails', '~> 1.13.0', feature_category: :internationalization 412gem 'gettext', '~> 3.5', '>= 3.5.1', 413 require: false, 414 group: [:development, :test], 415 feature_category: :internationalization 416 417gem 'batch-loader', '~> 2.0.5', feature_category: :shared 418 419gem 'tty-prompt', '~> 0.23', require: false, feature_category: :shared 420 421# Perf bar 422gem 'peek', '~> 1.1', feature_category: :shared 423 424# Snowplow events trackin 425gem 'snowplow-tracker', '~> 0.8.0', feature_category: :product_analytics 426 427# Metrics 428gem 'webrick', '~> 1.9.0', require: false, feature_category: :shared 429gem 'prometheus-client-mmap', '~> 1.2.9', require: 'prometheus/client', feature_category: :shared 430 431# Event-driven reactor for Ruby 432# Required manually in config/initializers/require_async_gem 433gem 'async', '~> 2.28.0', require: false, feature_category: :shared 434gem 'io-event', '~> 1.12', require: false, feature_category: :shared 435 436# Security report schemas used to validate CI job artifacts of security jobs 437gem 'gitlab-security_report_schemas', '0.1.3.min15.0.0.max15.2.3', feature_category: :vulnerability_management 438 439# Frontend bundling 440gem 'vite_rails', '~> 3.0.17', feature_category: :shared 441gem 'vite_ruby', '~> 3.9.0', feature_category: :shared 442 443# OpenTelemetry 444group :opentelemetry do 445 # Core OpenTelemetry gems 446 gem 'opentelemetry-sdk', feature_category: :observability 447 gem 'opentelemetry-exporter-otlp', feature_category: :observability 448 449 # OpenTelemetry gems selected from full set in `opentelemetry-instrumentation-all` metagem 450 gem 'opentelemetry-instrumentation-active_support', feature_category: :observability 451 gem 'opentelemetry-instrumentation-action_pack', feature_category: :observability 452 gem 'opentelemetry-instrumentation-active_job', feature_category: :observability 453 gem 'opentelemetry-instrumentation-active_record', feature_category: :observability 454 gem 'opentelemetry-instrumentation-action_view', feature_category: :observability 455 gem 'opentelemetry-instrumentation-aws_sdk', feature_category: :observability 456 gem 'opentelemetry-instrumentation-http', feature_category: :observability 457 gem 'opentelemetry-instrumentation-concurrent_ruby', feature_category: :observability 458 gem 'opentelemetry-instrumentation-ethon', feature_category: :observability 459 gem 'opentelemetry-instrumentation-excon', feature_category: :observability 460 gem 'opentelemetry-instrumentation-faraday', feature_category: :observability 461 gem 'opentelemetry-instrumentation-grape', feature_category: :observability 462 gem 'opentelemetry-instrumentation-graphql', feature_category: :observability 463 gem 'opentelemetry-instrumentation-http_client', feature_category: :observability 464 gem 'opentelemetry-instrumentation-net_http', feature_category: :observability 465 gem 'opentelemetry-instrumentation-pg', feature_category: :observability 466 gem 'opentelemetry-instrumentation-rack', feature_category: :observability 467 gem 'opentelemetry-instrumentation-rails', feature_category: :observability 468 gem 'opentelemetry-instrumentation-rake', feature_category: :observability 469 gem 'opentelemetry-instrumentation-redis', feature_category: :observability 470 gem 'opentelemetry-instrumentation-sidekiq', feature_category: :observability 471end 472 473gem 'warning', '~> 1.5.0', feature_category: :shared 474 475group :development do 476 gem 'lefthook', '~> 1.12.0', require: false, feature_category: :tooling 477 gem 'rubocop', feature_category: :tooling, require: false 478 gem 'debug', '~> 1.11.0', feature_category: :shared 479 480 gem 'solargraph', '~> 0.54.0', require: false, feature_category: :shared 481 gem 'solargraph-rspec', '~> 0.5.1', require: false, feature_category: :shared 482 483 gem 'letter_opener_web', '~> 3.0.0', feature_category: :shared 484 gem 'lookbook', '~> 2.3', feature_category: :shared 485 486 # Better errors handler 487 gem 'better_errors', '~> 2.10.1', feature_category: :shared 488 489 gem 'sprite-factory', '~> 1.7', feature_category: :shared 490 491 gem 'listen', '~> 3.7', feature_category: :shared 492 493 gem 'ruby-lsp', "~> 0.23.0", require: false, feature_category: :tooling 494 495 gem 'ruby-lsp-rails', "~> 0.3.6", feature_category: :tooling 496 497 gem 'ruby-lsp-rspec', "~> 0.1.10", require: false, feature_category: :tooling 498 499 gem 'gdk-toogle', '~> 0.9', '>= 0.9.5', require: 'toogle', feature_category: :tooling 500 501 # Used by 502 # * `lib/tasks/gitlab/security/update_banned_ssh_keys.rake` 503 # * `lib/tasks/gitlab/db/migration_squash.rake` 504 gem 'git', '~> 1.8', feature_category: :shared 505end 506 507group :development, :test do 508 gem 'deprecation_toolkit', '~> 2.2.3', require: false, feature_category: :shared 509 gem 'bullet', '~> 8.0.0', feature_category: :shared 510 gem 'parser', '= 3.3.9.0', feature_category: :shared 511 gem 'pry-byebug', feature_category: :shared 512 gem 'pry-rails', '~> 0.3.9', feature_category: :shared 513 gem 'pry-shell', '~> 0.6.4', feature_category: :shared 514 515 gem 'awesome_print', require: false, feature_category: :shared 516 517 gem 'database_cleaner-active_record', '~> 2.2.0', feature_category: :database 518 gem 'rspec-rails', '~> 7.1.0', feature_category: :shared 519 gem 'factory_bot_rails', '~> 6.5.0', feature_category: :tooling 520 521 # Prevent occasions where minitest is not bundled in packaged versions of ruby (see #3826) 522 gem 'minitest', '~> 5.11.0', feature_category: :shared 523 524 gem 'spring', '~> 4.3.0', feature_category: :shared 525 gem 'spring-commands-rspec', '~> 1.0.4', feature_category: :shared 526 527 gem 'gitlab-styles', '~> 13.1.0', feature_category: :tooling, require: false 528 gem 'haml_lint', '~> 0.58', feature_category: :tooling, require: false 529 530 # Benchmarking & profiling 531 gem 'benchmark-ips', '~> 2.14.0', require: false, feature_category: :shared 532 gem 'benchmark-memory', '~> 0.1', require: false, feature_category: :shared 533 534 gem 'knapsack', '~> 4.0.0', feature_category: :tooling 535 gem 'gitlab-crystalball', '~> 1.1.0', require: false, feature_category: :tooling 536 gem 'test_file_finder', '~> 0.3.1', feature_category: :tooling 537 538 gem 'simple_po_parser', '~> 1.1.6', require: false, feature_category: :shared 539 540 gem 'png_quantizator', '~> 0.2.1', require: false, feature_category: :shared 541 542 gem 'parallel', '~> 1.19', require: false, feature_category: :shared 543 544 gem 'sigdump', '~> 0.2.4', require: 'sigdump/setup', feature_category: :shared 545 546 gem 'pact', '~> 1.64', feature_category: :shared 547 548 gem 'gitlab-housekeeper', path: 'gems/gitlab-housekeeper', feature_category: :tooling 549 550 gem 'yard', '~> 0.9', require: false, feature_category: :tooling 551end 552 553group :development, :test, :danger do 554 gem 'gitlab-dangerfiles', '~> 4.10.0', require: false, feature_category: :tooling 555end 556 557group :development, :test, :coverage do 558 gem 'simplecov', '~> 0.22', require: false, feature_category: :tooling 559 gem 'simplecov-lcov', '~> 0.8.0', require: false, feature_category: :tooling 560 gem 'simplecov-cobertura', '~> 2.1.0', require: false, feature_category: :tooling 561 gem 'undercover', '~> 0.7.0', require: false, feature_category: :tooling 562end 563 564# Gems required in omnibus-gitlab pipeline 565group :development, :test, :omnibus do 566 gem 'license_finder', '~> 7.0', require: false, feature_category: :shared 567end 568 569# Gems required in various pipelines 570group :development, :test, :monorepo do 571 gem 'gitlab-rspec', path: 'gems/gitlab-rspec', feature_category: :shared 572 gem 'gitlab-rspec_flaky', path: 'gems/gitlab-rspec_flaky', feature_category: :tooling 573end 574 575group :test do 576 gem 'rspec-retry', '~> 0.6.2', feature_category: :tooling 577 gem 'rspec_profiling', '~> 0.0.9', feature_category: :tooling 578 gem 'rspec-benchmark', '~> 0.6.0', feature_category: :tooling 579 gem 'rspec-parameterized', '~> 1.0', '>= 1.0.2', require: false, feature_category: :tooling 580 gem 'os', '~> 1.1', '>= 1.1.4', feature_category: :tooling 581 582 gem 'capybara', '~> 3.40', feature_category: :test_platform 583 gem 'capybara-screenshot', '~> 1.0.26', feature_category: :test_platform 584 gem 'selenium-webdriver', '~> 4.21', '>= 4.21.1', feature_category: :test_platform 585 586 gem 'graphlyte', '~> 1.0.0', feature_category: :shared 587 588 # Upload CI metrics to a GCP BigQuery instance 589 # 590 # We only use this gem in CI. 591 gem 'google-cloud-bigquery', '~> 1.0', feature_category: :tooling 592 593 gem 'shoulda-matchers', '~> 6.4.0', require: false, feature_category: :shared 594 gem 'email_spec', '~> 2.3.0', feature_category: :shared 595 gem 'webmock', '~> 3.25.0', feature_category: :shared 596 gem 'rails-controller-testing', feature_category: :shared 597 gem 'concurrent-ruby', '~> 1.1', feature_category: :shared 598 gem 'test-prof', '~> 1.4.0', feature_category: :tooling 599 gem 'rspec_junit_formatter', feature_category: :shared 600 gem 'guard-rspec', feature_category: :shared 601 gem 'axe-core-rspec', '~> 4.10.0', feature_category: :tooling 602 gem 'state_machines-rspec', '~> 0.6', feature_category: :shared 603 604 # Moved in `test` because https://gitlab.com/gitlab-org/gitlab/-/issues/217527 605 gem 'derailed_benchmarks', require: false, feature_category: :shared 606 607 gem 'gitlab_quality-test_tooling', '~> 2.20.0', require: false, feature_category: :tooling 608end 609 610gem 'octokit', '~> 9.0', feature_category: :importers 611# Needed by octokit: https://github.com/octokit/octokit.rb/pull/1688 612gem 'faraday-multipart', '~> 1.0', feature_category: :importers 613 614gem 'gitlab-mail_room', '~> 0.0.24', require: 'mail_room', feature_category: :shared 615 616gem 'email_reply_trimmer', '~> 0.1', feature_category: :shared 617gem 'html2text', feature_category: :shared 618 619gem 'stackprof', '~> 0.2.26', require: false, feature_category: :shared 620gem 'rbtrace', '~> 0.4', require: false, feature_category: :shared 621gem 'memory_profiler', '~> 1.0', require: false, feature_category: :shared 622 623# OAuth 624gem 'oauth2', '~> 2.0', feature_category: :system_access 625 626# Health check 627gem 'health_check', '~> 3.0', feature_category: :shared 628 629# System information 630gem 'vmstat', '~> 2.3.0', feature_category: :shared 631gem 'sys-filesystem', '~> 1.4.3', feature_category: :shared 632 633# NTP client 634gem 'net-ntp', feature_category: :shared 635 636# SSH keys support 637gem 'ssh_data', '~> 1.3', feature_category: :shared 638 639# Spamcheck GRPC protocol definitions 640gem 'spamcheck', '~> 1.3.0', feature_category: :insider_threat 641 642# Gitaly GRPC protocol definitions 643gem 'gitaly', '~> 18.4.0.pre.rc1', feature_category: :gitaly 644 645# KAS GRPC protocol definitions 646gem 'gitlab-kas-grpc', '~> 18.3.0', feature_category: :deployment_management 647 648gem 'grpc', '~> 1.74.0', feature_category: :shared 649 650gem 'google-protobuf', '~> 3.25', '>= 3.25.3', feature_category: :shared 651 652gem 'toml-rb', '~> 2.2.0', feature_category: :shared 653 654# Feature toggles 655gem 'flipper', '~> 0.28.0', feature_category: :shared 656gem 'flipper-active_record', '~> 0.28.0', feature_category: :shared 657gem 'flipper-active_support_cache_store', '~> 0.28.0', feature_category: :shared 658gem 'unleash', '~> 3.2.2', feature_category: :shared 659gem 'gitlab-experiment', '~> 0.9.1', feature_category: :shared 660 661# Structured logging 662gem 'lograge', '~> 0.5', feature_category: :shared 663gem 'grape_logging', '~> 1.8', '>= 1.8.4', feature_category: :api 664 665# DNS Lookup 666gem 'gitlab-net-dns', '~> 0.15.0', feature_category: :shared 667 668# Countries list 669gem 'countries', '~> 4.0.0', feature_category: :shared 670 671gem 'retriable', '~> 3.1.2', feature_category: :shared 672 673# LRU cache 674gem 'lru_redux', feature_category: :shared 675 676# Locked as long as quoted-printable encoding issues are not resolved 677# Monkey-patched in `config/initializers/mail_encoding_patch.rb` 678# See https://gitlab.com/gitlab-org/gitlab/issues/197386 679# 680# `config/initializers/mail_starttls_patch.rb` has also been patched to 681# fix STARTTLS handling until https://github.com/mikel/mail/pull/1536 is 682# released. 683gem 'mail', '= 2.8.1', feature_category: :shared 684gem 'mail-smtp_pool', '~> 0.1.0', path: 'gems/mail-smtp_pool', require: false, feature_category: :shared 685 686gem 'microsoft_graph_mailer', '~> 0.1.0', path: 'vendor/gems/microsoft_graph_mailer', feature_category: :shared 687 688# File encryption 689gem 'lockbox', '~> 1.4.0', feature_category: :shared 690 691# Email validation 692gem 'valid_email', '~> 0.1', feature_category: :shared 693 694# JSON 695gem 'jsonb_accessor', '~> 1.4', feature_category: :shared 696gem 'json', '~> 2.13.0', feature_category: :shared 697gem 'json_schemer', '~> 2.3.0', feature_category: :shared 698gem 'oj', '~> 3.16.0', '>=3.16.10', feature_category: :shared 699gem 'oj-introspect', '~> 0.8', feature_category: :shared 700gem 'multi_json', '~> 1.17.0', feature_category: :shared 701gem 'yajl-ruby', '~> 1.4.3', require: 'yajl', feature_category: :shared 702 703gem 'webauthn', '~> 3.0', feature_category: :shared 704 705# IPAddress utilities 706gem 'ipaddress', '~> 0.8.3', feature_category: :shared 707 708gem 'parslet', '~> 1.8', feature_category: :shared 709 710gem 'ipynbdiff', path: 'gems/ipynbdiff', require: 'ipynb_diff', feature_category: :shared 711 712gem 'ed25519', '~> 1.4.0', feature_category: :shared 713 714# Error Tracking OpenAPI client 715# See https://gitlab.com/gitlab-org/gitlab/-/blob/master/doc/development/rake_tasks.md#update-openapi-client-for-error-tracking-feature 716gem 'error_tracking_open_api', path: 'gems/error_tracking_open_api', feature_category: :shared 717 718# Vulnerability advisories 719gem 'cvss-suite', '~> 3.3.0', require: 'cvss_suite', feature_category: :software_composition_analysis 720 721# Work with RPM packages 722gem 'arr-pm', '~> 0.0.12', feature_category: :package_registry 723 724# Remote Development 725gem 'devfile', '~> 0.4.8', feature_category: :workspaces 726gem 'hashdiff', '~> 1.2.0', feature_category: :workspaces 727 728# Apple plist parsing 729gem 'CFPropertyList', '~> 3.0.0', feature_category: :mobile_devops 730gem 'app_store_connect', feature_category: :mobile_devops 731 732# For phone verification 733gem 'telesignenterprise', '~> 2.6', feature_category: :insider_threat 734 735# NOTE: In Ruby 3.4 base64 was moved out of the stdlib 736# This gem was added while upgrading `telesignenterprise` to 2.6.0 to ensure compatibility with Ruby 3.4 737gem "base64", "~> 0.2.0", feature_category: :shared 738 739# BufferedIO patch 740gem 'net-protocol', '~> 0.2.2', feature_category: :shared 741gem "nkf", "~> 0.2.0", feature_category: :shared 742 743# This is locked to 0.6.0 because we patch Net::HTTP#connect in 744# gems/gitlab-http/lib/net_http/connect_patch.rb. 745# It can be upgraded but care must be taken to preserve the patch. 746gem 'net-http', '= 0.6.0', feature_category: :shared 747# This is locked to 0.13.0 because the default parser changes from RFC2396 to RFC3986, 748# which can be removed after Rails 7.2 upgrade 749# See https://gitlab.com/gitlab-org/gitlab/-/merge_requests/173142#note_2277952450 750gem 'uri', '= 0.13.2', feature_category: :shared 751 752gem 'duo_api', '~> 1.3', feature_category: :system_access 753 754gem 'gitlab-sdk', '~> 0.3.0', feature_category: :application_instrumentation 755 756gem 'paper_trail', '~> 16.0', feature_category: :shared 757 758gem "i18n_data", "~> 0.13.1", feature_category: :system_access 759 760gem "gitlab-cloud-connector", "~> 1.26", require: 'gitlab/cloud_connector', feature_category: :plan_provisioning