Clone of https://github.com/NixOS/nixpkgs.git (to stress-test knotserver)
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.1', feature_category: :shared 30else 31 gem 'rails', '~> 7.1.5.1', 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.5.6', 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', '~> 1.1.0', 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.9.3', 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.1.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.2.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.4.13', feature_category: :api 168gem 'graphql-docs', '~> 5.0.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 feature_category: :cell 175 176# Duo Workflow 177gem 'gitlab-duo-workflow-service-client', '~> 0.2', 178 path: 'vendor/gems/gitlab-duo-workflow-service-client', 179 feature_category: :duo_workflow 180 181# Generate Fake data 182gem 'ffaker', '~> 2.24', feature_category: :shared 183 184gem 'hashie', '~> 5.0.0', feature_category: :shared 185 186# Pagination 187gem 'kaminari', '~> 1.2.2', feature_category: :shared 188 189# HAML 190gem 'hamlit', '~> 2.15.0', feature_category: :shared 191 192# Files attachments 193gem 'carrierwave', '~> 1.3', feature_category: :shared 194gem 'mini_magick', '~> 4.12', feature_category: :shared 195 196# PDF generation 197gem 'prawn', feature_category: :vulnerability_management 198gem 'prawn-svg', feature_category: :vulnerability_management 199 200# for backups 201gem 'fog-aws', '~> 3.26', feature_category: :shared 202# Locked until fog-google resolves https://github.com/fog/fog-google/issues/421. 203# Also see config/initializers/fog_core_patch.rb. 204gem 'fog-core', '= 2.1.0', feature_category: :shared 205gem 'fog-google', '~> 1.24.1', 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.2.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.45.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.11.0', '>= 0.11.1', feature_category: :shared 224gem 'google-apis-compute_v1', '~> 0.57.0', feature_category: :shared 225gem 'google-apis-container_v1', '~> 0.43.0', feature_category: :shared 226gem 'google-apis-container_v1beta1', '~> 0.43.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.36.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.34.0', feature_category: :shared 233 234gem 'googleauth', '~> 1.8.1', 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.225.0', feature_category: :global_search 246gem 'aws-sdk-cloudformation', '~> 1', feature_category: :global_search 247gem 'aws-sdk-s3', '~> 1.189.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.5.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.31', 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.0', 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-clustering', '~> 5.4.0', feature_category: :redis 335gem 'connection_pool', '~> 2.5.3', feature_category: :shared 336 337# Redis session store 338gem 'redis-actionpack', '~> 5.5.0', feature_category: :redis 339 340# Jira integration 341gem 'jira-ruby', '~> 2.3.0', feature_category: :integrations 342gem 'atlassian-jwt', '~> 0.2.1', feature_category: :integrations 343 344# Slack integration 345gem 'slack-messenger', '~> 2.3.5', feature_category: :integrations 346 347# Kubernetes integration 348gem 'kubeclient', '~> 4.11.0', feature_category: :shared 349 350# AI 351gem 'circuitbox', '2.0.0', feature_category: :shared 352 353# Sanitize user input 354gem 'sanitize', '~> 6.0.2', feature_category: :shared 355gem 'babosa', '~> 2.0', feature_category: :shared 356 357# Sanitizes SVG input 358gem 'loofah', '~> 2.24.0', feature_category: :shared 359 360# Used to provide license templates 361gem 'licensee', '~> 9.16', feature_category: :shared 362 363# Detect and convert string character encoding 364gem 'charlock_holmes', '~> 0.7.9', feature_category: :shared 365 366# Detect mime content type from content 367gem 'ruby-magic', '~> 0.6', feature_category: :shared 368 369# Faster blank 370gem 'fast_blank', '~> 1.0.1', feature_category: :shared 371 372# Parse time & duration 373gem 'gitlab-chronic', '~> 0.10.5', feature_category: :shared 374gem 'gitlab_chronic_duration', '~> 0.12', feature_category: :shared 375 376gem 'rack-proxy', '~> 0.7.7', feature_category: :shared 377 378gem 'cssbundling-rails', '1.4.3', feature_category: :shared 379gem 'terser', '1.0.2', feature_category: :shared 380 381gem 'click_house-client', path: 'gems/click_house-client', require: 'click_house/client', feature_category: :database 382gem 'addressable', '~> 2.8', feature_category: :shared 383gem 'gon', '~> 6.4.0', feature_category: :shared 384gem 'request_store', '~> 1.7.0', feature_category: :shared 385gem 'base32', '~> 0.3.0', feature_category: :shared 386gem 'gitlab-license', '~> 2.6', feature_category: :shared 387 388# Protect against bruteforcing 389gem 'rack-attack', '~> 6.7.0', feature_category: :shared 390 391# Sentry integration 392gem 'sentry-ruby', '~> 5.23.0', feature_category: :observability 393gem 'sentry-rails', '~> 5.23.0', feature_category: :observability 394gem 'sentry-sidekiq', '~> 5.23.0', feature_category: :observability 395 396# PostgreSQL query parsing 397# 398gem 'pg_query', '~> 6.1.0', feature_category: :database 399 400gem 'gitlab-schema-validation', path: 'gems/gitlab-schema-validation', feature_category: :shared 401gem 'gitlab-http', path: 'gems/gitlab-http', feature_category: :shared 402 403gem 'premailer-rails', '~> 1.12.0', feature_category: :notifications 404gem 'gitlab-labkit', '~> 0.39.0', feature_category: :shared 405gem 'thrift', '>= 0.16.0', feature_category: :shared 406 407# I18n 408gem 'rails-i18n', '~> 7.0', '>= 7.0.9', feature_category: :internationalization 409gem 'gettext_i18n_rails', '~> 1.13.0', feature_category: :internationalization 410gem 'gettext', '~> 3.5', '>= 3.5.1', 411 require: false, 412 group: [:development, :test], 413 feature_category: :internationalization 414 415gem 'batch-loader', '~> 2.0.5', feature_category: :shared 416 417gem 'tty-prompt', '~> 0.23', require: false, feature_category: :shared 418 419# Perf bar 420gem 'peek', '~> 1.1', feature_category: :shared 421 422# Snowplow events trackin 423gem 'snowplow-tracker', '~> 0.8.0', feature_category: :product_analytics 424 425# Metrics 426gem 'webrick', '~> 1.9.0', require: false, feature_category: :shared 427gem 'prometheus-client-mmap', '~> 1.2.9', require: 'prometheus/client', feature_category: :shared 428 429# Event-driven reactor for Ruby 430# Required manually in config/initializers/require_async_gem 431gem 'async', '~> 2.24.0', require: false, feature_category: :shared 432 433# Security report schemas used to validate CI job artifacts of security jobs 434gem 'gitlab-security_report_schemas', '0.1.3.min15.0.0.max15.2.2', feature_category: :vulnerability_management 435 436# OpenTelemetry 437group :opentelemetry do 438 # Core OpenTelemetry gems 439 gem 'opentelemetry-sdk', feature_category: :observability 440 gem 'opentelemetry-exporter-otlp', feature_category: :observability 441 442 # OpenTelemetry gems selected from full set in `opentelemetry-instrumentation-all` metagem 443 gem 'opentelemetry-instrumentation-active_support', feature_category: :observability 444 gem 'opentelemetry-instrumentation-action_pack', feature_category: :observability 445 gem 'opentelemetry-instrumentation-active_job', feature_category: :observability 446 gem 'opentelemetry-instrumentation-active_record', feature_category: :observability 447 gem 'opentelemetry-instrumentation-action_view', feature_category: :observability 448 gem 'opentelemetry-instrumentation-aws_sdk', feature_category: :observability 449 gem 'opentelemetry-instrumentation-http', feature_category: :observability 450 gem 'opentelemetry-instrumentation-concurrent_ruby', feature_category: :observability 451 gem 'opentelemetry-instrumentation-ethon', feature_category: :observability 452 gem 'opentelemetry-instrumentation-excon', feature_category: :observability 453 gem 'opentelemetry-instrumentation-faraday', feature_category: :observability 454 gem 'opentelemetry-instrumentation-grape', feature_category: :observability 455 gem 'opentelemetry-instrumentation-graphql', feature_category: :observability 456 gem 'opentelemetry-instrumentation-http_client', feature_category: :observability 457 gem 'opentelemetry-instrumentation-net_http', feature_category: :observability 458 gem 'opentelemetry-instrumentation-pg', feature_category: :observability 459 gem 'opentelemetry-instrumentation-rack', feature_category: :observability 460 gem 'opentelemetry-instrumentation-rails', feature_category: :observability 461 gem 'opentelemetry-instrumentation-rake', feature_category: :observability 462 gem 'opentelemetry-instrumentation-redis', feature_category: :observability 463 gem 'opentelemetry-instrumentation-sidekiq', feature_category: :observability 464end 465 466gem 'warning', '~> 1.5.0', feature_category: :shared 467 468group :development do 469 gem 'lefthook', '~> 1.11.0', require: false, feature_category: :tooling 470 gem 'rubocop', feature_category: :tooling 471 472 gem 'solargraph', '~> 0.54.0', require: false, feature_category: :shared 473 gem 'solargraph-rspec', '~> 0.5.1', require: false, feature_category: :shared 474 475 gem 'letter_opener_web', '~> 3.0.0', feature_category: :shared 476 gem 'lookbook', '~> 2.3', feature_category: :shared 477 478 # Better errors handler 479 gem 'better_errors', '~> 2.10.1', feature_category: :shared 480 481 gem 'sprite-factory', '~> 1.7', feature_category: :shared 482 483 gem 'listen', '~> 3.7', feature_category: :shared 484 485 gem 'ruby-lsp', "~> 0.23.0", require: false, feature_category: :tooling 486 487 gem 'ruby-lsp-rails', "~> 0.3.6", feature_category: :tooling 488 489 gem 'ruby-lsp-rspec', "~> 0.1.10", require: false, feature_category: :tooling 490 491 gem 'gdk-toogle', '~> 0.9', '>= 0.9.5', require: 'toogle', feature_category: :tooling 492 493 # Used by 494 # * `lib/tasks/gitlab/security/update_banned_ssh_keys.rake` 495 # * `lib/tasks/gitlab/db/migration_squash.rake` 496 gem 'git', '~> 1.8', feature_category: :shared 497end 498 499group :development, :test do 500 gem 'deprecation_toolkit', '~> 2.2.3', require: false, feature_category: :shared 501 gem 'bullet', '~> 8.0.0', feature_category: :shared 502 gem 'parser', '= 3.3.8.0', feature_category: :shared 503 gem 'pry-byebug', feature_category: :shared 504 gem 'pry-rails', '~> 0.3.9', feature_category: :shared 505 gem 'pry-shell', '~> 0.6.4', feature_category: :shared 506 507 gem 'awesome_print', require: false, feature_category: :shared 508 509 gem 'database_cleaner-active_record', '~> 2.2.0', feature_category: :database 510 gem 'rspec-rails', '~> 7.1.0', feature_category: :shared 511 gem 'factory_bot_rails', '~> 6.5.0', feature_category: :tooling 512 513 # Prevent occasions where minitest is not bundled in packaged versions of ruby (see #3826) 514 gem 'minitest', '~> 5.11.0', feature_category: :shared 515 516 gem 'spring', '~> 4.3.0', feature_category: :shared 517 gem 'spring-commands-rspec', '~> 1.0.4', feature_category: :shared 518 519 gem 'gitlab-styles', '~> 13.1.0', feature_category: :tooling, require: false 520 gem 'haml_lint', '~> 0.58', feature_category: :tooling, require: false 521 522 # Benchmarking & profiling 523 gem 'benchmark-ips', '~> 2.14.0', require: false, feature_category: :shared 524 gem 'benchmark-memory', '~> 0.1', require: false, feature_category: :shared 525 526 # Profiling data from CI/CD pipelines 527 gem 'influxdb-client', '~> 3.1', require: false, feature_category: :tooling 528 529 gem 'knapsack', '~> 4.0.0', feature_category: :tooling 530 gem 'gitlab-crystalball', '~> 1.1.0', require: false, feature_category: :tooling 531 gem 'test_file_finder', '~> 0.3.1', feature_category: :tooling 532 533 gem 'simple_po_parser', '~> 1.1.6', require: false, feature_category: :shared 534 535 gem 'png_quantizator', '~> 0.2.1', require: false, feature_category: :shared 536 537 gem 'parallel', '~> 1.19', require: false, feature_category: :shared 538 539 gem 'sigdump', '~> 0.2.4', require: 'sigdump/setup', feature_category: :shared 540 541 gem 'pact', '~> 1.64', feature_category: :shared 542 543 # For now we only use vite in development / test, and not for production builds 544 # See: https://gitlab.com/gitlab-org/frontend/rfcs/-/issues/106 545 gem 'vite_rails', '~> 3.0.17', feature_category: :shared 546 gem 'vite_ruby', '~> 3.9.0', 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.9.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 gem 'shoulda-matchers', '~> 6.4.0', require: false, feature_category: :shared 589 gem 'email_spec', '~> 2.3.0', feature_category: :shared 590 gem 'webmock', '~> 3.25.0', feature_category: :shared 591 gem 'rails-controller-testing', feature_category: :shared 592 gem 'concurrent-ruby', '~> 1.1', feature_category: :shared 593 gem 'test-prof', '~> 1.4.0', feature_category: :tooling 594 gem 'rspec_junit_formatter', feature_category: :shared 595 gem 'guard-rspec', feature_category: :shared 596 gem 'axe-core-rspec', '~> 4.10.0', feature_category: :tooling 597 gem 'state_machines-rspec', '~> 0.6', feature_category: :shared 598 599 # Moved in `test` because https://gitlab.com/gitlab-org/gitlab/-/issues/217527 600 gem 'derailed_benchmarks', require: false, feature_category: :shared 601 602 gem 'gitlab_quality-test_tooling', '~> 2.10.0', require: false, feature_category: :tooling 603end 604 605gem 'octokit', '~> 9.0', feature_category: :importers 606# Needed by octokit: https://github.com/octokit/octokit.rb/pull/1688 607gem 'faraday-multipart', '~> 1.0', feature_category: :importers 608 609gem 'gitlab-mail_room', '~> 0.0.24', require: 'mail_room', feature_category: :shared 610 611gem 'email_reply_trimmer', '~> 0.1', feature_category: :shared 612gem 'html2text', feature_category: :shared 613 614gem 'stackprof', '~> 0.2.26', require: false, feature_category: :shared 615gem 'rbtrace', '~> 0.4', require: false, feature_category: :shared 616gem 'memory_profiler', '~> 1.0', require: false, feature_category: :shared 617gem 'activerecord-explain-analyze', '~> 0.1', require: false, feature_category: :shared 618 619# OAuth 620gem 'oauth2', '~> 2.0', feature_category: :system_access 621 622# Health check 623gem 'health_check', '~> 3.0', feature_category: :shared 624 625# System information 626gem 'vmstat', '~> 2.3.0', feature_category: :shared 627gem 'sys-filesystem', '~> 1.4.3', feature_category: :shared 628 629# NTP client 630gem 'net-ntp', feature_category: :shared 631 632# SSH keys support 633gem 'ssh_data', '~> 1.3', feature_category: :shared 634 635# Spamcheck GRPC protocol definitions 636gem 'spamcheck', '~> 1.3.0', feature_category: :insider_threat 637 638# Gitaly GRPC protocol definitions 639gem 'gitaly', '~> 18.1.0.pre.rc1', feature_category: :gitaly 640 641# KAS GRPC protocol definitions 642gem 'gitlab-kas-grpc', '~> 18.1.0', feature_category: :deployment_management 643 644# Lock until 1.74.0 is available 645# https://gitlab.com/gitlab-com/gl-infra/production/-/issues/20067 646gem 'grpc', '= 1.63.0', feature_category: :shared 647 648gem 'google-protobuf', '~> 3.25', '>= 3.25.3', feature_category: :shared 649 650gem 'toml-rb', '~> 2.2.0', feature_category: :shared 651 652# Feature toggles 653gem 'flipper', '~> 0.28.0', feature_category: :shared 654gem 'flipper-active_record', '~> 0.28.0', feature_category: :shared 655gem 'flipper-active_support_cache_store', '~> 0.28.0', feature_category: :shared 656gem 'unleash', '~> 3.2.2', feature_category: :shared 657gem 'gitlab-experiment', '~> 0.9.1', feature_category: :shared 658 659# Structured logging 660gem 'lograge', '~> 0.5', feature_category: :shared 661gem 'grape_logging', '~> 1.8', '>= 1.8.4', feature_category: :api 662 663# DNS Lookup 664gem 'gitlab-net-dns', '~> 0.12.0', feature_category: :shared 665 666# Countries list 667gem 'countries', '~> 4.0.0', feature_category: :shared 668 669gem 'retriable', '~> 3.1.2', feature_category: :shared 670 671# LRU cache 672gem 'lru_redux', feature_category: :shared 673 674# Locked as long as quoted-printable encoding issues are not resolved 675# Monkey-patched in `config/initializers/mail_encoding_patch.rb` 676# See https://gitlab.com/gitlab-org/gitlab/issues/197386 677# 678# `config/initializers/mail_starttls_patch.rb` has also been patched to 679# fix STARTTLS handling until https://github.com/mikel/mail/pull/1536 is 680# released. 681gem 'mail', '= 2.8.1', feature_category: :shared 682gem 'mail-smtp_pool', '~> 0.1.0', path: 'vendor/gems/mail-smtp_pool', require: false, feature_category: :shared 683 684gem 'microsoft_graph_mailer', '~> 0.1.0', path: 'vendor/gems/microsoft_graph_mailer', feature_category: :shared 685 686# File encryption 687gem 'lockbox', '~> 1.3.0', feature_category: :shared 688 689# Email validation 690gem 'valid_email', '~> 0.1', feature_category: :shared 691 692# JSON 693gem 'jsonb_accessor', '~> 1.4', feature_category: :shared 694gem 'json', '~> 2.11.0', feature_category: :shared 695gem 'json_schemer', '~> 2.3.0', feature_category: :shared 696gem 'oj', '~> 3.16.0', '>=3.16.10', feature_category: :shared 697gem 'oj-introspect', '~> 0.8', feature_category: :shared 698gem 'multi_json', '~> 1.14.1', feature_category: :shared 699gem 'yajl-ruby', '~> 1.4.3', require: 'yajl', feature_category: :shared 700 701gem 'webauthn', '~> 3.0', feature_category: :shared 702 703# IPAddress utilities 704gem 'ipaddress', '~> 0.8.3', feature_category: :shared 705 706gem 'parslet', '~> 1.8', feature_category: :shared 707 708gem 'ipynbdiff', path: 'gems/ipynbdiff', require: 'ipynb_diff', feature_category: :shared 709 710gem 'ed25519', '~> 1.4.0', feature_category: :shared 711 712# Error Tracking OpenAPI client 713# See https://gitlab.com/gitlab-org/gitlab/-/blob/master/doc/development/rake_tasks.md#update-openapi-client-for-error-tracking-feature 714gem 'error_tracking_open_api', path: 'gems/error_tracking_open_api', feature_category: :shared 715 716# Vulnerability advisories 717gem 'cvss-suite', '~> 3.3.0', require: 'cvss_suite', feature_category: :software_composition_analysis 718 719# Work with RPM packages 720gem 'arr-pm', '~> 0.0.12', feature_category: :package_registry 721 722# Remote Development 723gem 'devfile', '~> 0.4.4', feature_category: :workspaces 724gem 'hashdiff', '~> 1.2.0', feature_category: :workspaces 725 726# Apple plist parsing 727gem 'CFPropertyList', '~> 3.0.0', feature_category: :mobile_devops 728gem 'app_store_connect', feature_category: :mobile_devops 729 730# For phone verification 731gem 'telesignenterprise', '~> 2.2', feature_category: :insider_threat 732 733# BufferedIO patch 734# Updating this version will require updating scripts/allowed_warnings.txt 735gem 'net-protocol', '~> 0.1.3', feature_category: :shared 736gem "nkf", "~> 0.2.0", feature_category: :shared 737 738# This is locked to 0.6.0 because we patch Net::HTTP#connect in 739# gems/gitlab-http/lib/net_http/connect_patch.rb. 740# It can be upgraded but care must be taken to preserve the patch. 741gem 'net-http', '= 0.6.0', feature_category: :shared 742# This is locked to 0.13.0 because the default parser changes from RFC2396 to RFC3986, 743# which can be removed after Rails 7.2 upgrade 744# See https://gitlab.com/gitlab-org/gitlab/-/merge_requests/173142#note_2277952450 745gem 'uri', '= 0.13.2', feature_category: :shared 746 747gem 'duo_api', '~> 1.3', feature_category: :system_access 748 749gem 'gitlab-sdk', '~> 0.3.0', feature_category: :application_instrumentation 750 751gem 'paper_trail', '~> 16.0', feature_category: :shared 752 753gem "i18n_data", "~> 0.13.1", feature_category: :system_access 754 755gem "gitlab-cloud-connector", "~> 1.21", require: 'gitlab/cloud_connector', feature_category: :plan_provisioning