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