1# frozen_string_literal: true
2
3source 'https://rubygems.org'
4
5gem 'rails', '~> 6.1.4.1'
6
7gem 'bootsnap', '~> 1.4.6'
8
9# Responders respond_to and respond_with
10gem 'responders', '~> 3.0'
11
12gem 'sprockets', '~> 3.7.0'
13
14# Default values for AR models
15gem 'default_value_for', '~> 3.4.0'
16
17# Supported DBs
18gem 'pg', '~> 1.1'
19
20gem 'rugged', '~> 1.1'
21gem 'grape-path-helpers', '~> 1.7.0'
22
23gem 'faraday', '~> 1.0'
24gem 'marginalia', '~> 1.10.0'
25
26# Authorization
27gem 'declarative_policy', '~> 1.0.0'
28
29# Authentication libraries
30gem 'devise', '~> 4.7.2'
31gem 'bcrypt', '~> 3.1', '>= 3.1.14'
32gem 'doorkeeper', '~> 5.5.0.rc2'
33gem 'doorkeeper-openid_connect', '~> 1.7.5'
34gem 'rexml', '~> 3.2.5'
35gem 'ruby-saml', '~> 1.13.0'
36gem 'omniauth', '~> 1.8'
37gem 'omniauth-auth0', '~> 2.0.0'
38gem 'omniauth-azure-activedirectory-v2', '~> 1.0'
39gem 'omniauth-azure-oauth2', '~> 0.0.9' # Deprecated v1 version
40gem 'omniauth-cas3', '~> 1.1.4'
41gem 'omniauth-facebook', '~> 4.0.0'
42gem 'omniauth-github', '~> 1.4'
43gem 'omniauth-gitlab', '~> 1.0.2'
44gem 'omniauth-google-oauth2', '~> 0.6.0'
45gem 'omniauth-kerberos', '~> 0.3.0', group: :kerberos
46gem 'omniauth-oauth2-generic', '~> 0.2.2'
47gem 'omniauth-saml', '~> 1.10'
48gem 'omniauth-shibboleth', '~> 1.3.0'
49gem 'omniauth-twitter', '~> 1.4'
50gem 'omniauth_crowd', '~> 2.4.0'
51gem 'omniauth-authentiq', '~> 0.3.3'
52gem 'gitlab-omniauth-openid-connect', '~> 0.8.0', require: 'omniauth_openid_connect'
53gem 'omniauth-salesforce', '~> 1.0.5'
54gem 'omniauth-atlassian-oauth2', '~> 0.2.0'
55gem 'rack-oauth2', '~> 1.16.0'
56gem 'jwt', '~> 2.1.0'
57
58# Kerberos authentication. EE-only
59gem 'gssapi', group: :kerberos
60
61# Spam and anti-bot protection
62gem 'recaptcha', '~> 4.11', require: 'recaptcha/rails'
63gem 'akismet', '~> 3.0'
64gem 'invisible_captcha', '~> 1.1.0'
65
66# Two-factor authentication
67gem 'devise-two-factor', '~> 4.0.0'
68gem 'rqrcode-rails3', '~> 0.1.7'
69gem 'attr_encrypted', '~> 3.1.0'
70gem 'u2f', '~> 0.2.1'
71
72# GitLab Pages
73gem 'validates_hostname', '~> 1.0.11'
74gem 'rubyzip', '~> 2.0.0', require: 'zip'
75# GitLab Pages letsencrypt support
76gem 'acme-client', '~> 2.0', '>= 2.0.6'
77
78# Browser detection
79gem 'browser', '~> 4.2'
80
81# OS detection for usage ping
82gem 'ohai', '~> 16.10'
83
84# GPG
85gem 'gpgme', '~> 2.0.19'
86
87# LDAP Auth
88# GitLab fork with several improvements to original library. For full list of changes
89# see https://github.com/intridea/omniauth-ldap/compare/master...gitlabhq:master
90gem 'gitlab_omniauth-ldap', '~> 2.1.1', require: 'omniauth-ldap'
91gem 'net-ldap', '~> 0.16.3'
92
93# API
94gem 'grape', '~> 1.5.2'
95gem 'grape-entity', '~> 0.10.0'
96gem 'rack-cors', '~> 1.0.6', require: 'rack/cors'
97
98# GraphQL API
99gem 'graphql', '~> 1.11.8'
100# NOTE: graphiql-rails v1.5+ doesn't work: https://gitlab.com/gitlab-org/gitlab/issues/31771
101# TODO: remove app/views/graphiql/rails/editors/show.html.erb when https://github.com/rmosolgo/graphiql-rails/pull/71 is released:
102# https://gitlab.com/gitlab-org/gitlab/issues/31747
103gem 'graphiql-rails', '~> 1.4.10'
104gem 'apollo_upload_server', '~> 2.1.0'
105gem 'graphql-docs', '~> 1.6.0', group: [:development, :test]
106gem 'graphlient', '~> 0.4.0' # Used by BulkImport feature (group::import)
107
108gem 'hashie'
109# Disable strong_params so that Mash does not respond to :permitted?
110gem 'hashie-forbidden_attributes'
111
112# Pagination
113gem 'kaminari', '~> 1.0'
114
115# HAML
116gem 'hamlit', '~> 2.15.0'
117
118# Files attachments
119gem 'carrierwave', '~> 1.3'
120gem 'mini_magick', '~> 4.10.1'
121
122# for backups
123gem 'fog-aws', '~> 3.12'
124# Locked until fog-google resolves https://github.com/fog/fog-google/issues/421.
125# Also see config/initializers/fog_core_patch.rb.
126gem 'fog-core', '= 2.1.0'
127gem 'fog-google', '~> 1.15', require: 'fog/google'
128gem 'fog-local', '~> 0.6'
129gem 'fog-openstack', '~> 1.0'
130gem 'fog-rackspace', '~> 0.1.1'
131gem 'fog-aliyun', '~> 0.3'
132gem 'gitlab-fog-azure-rm', '~> 1.2.0', require: false
133
134# for Google storage
135gem 'google-api-client', '~> 0.33'
136
137# for aws storage
138gem 'unf', '~> 0.1.4'
139
140# Seed data
141gem 'seed-fu', '~> 2.3.7'
142
143# Search
144gem 'elasticsearch-model', '~> 6.1'
145gem 'elasticsearch-rails', '~> 6.1', require: 'elasticsearch/rails/instrumentation'
146gem 'elasticsearch-api', '~> 6.8.2'
147gem 'aws-sdk-core', '~> 3'
148gem 'aws-sdk-cloudformation', '~> 1'
149gem 'aws-sdk-s3', '~> 1'
150gem 'faraday_middleware-aws-sigv4', '~>0.3.0'
151
152# Markdown and HTML processing
153gem 'html-pipeline', '~> 2.13.2'
154gem 'deckar01-task_list', '2.3.1'
155gem 'gitlab-markup', '~> 1.7.1'
156gem 'github-markup', '~> 1.7.0', require: 'github/markup'
157gem 'commonmarker', '~> 0.23.2'
158gem 'kramdown', '~> 2.3.1'
159gem 'RedCloth', '~> 4.3.2'
160gem 'rdoc', '~> 6.3.2'
161gem 'org-ruby', '~> 0.9.12'
162gem 'creole', '~> 0.5.0'
163gem 'wikicloth', '0.8.1'
164gem 'asciidoctor', '~> 2.0.10'
165gem 'asciidoctor-include-ext', '~> 0.3.1', require: false
166gem 'asciidoctor-plantuml', '~> 0.0.12'
167gem 'asciidoctor-kroki', '~> 0.5.0', require: false
168gem 'rouge', '~> 3.26.1'
169gem 'truncato', '~> 0.7.11'
170gem 'bootstrap_form', '~> 4.2.0'
171gem 'nokogiri', '~> 1.11.4'
172gem 'escape_utils', '~> 1.1'
173
174# Calendar rendering
175gem 'icalendar'
176
177# Diffs
178gem 'diffy', '~> 3.3'
179gem 'diff_match_patch', '~> 0.1.0'
180
181# Application server
182gem 'rack', '~> 2.2.3'
183# https://github.com/sharpstone/rack-timeout/blob/master/README.md#rails-apps-manually
184gem 'rack-timeout', '~> 0.5.1', require: 'rack/timeout/base'
185
186group :puma do
187 gem 'puma', '~> 5.3.1', require: false
188 gem 'puma_worker_killer', '~> 0.3.1', require: false
189end
190
191# State machine
192gem 'state_machines-activerecord', '~> 0.8.0'
193
194# Issue tags
195gem 'acts-as-taggable-on', '~> 7.0'
196
197# Background jobs
198gem 'sidekiq', '~> 6.2.2'
199gem 'sidekiq-cron', '~> 1.0'
200gem 'redis-namespace', '~> 1.8.1'
201gem 'gitlab-sidekiq-fetcher', '0.8.0', require: 'sidekiq-reliable-fetch'
202
203# Cron Parser
204gem 'fugit', '~> 1.2.1'
205
206# HTTP requests
207gem 'httparty', '~> 0.16.4'
208
209# Colored output to console
210gem 'rainbow', '~> 3.0'
211
212# Progress bar
213gem 'ruby-progressbar', '~> 1.10'
214
215# GitLab settings
216gem 'settingslogic', '~> 2.0.9'
217
218# Linear-time regex library for untrusted regular expressions
219gem 're2', '~> 1.2.0'
220
221# Misc
222
223gem 'version_sorter', '~> 2.2.4'
224
225# Export Ruby Regex to Javascript
226gem 'js_regex', '~> 3.7'
227
228# User agent parsing
229gem 'device_detector'
230
231# Redis
232gem 'redis', '~> 4.4.0'
233gem 'connection_pool', '~> 2.0'
234
235# Redis session store
236gem 'redis-actionpack', '~> 5.2.0'
237
238# Discord integration
239gem 'discordrb-webhooks', '~> 3.4', require: false
240
241# Jira integration
242gem 'jira-ruby', '~> 2.1.4'
243gem 'atlassian-jwt', '~> 0.2.0'
244
245# Flowdock integration
246gem 'flowdock', '~> 0.7'
247
248# Slack integration
249gem 'slack-messenger', '~> 2.3.4'
250
251# Hangouts Chat integration
252gem 'hangouts-chat', '~> 0.0.5', require: 'hangouts_chat'
253
254# Asana integration
255gem 'asana', '~> 0.10.3'
256
257# FogBugz integration
258gem 'ruby-fogbugz', '~> 0.2.1'
259
260# Kubernetes integration
261gem 'kubeclient', '~> 4.9.2'
262
263# Sanitize user input
264gem 'sanitize', '~> 5.2.1'
265gem 'babosa', '~> 1.0.4'
266
267# Sanitizes SVG input
268gem 'loofah', '~> 2.2'
269
270# Working with license
271gem 'licensee', '~> 9.14.1'
272
273# Detect and convert string character encoding
274gem 'charlock_holmes', '~> 0.7.7'
275
276# Detect mime content type from content
277gem 'ruby-magic', '~> 0.4'
278
279# Faster blank
280gem 'fast_blank'
281
282# Parse time & duration
283gem 'gitlab-chronic', '~> 0.10.5'
284gem 'gitlab_chronic_duration', '~> 0.10.6.2'
285
286gem 'rack-proxy', '~> 0.6.0'
287
288gem 'sassc-rails', '~> 2.1.0'
289gem 'autoprefixer-rails', '10.2.5.1'
290gem 'terser', '1.0.2'
291
292gem 'addressable', '~> 2.8'
293gem 'gemojione', '~> 3.3'
294gem 'gon', '~> 6.4.0'
295gem 'request_store', '~> 1.5'
296gem 'base32', '~> 0.3.0'
297
298gem 'gitlab-license', '~> 2.0'
299
300# Protect against bruteforcing
301gem 'rack-attack', '~> 6.3.0'
302
303# Sentry integration
304gem 'sentry-raven', '~> 3.1'
305
306# PostgreSQL query parsing
307#
308gem 'pg_query', '~> 2.1'
309
310gem 'premailer-rails', '~> 1.10.3'
311
312# LabKit: Tracing and Correlation
313gem 'gitlab-labkit', '~> 0.21.1'
314# Thrift is a dependency of gitlab-labkit, we want a version higher than 0.14.0
315# because of https://gitlab.com/gitlab-org/gitlab/-/issues/321900
316gem 'thrift', '>= 0.14.0'
317
318# I18n
319gem 'ruby_parser', '~> 3.15', require: false
320gem 'rails-i18n', '~> 6.0'
321gem 'gettext_i18n_rails', '~> 1.8.0'
322gem 'gettext_i18n_rails_js', '~> 1.3'
323gem 'gettext', '~> 3.3', require: false, group: :development
324
325gem 'batch-loader', '~> 2.0.1'
326
327# Perf bar
328gem 'peek', '~> 1.1'
329
330# Snowplow events tracking
331gem 'snowplow-tracker', '~> 0.6.1'
332
333# Metrics
334gem 'method_source', '~> 1.0', require: false
335gem 'webrick', '~> 1.6.1', require: false
336gem 'prometheus-client-mmap', '~> 0.15.0', require: 'prometheus/client'
337
338gem 'warning', '~> 1.2.0'
339
340group :development do
341 gem 'lefthook', '~> 0.7.0', require: false
342 gem 'solargraph', '~> 0.43', require: false
343
344 gem 'letter_opener_web', '~> 1.4.1'
345
346 # Better errors handler
347 gem 'better_errors', '~> 2.9.0'
348
349 # thin instead webrick
350 gem 'thin', '~> 1.8.0'
351end
352
353group :development, :test do
354 gem 'deprecation_toolkit', '~> 1.5.1', require: false
355 gem 'bullet', '~> 6.1.3'
356 gem 'pry-byebug'
357 gem 'pry-rails', '~> 0.3.9'
358 gem 'pry-shell', '~> 0.5.0'
359
360 gem 'awesome_print', require: false
361
362 gem 'database_cleaner', '~> 1.7.0'
363 gem 'factory_bot_rails', '~> 6.2.0'
364 gem 'rspec-rails', '~> 5.0.1'
365
366 # Prevent occasions where minitest is not bundled in packaged versions of ruby (see #3826)
367 gem 'minitest', '~> 5.11.0'
368
369 # Generate Fake data
370 gem 'ffaker', '~> 2.10'
371
372 gem 'spring', '~> 2.1.0'
373 gem 'spring-commands-rspec', '~> 1.0.4'
374
375 gem 'gitlab-styles', '~> 6.3.0', require: false
376
377 gem 'haml_lint', '~> 0.36.0', require: false
378 gem 'bundler-audit', '~> 0.7.0.1', require: false
379
380 gem 'benchmark-ips', '~> 2.3.0', require: false
381
382 gem 'knapsack', '~> 1.21.1'
383 gem 'crystalball', '~> 0.7.0', require: false
384
385 gem 'simple_po_parser', '~> 1.1.2', require: false
386
387 gem 'timecop', '~> 0.9.1'
388
389 gem 'png_quantizator', '~> 0.2.1', require: false
390
391 gem 'parallel', '~> 1.19', require: false
392
393 gem 'rblineprof', '~> 0.3.6', platform: :mri, require: false
394
395 gem 'test_file_finder', '~> 0.1.3'
396end
397
398group :development, :test, :danger do
399 gem 'gitlab-dangerfiles', '~> 2.3.0', require: false
400end
401
402group :development, :test, :coverage do
403 gem 'simplecov', '~> 0.18.5', require: false
404 gem 'simplecov-cobertura', '~> 1.3.1', require: false
405end
406
407# Gems required in omnibus-gitlab pipeline
408group :development, :test, :omnibus do
409 gem 'license_finder', '~> 6.0', require: false
410end
411
412group :test do
413 gem 'fuubar', '~> 2.2.0'
414 gem 'rspec-retry', '~> 0.6.1'
415 gem 'rspec_profiling', '~> 0.0.6'
416 gem 'rspec-parameterized', require: false
417
418 gem 'capybara', '~> 3.35.3'
419 gem 'capybara-screenshot', '~> 1.0.22'
420 gem 'selenium-webdriver', '~> 3.142'
421
422 gem 'shoulda-matchers', '~> 4.0.1', require: false
423 gem 'email_spec', '~> 2.2.0'
424 gem 'webmock', '~> 3.9.1'
425 gem 'rails-controller-testing'
426 gem 'concurrent-ruby', '~> 1.1'
427 gem 'test-prof', '~> 1.0.7'
428 gem 'rspec_junit_formatter'
429 gem 'guard-rspec'
430
431 # Moved in `test` because https://gitlab.com/gitlab-org/gitlab/-/issues/217527
432 gem 'derailed_benchmarks', require: false
433end
434
435gem 'octokit', '~> 4.15'
436
437# https://gitlab.com/gitlab-org/gitlab/issues/207207
438gem 'gitlab-mail_room', '~> 0.0.9', require: 'mail_room'
439
440gem 'email_reply_trimmer', '~> 0.1'
441gem 'html2text'
442
443gem 'ruby-prof', '~> 1.3.0'
444gem 'stackprof', '~> 0.2.15', require: false
445gem 'rbtrace', '~> 0.4', require: false
446gem 'memory_profiler', '~> 0.9', require: false
447gem 'benchmark-memory', '~> 0.1', require: false
448gem 'activerecord-explain-analyze', '~> 0.1', require: false
449
450# OAuth
451gem 'oauth2', '~> 1.4'
452
453# Health check
454gem 'health_check', '~> 3.0'
455
456# System information
457gem 'vmstat', '~> 2.3.0'
458gem 'sys-filesystem', '~> 1.1.6'
459
460# NTP client
461gem 'net-ntp'
462
463# SSH host key support
464gem 'net-ssh', '~> 6.0'
465gem 'sshkey', '~> 2.0'
466
467# Required for ED25519 SSH host key support
468group :ed25519 do
469 gem 'ed25519', '~> 1.2'
470 gem 'bcrypt_pbkdf', '~> 1.0'
471end
472
473# Spamcheck GRPC protocol definitions
474gem 'spamcheck', '~> 0.1.0'
475
476# Gitaly GRPC protocol definitions
477gem 'gitaly', '~> 14.3.0.pre.rc2'
478
479# KAS GRPC protocol definitions
480gem 'kas-grpc', '~> 0.0.2'
481
482gem 'grpc', '~> 1.30.2'
483
484gem 'google-protobuf', '~> 3.17.1'
485
486gem 'toml-rb', '~> 2.0'
487
488# Feature toggles
489gem 'flipper', '~> 0.21.0'
490gem 'flipper-active_record', '~> 0.21.0'
491gem 'flipper-active_support_cache_store', '~> 0.21.0'
492gem 'unleash', '~> 3.2.2'
493gem 'gitlab-experiment', '~> 0.6.4'
494
495# Structured logging
496gem 'lograge', '~> 0.5'
497gem 'grape_logging', '~> 1.7'
498
499# DNS Lookup
500gem 'gitlab-net-dns', '~> 0.9.1'
501
502# Countries list
503gem 'countries', '~> 3.0'
504
505gem 'retriable', '~> 3.1.2'
506
507# LRU cache
508gem 'lru_redux'
509
510gem 'erubi', '~> 1.9.0'
511
512# Locked as long as quoted-printable encoding issues are not resolved
513# Monkey-patched in `config/initializers/mail_encoding_patch.rb`
514# See https://gitlab.com/gitlab-org/gitlab/issues/197386
515gem 'mail', '= 2.7.1'
516
517
518# File encryption
519gem 'lockbox', '~> 0.6.2'
520
521# Email validation
522gem 'valid_email', '~> 0.1'
523
524# JSON
525gem 'json', '~> 2.5.1'
526gem 'json_schemer', '~> 0.2.18'
527gem 'oj', '~> 3.10.6'
528gem 'multi_json', '~> 1.14.1'
529gem 'yajl-ruby', '~> 1.4.1', require: 'yajl'
530
531gem 'webauthn', '~> 2.3'
532
533# IPAddress utilities
534gem 'ipaddress', '~> 0.8.3'
535
536gem 'parslet', '~> 1.8'
537
538gem 'sd_notify'