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