1# frozen_string_literal: true
2
3source 'https://rubygems.org'
4
5if ENV.fetch('BUNDLER_CHECKSUM_VERIFICATION_OPT_IN', 'false') != 'false' # this verification is still experimental
6 $LOAD_PATH.unshift(File.expand_path("vendor/gems/bundler-checksum/lib", __dir__))
7 require 'bundler-checksum'
8 BundlerChecksum.patch!
9end
10
11gem 'bundler-checksum', '~> 0.1.0', path: 'vendor/gems/bundler-checksum', require: false
12
13# NOTE: When incrementing the major or minor version here, also increment activerecord_version
14# in vendor/gems/attr_encrypted/attr_encrypted.gemspec until we resolve
15# https://gitlab.com/gitlab-org/gitlab/-/issues/375713
16gem 'rails', '~> 6.1.7.2'
17
18gem 'bootsnap', '~> 1.16.0', require: false
19
20gem 'openssl', '~> 3.0'
21gem 'ipaddr', '~> 1.2.5'
22
23# Responders respond_to and respond_with
24gem 'responders', '~> 3.0'
25
26gem 'sprockets', '~> 3.7.0'
27
28gem 'view_component', '~> 2.82.0'
29
30# Supported DBs
31gem 'pg', '~> 1.5.3'
32
33gem 'neighbor', '~> 0.2.3'
34
35gem 'rugged', '~> 1.5'
36gem 'grape-path-helpers', '~> 1.7.1'
37
38gem 'faraday', '~> 1.0'
39gem 'marginalia', '~> 1.11.1'
40
41# Authorization
42gem 'declarative_policy', '~> 1.1.0'
43
44# Authentication libraries
45gem 'devise', '~> 4.8.1'
46gem 'devise-pbkdf2-encryptable', '~> 0.0.0', path: 'vendor/gems/devise-pbkdf2-encryptable'
47gem 'bcrypt', '~> 3.1', '>= 3.1.14'
48gem 'doorkeeper', '~> 5.6', '>= 5.6.6'
49gem 'doorkeeper-openid_connect', '~> 1.8', '>= 1.8.6'
50gem 'rexml', '~> 3.2.5'
51gem 'ruby-saml', '~> 1.13.0'
52gem 'omniauth', '~> 2.1.0'
53gem 'omniauth-auth0', '~> 3.1'
54gem 'omniauth-azure-activedirectory-v2', '~> 2.0'
55gem 'omniauth-azure-oauth2', '~> 0.0.9', path: 'vendor/gems/omniauth-azure-oauth2' # See gem README.md
56gem 'omniauth-dingtalk-oauth2', '~> 1.0'
57gem 'omniauth-alicloud', '~> 2.0.1'
58gem 'omniauth-facebook', '~> 4.0.0'
59gem 'omniauth-github', '2.0.1'
60gem 'omniauth-gitlab', '~> 4.0.0', path: 'vendor/gems/omniauth-gitlab' # See vendor/gems/omniauth-gitlab/README.md
61gem 'omniauth-google-oauth2', '~> 1.1'
62gem 'omniauth-oauth2-generic', '~> 0.2.2'
63gem 'omniauth-saml', '~> 2.1.0'
64gem 'omniauth-twitter', '~> 1.4'
65gem 'omniauth_crowd', '~> 2.4.0', path: 'vendor/gems/omniauth_crowd' # See vendor/gems/omniauth_crowd/README.md
66gem 'omniauth_openid_connect', '~> 0.6.1'
67# Locked until Ruby 3.0 upgrade since upgrading will pull in an updated net-smtp gem.
68# See https://docs.gitlab.com/ee/development/emails.html#rationale.
69gem 'openid_connect', '= 1.3.0'
70gem 'omniauth-salesforce', '~> 1.0.5', path: 'vendor/gems/omniauth-salesforce' # See gem README.md
71gem 'omniauth-atlassian-oauth2', '~> 0.2.0'
72gem 'rack-oauth2', '~> 1.21.3'
73gem 'jwt', '~> 2.5'
74
75# Kerberos authentication. EE-only
76gem 'gssapi', '~> 1.3.1', group: :kerberos
77gem 'timfel-krb5-auth', '~> 0.8', group: :kerberos
78
79# Spam and anti-bot protection
80gem 'recaptcha', '~> 5.12', require: 'recaptcha/rails'
81gem 'akismet', '~> 3.0'
82gem 'invisible_captcha', '~> 2.0.0'
83
84# Two-factor authentication
85gem 'devise-two-factor', '~> 4.0.2'
86gem 'rqrcode-rails3', '~> 0.1.7'
87gem 'attr_encrypted', '~> 3.2.4', path: 'vendor/gems/attr_encrypted'
88
89# GitLab Pages
90gem 'validates_hostname', '~> 1.0.11'
91gem 'rubyzip', '~> 2.3.2', require: 'zip'
92# GitLab Pages letsencrypt support
93gem 'acme-client', '~> 2.0'
94
95# Browser detection
96gem 'browser', '~> 5.3.1'
97
98# OS detection for usage ping
99gem 'ohai', '~> 17.9'
100
101# GPG
102gem 'gpgme', '~> 2.0.22'
103
104# LDAP Auth
105# GitLab fork with several improvements to original library. For full list of changes
106# see https://github.com/intridea/omniauth-ldap/compare/master...gitlabhq:master
107gem 'gitlab_omniauth-ldap', '~> 2.2.0', require: 'omniauth-ldap'
108gem 'net-ldap', '~> 0.17.1'
109
110# API
111gem 'grape', '~> 1.5.2'
112gem 'grape-entity', '~> 0.10.0'
113gem 'rack-cors', '~> 1.1.1', require: 'rack/cors'
114gem 'grape-swagger', '~>1.5.0', group: [:development, :test]
115gem 'grape-swagger-entity', '~> 0.5.1', group: [:development, :test]
116
117# GraphQL API
118gem 'graphql', '~> 1.13.12'
119gem 'graphiql-rails', '~> 1.8'
120gem 'apollo_upload_server', '~> 2.1.0'
121gem 'graphql-docs', '~> 2.1.0', group: [:development, :test]
122gem 'graphlient', '~> 0.5.0' # Used by BulkImport feature (group::import)
123
124gem 'hashie', '~> 5.0.0'
125
126# Pagination
127gem 'kaminari', '~> 1.2.2'
128
129# HAML
130gem 'hamlit', '~> 2.15.0'
131
132# Files attachments
133gem 'carrierwave', '~> 1.3'
134gem 'mini_magick', '~> 4.10.1'
135
136# for backups
137gem 'fog-aws', '~> 3.18'
138# Locked until fog-google resolves https://github.com/fog/fog-google/issues/421.
139# Also see config/initializers/fog_core_patch.rb.
140gem 'fog-core', '= 2.1.0'
141gem 'fog-google', '~> 1.19', require: 'fog/google'
142gem 'fog-local', '~> 0.8'
143# NOTE:
144# the fog-aliyun gem since v0.4 pulls in aliyun-sdk transitively, which monkey-patches
145# the rest-client gem to drop the Content-Length header field for chunked transfers,
146# which may have knock-on effects on other features using `RestClient`.
147# We may want to update this dependency if this is ever addressed upstream, e.g. via
148# https://github.com/aliyun/aliyun-oss-ruby-sdk/pull/93
149gem 'fog-aliyun', '~> 0.4'
150gem 'gitlab-fog-azure-rm', '~> 1.7.0', require: 'fog/azurerm'
151
152# for Google storage
153gem 'google-cloud-storage', '~> 1.44.0'
154gem 'google-apis-core', '~> 0.10.0'
155gem 'google-apis-compute_v1', '~> 0.57.0'
156gem 'google-apis-container_v1', '~> 0.43.0'
157gem 'google-apis-container_v1beta1', '~> 0.43.0'
158gem 'google-apis-cloudbilling_v1', '~> 0.21.0'
159gem 'google-apis-cloudresourcemanager_v1', '~> 0.31.0'
160gem 'google-apis-iam_v1', '~> 0.36.0'
161gem 'google-apis-serviceusage_v1', '~> 0.28.0'
162gem 'google-apis-sqladmin_v1beta4', '~> 0.41.0'
163gem 'google-apis-androidpublisher_v3', '~> 0.34.0'
164
165# for aws storage
166gem 'unf', '~> 0.1.4'
167
168# Seed data
169gem 'seed-fu', '~> 2.3.7'
170
171# Search
172gem 'elasticsearch-model', '~> 7.2'
173gem 'elasticsearch-rails', '~> 7.2', require: 'elasticsearch/rails/instrumentation'
174gem 'elasticsearch-api', '7.13.3'
175gem 'aws-sdk-core', '~> 3.172.0'
176gem 'aws-sdk-cloudformation', '~> 1'
177gem 'aws-sdk-s3', '~> 1.122.0'
178gem 'faraday_middleware-aws-sigv4', '~>0.3.0'
179gem 'typhoeus', '~> 1.4.0' # Used with Elasticsearch to support http keep-alive connections
180
181# Markdown and HTML processing
182gem 'html-pipeline', '~> 2.14.3'
183gem 'deckar01-task_list', '2.3.2'
184gem 'gitlab-markup', '~> 1.9.0', require: 'github/markup'
185gem 'commonmarker', '~> 0.23.6'
186gem 'kramdown', '~> 2.3.1'
187gem 'RedCloth', '~> 4.3.2'
188gem 'rdoc', '~> 6.3.2'
189gem 'org-ruby', '~> 0.9.12'
190gem 'creole', '~> 0.5.0'
191gem 'wikicloth', '0.8.1'
192gem 'asciidoctor', '~> 2.0.18'
193gem 'asciidoctor-include-ext', '~> 0.4.0', require: false
194gem 'asciidoctor-plantuml', '~> 0.0.16'
195gem 'asciidoctor-kroki', '~> 0.8.0', require: false
196gem 'rouge', '~> 4.1.0'
197gem 'truncato', '~> 0.7.12'
198gem 'nokogiri', '~> 1.14.3'
199
200# Calendar rendering
201gem 'icalendar'
202
203# Diffs
204gem 'diffy', '~> 3.4'
205gem 'diff_match_patch', '~> 0.1.0'
206
207# Application server
208gem 'rack', '~> 2.2.7'
209# https://github.com/zombocom/rack-timeout/blob/master/README.md#rails-apps-manually
210gem 'rack-timeout', '~> 0.6.3', require: 'rack/timeout/base'
211
212group :puma do
213 gem 'puma', '~> 5.6.5', require: false
214 gem 'puma_worker_killer', '~> 0.3.1', require: false
215 gem 'sd_notify', '~> 0.1.0', require: false
216end
217
218# State machine
219gem 'state_machines-activerecord', '~> 0.8.0'
220
221# CI domain tags
222gem 'acts-as-taggable-on', '~> 9.0'
223
224# Background jobs
225gem 'sidekiq', '~> 6.5.7'
226gem 'sidekiq-cron', '~> 1.8.0'
227gem 'redis-namespace', '~> 1.9.0'
228gem 'gitlab-sidekiq-fetcher', path: 'vendor/gems/sidekiq-reliable-fetch', require: 'sidekiq-reliable-fetch'
229
230# Cron Parser
231gem 'fugit', '~> 1.8.1'
232
233# HTTP requests
234gem 'httparty', '~> 0.20.0'
235
236# Colored output to console
237gem 'rainbow', '~> 3.0'
238
239# Progress bar
240gem 'ruby-progressbar', '~> 1.10'
241
242# Linear-time regex library for untrusted regular expressions
243gem 're2', '~> 1.6.0'
244
245# Misc
246
247gem 'semver_dialects', '~> 1.2.1'
248gem 'version_sorter', '~> 2.3'
249
250# Export Ruby Regex to Javascript
251gem 'js_regex', '~> 3.8'
252
253# User agent parsing
254gem 'device_detector'
255
256# Redis
257gem 'redis', '~> 4.8.0'
258gem 'connection_pool', '~> 2.0'
259
260# Redis session store
261gem 'redis-actionpack', '~> 5.3.0'
262
263# Discord integration
264gem 'discordrb-webhooks', '~> 3.4', require: false
265
266# Jira integration
267gem 'jira-ruby', '~> 2.1.4'
268gem 'atlassian-jwt', '~> 0.2.0'
269
270# Slack integration
271gem 'slack-messenger', '~> 2.3.4'
272
273# Hangouts Chat integration
274gem 'hangouts-chat', '~> 0.0.5', require: 'hangouts_chat'
275
276# Asana integration
277gem 'asana', '~> 0.10.13'
278
279# FogBugz integration
280gem 'ruby-fogbugz', '~> 0.3.0'
281
282# Kubernetes integration
283gem 'kubeclient', '~> 4.11.0'
284
285# AI
286gem 'ruby-openai', '~> 3.7'
287gem 'circuitbox', '2.0.0'
288
289# Sanitize user input
290gem 'sanitize', '~> 6.0'
291gem 'babosa', '~> 1.0.4'
292
293# Sanitizes SVG input
294gem 'loofah', '~> 2.21.0'
295
296# Working with license
297# Detects the open source license the repository includes
298# This version needs to be in sync with gitlab-org/gitaly
299gem 'licensee', '~> 9.15'
300
301# Detect and convert string character encoding
302gem 'charlock_holmes', '~> 0.7.7'
303
304# Detect mime content type from content
305gem 'ruby-magic', '~> 0.6'
306
307# Faster blank
308gem 'fast_blank'
309
310# Parse time & duration
311gem 'gitlab-chronic', '~> 0.10.5'
312gem 'gitlab_chronic_duration', '~> 0.10.6.2'
313
314gem 'rack-proxy', '~> 0.7.6'
315
316gem 'sassc-rails', '~> 2.1.0'
317gem 'autoprefixer-rails', '10.2.5.1'
318gem 'terser', '1.0.2'
319
320gem 'addressable', '~> 2.8'
321gem 'tanuki_emoji', '~> 0.6'
322gem 'gon', '~> 6.4.0'
323gem 'request_store', '~> 1.5.1'
324gem 'base32', '~> 0.3.0'
325
326gem 'gitlab-license', '~> 2.2.1'
327
328# Protect against bruteforcing
329gem 'rack-attack', '~> 6.6.1'
330
331# Sentry integration
332gem 'sentry-raven', '~> 3.1'
333gem 'sentry-ruby', '~> 5.8.0'
334gem 'sentry-rails', '~> 5.8.0'
335gem 'sentry-sidekiq', '~> 5.8.0'
336
337# PostgreSQL query parsing
338#
339gem 'pg_query', '~> 2.2', '>= 2.2.1'
340
341gem 'premailer-rails', '~> 1.10.3'
342
343gem 'gitlab-labkit', '~> 0.32.0'
344gem 'thrift', '>= 0.16.0'
345
346# I18n
347gem 'ruby_parser', '~> 3.20', require: false
348gem 'rails-i18n', '~> 7.0'
349gem 'gettext_i18n_rails', '~> 1.8.0'
350gem 'gettext_i18n_rails_js', '~> 1.3'
351gem 'gettext', '~> 3.3', require: false, group: :development
352
353gem 'batch-loader', '~> 2.0.1'
354
355# Perf bar
356gem 'peek', '~> 1.1'
357
358# Google Cloud Profiler support
359gem 'cloud_profiler_agent', '~> 0.0.0', path: 'vendor/gems/cloud_profiler_agent', require: false
360
361# Snowplow events tracking
362gem 'snowplow-tracker', '~> 0.8.0'
363
364# Metrics
365gem 'webrick', '~> 1.8.1', require: false
366gem 'prometheus-client-mmap', '~> 0.23', require: 'prometheus/client'
367
368gem 'warning', '~> 1.3.0'
369
370group :development do
371 gem 'lefthook', '~> 1.3.13', require: false
372 gem 'rubocop'
373 gem 'solargraph', '~> 0.47.2', require: false
374
375 gem 'letter_opener_web', '~> 2.0.0'
376 gem 'lookbook', '~> 2.0', '>= 2.0.1'
377
378 # Better errors handler
379 gem 'better_errors', '~> 2.10.0'
380
381 gem 'sprite-factory', '~> 1.7'
382
383 gem "listen", "~> 3.7"
384end
385
386group :development, :test do
387 gem 'deprecation_toolkit', '~> 1.5.1', require: false
388 gem 'bullet', '~> 7.0.2'
389 gem 'pry-byebug'
390 gem 'pry-rails', '~> 0.3.9'
391 gem 'pry-shell', '~> 0.6.1'
392
393 gem 'awesome_print', require: false
394
395 gem 'database_cleaner', '~> 1.7.0'
396 gem 'factory_bot_rails', '~> 6.2.0'
397 gem 'rspec-rails', '~> 6.0.1'
398
399 # Prevent occasions where minitest is not bundled in packaged versions of ruby (see #3826)
400 gem 'minitest', '~> 5.11.0'
401
402 # Generate Fake data
403 gem 'ffaker', '~> 2.10'
404
405 gem 'spring', '~> 4.1.0'
406 gem 'spring-commands-rspec', '~> 1.0.4'
407
408 gem 'gitlab-styles', '~> 10.0.0', require: false
409
410 gem 'haml_lint', '~> 0.40.0', require: false
411 gem 'bundler-audit', '~> 0.7.0.1', require: false
412
413 # Benchmarking & profiling
414 gem 'benchmark-ips', '~> 2.11.0', require: false
415 gem 'benchmark-memory', '~> 0.1', require: false
416
417 gem 'knapsack', '~> 1.21.1'
418 gem 'crystalball', '~> 0.7.0', require: false
419
420 gem 'simple_po_parser', '~> 1.1.6', require: false
421
422 gem 'png_quantizator', '~> 0.2.1', require: false
423
424 gem 'parallel', '~> 1.19', require: false
425
426 gem 'test_file_finder', '~> 0.1.3'
427
428 gem 'sigdump', '~> 0.2.4', require: 'sigdump/setup'
429
430 gem 'pact', '~> 1.63'
431end
432
433group :development, :test, :danger do
434 gem 'gitlab-dangerfiles', '~> 3.10.0', require: false
435end
436
437group :development, :test, :coverage do
438 gem 'simplecov', '~> 0.21', require: false
439 gem 'simplecov-lcov', '~> 0.8.0', require: false
440 gem 'simplecov-cobertura', '~> 1.3.1', require: false
441 gem 'undercover', '~> 0.4.4', require: false
442end
443
444# Gems required in omnibus-gitlab pipeline
445group :development, :test, :omnibus do
446 gem 'license_finder', '~> 7.0', require: false
447end
448
449group :test do
450 gem 'fuubar', '~> 2.2.0'
451 gem 'rspec-retry', '~> 0.6.2'
452 gem 'rspec_profiling', '~> 0.0.6'
453 gem 'rspec-benchmark', '~> 0.6.0'
454 gem 'rspec-parameterized', '~> 1.0', require: false
455
456 gem 'capybara', '~> 3.39'
457 gem 'capybara-screenshot', '~> 1.0.26'
458 # 4.9.1 drops Ruby 2.7 support. We can upgrade further after we drop Ruby 2.7 support.
459 gem 'selenium-webdriver', '= 4.9.0'
460
461 gem 'graphlyte', '~> 1.0.0'
462
463 gem 'shoulda-matchers', '~> 5.1.0', require: false
464 gem 'email_spec', '~> 2.2.0'
465 gem 'webmock', '~> 3.18.1'
466 gem 'rails-controller-testing'
467 gem 'concurrent-ruby', '~> 1.1'
468 gem 'test-prof', '~> 1.2.1'
469 gem 'rspec_junit_formatter'
470 gem 'guard-rspec'
471 gem 'axe-core-rspec'
472
473 # Moved in `test` because https://gitlab.com/gitlab-org/gitlab/-/issues/217527
474 gem 'derailed_benchmarks', require: false
475end
476
477gem 'octokit', '~> 4.15'
478
479gem 'gitlab-mail_room', '~> 0.0.23', require: 'mail_room'
480
481gem 'email_reply_trimmer', '~> 0.1'
482gem 'html2text'
483
484gem 'stackprof', '~> 0.2.25', require: false
485gem 'rbtrace', '~> 0.4', require: false
486gem 'memory_profiler', '~> 1.0', require: false
487gem 'activerecord-explain-analyze', '~> 0.1', require: false
488
489# OAuth
490gem 'oauth2', '~> 2.0'
491
492# Health check
493gem 'health_check', '~> 3.0'
494
495# System information
496gem 'vmstat', '~> 2.3.0'
497gem 'sys-filesystem', '~> 1.4.3'
498
499# NTP client
500gem 'net-ntp'
501
502# SSH keys support
503gem 'ssh_data', '~> 1.3'
504
505# Spamcheck GRPC protocol definitions
506gem 'spamcheck', '~> 1.3.0'
507
508# Gitaly GRPC protocol definitions
509gem 'gitaly', '~> 15.9.0-rc3'
510
511# KAS GRPC protocol definitions
512gem 'kas-grpc', '~> 0.1.0'
513
514gem 'grpc', '~> 1.42.0'
515
516gem 'google-protobuf', '~> 3.22', '>= 3.22.3'
517
518gem 'toml-rb', '~> 2.2.0'
519
520# Feature toggles
521gem 'flipper', '~> 0.25.0'
522gem 'flipper-active_record', '~> 0.25.0'
523gem 'flipper-active_support_cache_store', '~> 0.25.0'
524gem 'unleash', '~> 3.2.2'
525gem 'gitlab-experiment', '~> 0.7.1'
526
527# Structured logging
528gem 'lograge', '~> 0.5'
529gem 'grape_logging', '~> 1.8'
530
531# DNS Lookup
532gem 'gitlab-net-dns', '~> 0.9.2'
533
534# Countries list
535gem 'countries', '~> 4.0.0'
536
537gem 'retriable', '~> 3.1.2'
538
539# LRU cache
540gem 'lru_redux'
541
542# Locked as long as quoted-printable encoding issues are not resolved
543# Monkey-patched in `config/initializers/mail_encoding_patch.rb`
544# See https://gitlab.com/gitlab-org/gitlab/issues/197386
545#
546# `config/initializers/mail_starttls_patch.rb` has also been patched to
547# fix STARTTLS handling until https://github.com/mikel/mail/pull/1536 is
548# released.
549gem 'mail', '= 2.8.1'
550gem 'mail-smtp_pool', '~> 0.1.0', path: 'vendor/gems/mail-smtp_pool', require: false
551
552gem 'microsoft_graph_mailer', '~> 0.1.0', path: 'vendor/gems/microsoft_graph_mailer'
553
554# File encryption
555gem 'lockbox', '~> 1.1.1'
556
557# Email validation
558gem 'valid_email', '~> 0.1'
559
560# JSON
561gem 'json', '~> 2.6.3'
562gem 'json_schemer', '~> 0.2.18'
563gem 'oj', '~> 3.13.21'
564gem 'oj-introspect', '~> 0.7'
565gem 'multi_json', '~> 1.14.1'
566gem 'yajl-ruby', '~> 1.4.3', require: 'yajl'
567
568gem 'webauthn', '~> 3.0'
569
570# IPAddress utilities
571gem 'ipaddress', '~> 0.8.3'
572
573gem 'parslet', '~> 1.8'
574
575gem 'ipynbdiff', path: 'vendor/gems/ipynbdiff'
576
577gem 'ed25519', '~> 1.3.0'
578
579# Error Tracking OpenAPI client
580# See https://gitlab.com/gitlab-org/gitlab/-/blob/master/doc/development/rake_tasks.md#update-openapi-client-for-error-tracking-feature
581gem 'error_tracking_open_api', path: 'vendor/gems/error_tracking_open_api'
582
583# Vulnerability advisories
584gem 'cvss-suite', '~> 3.0.1', require: 'cvss_suite'
585
586# Work with RPM packages
587gem 'arr-pm', '~> 0.0.12'
588
589# Remote Development
590gem 'devfile', '~> 0.0.17.pre.alpha1'
591
592# Apple plist parsing
593gem 'CFPropertyList', '~> 3.0.0'
594gem 'app_store_connect'
595
596# For phone verification
597gem 'telesignenterprise', '~> 2.2'
598
599# BufferedIO patch
600# Updating this version will require updating scripts/allowed_warnings.txt
601gem 'net-protocol', '~> 0.1.3'
602
603gem 'duo_api', '~> 1.3'