gitlab: Refactor for new repo structure
GitLab recently restructured their repos; whereas previously they had one gitlab-ce and one gitlab-ee repo, they're now one and the same. All proprietary components are put into the ee subdirectory - removing it gives us the foss / community version of GitLab. For more info, see https://about.gitlab.com/2019/02/21/merging-ce-and-ee-codebases/ This gives us the opportunity to simplify things quite a bit, since we don't have to keep track of two separate versions of either the base data or rubyEnv.
This commit is contained in:
parent
59324d1fb9
commit
afa3abf632
@ -1,32 +1,13 @@
|
|||||||
{
|
{
|
||||||
"ce": {
|
"version": "12.3.4",
|
||||||
"version": "12.3.4",
|
"repo_hash": "152gg7h0zwzih93ajn3ki5ij8c1fbanlgwl40i44nnsk79m8jbia",
|
||||||
"repo_hash": "02nfgwvm8z8cn64qlkvjmj9mvxqy9aszzdsmfr0kjjq0zzg7l7hk",
|
"owner": "gitlab-org",
|
||||||
"deb_hash": "09iwrqdx897i35hb0dvw13s0747wqcqk67h855a9abm5phbkv4bb",
|
"repo": "gitlab",
|
||||||
"deb_url": "https://packages.gitlab.com/gitlab/gitlab-ce/packages/debian/stretch/gitlab-ce_12.3.4-ce.0_amd64.deb/download.deb",
|
"rev": "v12.3.4-ee",
|
||||||
"owner": "gitlab-org",
|
"passthru": {
|
||||||
"repo": "gitlab-foss",
|
"GITALY_SERVER_VERSION": "1.65.1",
|
||||||
"rev": "v12.3.4",
|
"GITLAB_PAGES_VERSION": "1.9.0",
|
||||||
"passthru": {
|
"GITLAB_SHELL_VERSION": "10.0.0",
|
||||||
"GITALY_SERVER_VERSION": "1.65.1",
|
"GITLAB_WORKHORSE_VERSION": "8.10.0"
|
||||||
"GITLAB_PAGES_VERSION": "1.9.0",
|
|
||||||
"GITLAB_SHELL_VERSION": "10.0.0",
|
|
||||||
"GITLAB_WORKHORSE_VERSION": "8.10.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"ee": {
|
|
||||||
"version": "12.3.4",
|
|
||||||
"repo_hash": "152gg7h0zwzih93ajn3ki5ij8c1fbanlgwl40i44nnsk79m8jbia",
|
|
||||||
"deb_hash": "1kyw3r0l5h79sfckfqwwfd7g2zxslywksbv58yhar6nwcidrjags",
|
|
||||||
"deb_url": "https://packages.gitlab.com/gitlab/gitlab-ee/packages/debian/stretch/gitlab-ee_12.3.4-ee.0_amd64.deb/download.deb",
|
|
||||||
"owner": "gitlab-org",
|
|
||||||
"repo": "gitlab",
|
|
||||||
"rev": "v12.3.4-ee",
|
|
||||||
"passthru": {
|
|
||||||
"GITALY_SERVER_VERSION": "1.65.1",
|
|
||||||
"GITLAB_PAGES_VERSION": "1.9.0",
|
|
||||||
"GITLAB_SHELL_VERSION": "10.0.0",
|
|
||||||
"GITLAB_WORKHORSE_VERSION": "8.10.0"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -5,8 +5,7 @@
|
|||||||
}:
|
}:
|
||||||
|
|
||||||
let
|
let
|
||||||
flavour = if gitlabEnterprise then "ee" else "ce";
|
data = (builtins.fromJSON (builtins.readFile ./data.json));
|
||||||
data = (builtins.fromJSON (builtins.readFile ./data.json)).${flavour};
|
|
||||||
|
|
||||||
version = data.version;
|
version = data.version;
|
||||||
src = fetchFromGitLab {
|
src = fetchFromGitLab {
|
||||||
@ -19,7 +18,7 @@ let
|
|||||||
rubyEnv = bundlerEnv rec {
|
rubyEnv = bundlerEnv rec {
|
||||||
name = "gitlab-env-${version}";
|
name = "gitlab-env-${version}";
|
||||||
inherit ruby;
|
inherit ruby;
|
||||||
gemdir = ./rubyEnv- + (if gitlabEnterprise then "ee" else "ce");
|
gemdir = ./rubyEnv;
|
||||||
gemset =
|
gemset =
|
||||||
let x = import (gemdir + "/gemset.nix");
|
let x = import (gemdir + "/gemset.nix");
|
||||||
in x // {
|
in x // {
|
||||||
@ -93,7 +92,7 @@ let
|
|||||||
};
|
};
|
||||||
in
|
in
|
||||||
stdenv.mkDerivation {
|
stdenv.mkDerivation {
|
||||||
name = "gitlab${if gitlabEnterprise then "-ee" else ""}-${version}";
|
name = "gitlab${lib.optionalString gitlabEnterprise "-ee"}-${version}";
|
||||||
|
|
||||||
inherit src;
|
inherit src;
|
||||||
|
|
||||||
@ -104,6 +103,11 @@ stdenv.mkDerivation {
|
|||||||
patches = [ ./remove-hardcoded-locations.patch ];
|
patches = [ ./remove-hardcoded-locations.patch ];
|
||||||
|
|
||||||
postPatch = ''
|
postPatch = ''
|
||||||
|
${lib.optionalString (!gitlabEnterprise) ''
|
||||||
|
# Remove all proprietary components
|
||||||
|
rm -rf ee
|
||||||
|
''}
|
||||||
|
|
||||||
# For reasons I don't understand "bundle exec" ignores the
|
# For reasons I don't understand "bundle exec" ignores the
|
||||||
# RAILS_ENV causing tests to be executed that fail because we're
|
# RAILS_ENV causing tests to be executed that fail because we're
|
||||||
# not installing development and test gems above. Deleting the
|
# not installing development and test gems above. Deleting the
|
||||||
@ -138,7 +142,7 @@ stdenv.mkDerivation {
|
|||||||
'';
|
'';
|
||||||
|
|
||||||
passthru = {
|
passthru = {
|
||||||
inherit rubyEnv;
|
inherit rubyEnv assets;
|
||||||
ruby = rubyEnv.wrappedRuby;
|
ruby = rubyEnv.wrappedRuby;
|
||||||
GITALY_SERVER_VERSION = data.passthru.GITALY_SERVER_VERSION;
|
GITALY_SERVER_VERSION = data.passthru.GITALY_SERVER_VERSION;
|
||||||
GITLAB_PAGES_VERSION = data.passthru.GITLAB_PAGES_VERSION;
|
GITLAB_PAGES_VERSION = data.passthru.GITLAB_PAGES_VERSION;
|
||||||
|
@ -1,471 +0,0 @@
|
|||||||
source 'https://rubygems.org'
|
|
||||||
|
|
||||||
gem 'rails', '5.2.3'
|
|
||||||
|
|
||||||
gem 'bootsnap', '~> 1.4'
|
|
||||||
|
|
||||||
# Improves copy-on-write performance for MRI
|
|
||||||
gem 'nakayoshi_fork', '~> 0.0.4'
|
|
||||||
|
|
||||||
# Responders respond_to and respond_with
|
|
||||||
gem 'responders', '~> 2.0'
|
|
||||||
|
|
||||||
gem 'sprockets', '~> 3.7.0'
|
|
||||||
|
|
||||||
# Default values for AR models
|
|
||||||
gem 'default_value_for', '~> 3.2.0'
|
|
||||||
|
|
||||||
# Supported DBs
|
|
||||||
gem 'pg', '~> 1.1'
|
|
||||||
|
|
||||||
gem 'rugged', '~> 0.28'
|
|
||||||
gem 'grape-path-helpers', '~> 1.1'
|
|
||||||
|
|
||||||
gem 'faraday', '~> 0.12'
|
|
||||||
|
|
||||||
# Authentication libraries
|
|
||||||
gem 'devise', '~> 4.6'
|
|
||||||
gem 'doorkeeper', '~> 4.3'
|
|
||||||
gem 'doorkeeper-openid_connect', '~> 1.5'
|
|
||||||
gem 'omniauth', '~> 1.8'
|
|
||||||
gem 'omniauth-auth0', '~> 2.0.0'
|
|
||||||
gem 'omniauth-azure-oauth2', '~> 0.0.9'
|
|
||||||
gem 'omniauth-cas3', '~> 1.1.4'
|
|
||||||
gem 'omniauth-facebook', '~> 4.0.0'
|
|
||||||
gem 'omniauth-github', '~> 1.3'
|
|
||||||
gem 'omniauth-gitlab', '~> 1.0.2'
|
|
||||||
gem 'omniauth-google-oauth2', '~> 0.6.0'
|
|
||||||
gem 'omniauth-kerberos', '~> 0.3.0', group: :kerberos
|
|
||||||
gem 'omniauth-oauth2-generic', '~> 0.2.2'
|
|
||||||
gem 'omniauth-saml', '~> 1.10'
|
|
||||||
gem 'omniauth-shibboleth', '~> 1.3.0'
|
|
||||||
gem 'omniauth-twitter', '~> 1.4'
|
|
||||||
gem 'omniauth_crowd', '~> 2.2.0'
|
|
||||||
gem 'omniauth-authentiq', '~> 0.3.3'
|
|
||||||
gem 'omniauth_openid_connect', '~> 0.3.1'
|
|
||||||
gem "omniauth-ultraauth", '~> 0.0.2'
|
|
||||||
gem 'omniauth-salesforce', '~> 1.0.5'
|
|
||||||
gem 'rack-oauth2', '~> 1.9.3'
|
|
||||||
gem 'jwt', '~> 2.1.0'
|
|
||||||
|
|
||||||
# Kerberos authentication. EE-only
|
|
||||||
gem 'gssapi', group: :kerberos
|
|
||||||
|
|
||||||
# Spam and anti-bot protection
|
|
||||||
gem 'recaptcha', '~> 4.11', require: 'recaptcha/rails'
|
|
||||||
gem 'akismet', '~> 2.0'
|
|
||||||
gem 'invisible_captcha', '~> 0.12.1'
|
|
||||||
|
|
||||||
# Two-factor authentication
|
|
||||||
gem 'devise-two-factor', '~> 3.0.0'
|
|
||||||
gem 'rqrcode-rails3', '~> 0.1.7'
|
|
||||||
gem 'attr_encrypted', '~> 3.1.0'
|
|
||||||
gem 'u2f', '~> 0.2.1'
|
|
||||||
|
|
||||||
# GitLab Pages
|
|
||||||
gem 'validates_hostname', '~> 1.0.6'
|
|
||||||
gem 'rubyzip', '~> 1.2.2', require: 'zip'
|
|
||||||
# GitLab Pages letsencrypt support
|
|
||||||
gem 'acme-client', '~> 2.0.2'
|
|
||||||
|
|
||||||
# Browser detection
|
|
||||||
gem 'browser', '~> 2.5'
|
|
||||||
|
|
||||||
# GPG
|
|
||||||
gem 'gpgme', '~> 2.0.18'
|
|
||||||
|
|
||||||
# LDAP Auth
|
|
||||||
# GitLab fork with several improvements to original library. For full list of changes
|
|
||||||
# see https://github.com/intridea/omniauth-ldap/compare/master...gitlabhq:master
|
|
||||||
gem 'gitlab_omniauth-ldap', '~> 2.1.1', require: 'omniauth-ldap'
|
|
||||||
gem 'net-ldap'
|
|
||||||
|
|
||||||
# API
|
|
||||||
gem 'grape', '~> 1.1.0'
|
|
||||||
gem 'grape-entity', '~> 0.7.1'
|
|
||||||
gem 'rack-cors', '~> 1.0.0', require: 'rack/cors'
|
|
||||||
|
|
||||||
# GraphQL API
|
|
||||||
gem 'graphql', '~> 1.9.11'
|
|
||||||
# NOTE: graphiql-rails v1.5+ doesn't work: https://gitlab.com/gitlab-org/gitlab-ce/issues/67293
|
|
||||||
# TODO: remove app/views/graphiql/rails/editors/show.html.erb when https://github.com/rmosolgo/graphiql-rails/pull/71 is released:
|
|
||||||
# https://gitlab.com/gitlab-org/gitlab-ce/issues/67263
|
|
||||||
gem 'graphiql-rails', '~> 1.4.10'
|
|
||||||
gem 'apollo_upload_server', '~> 2.0.0.beta3'
|
|
||||||
gem 'graphql-docs', '~> 1.6.0', group: [:development, :test]
|
|
||||||
|
|
||||||
# Disable strong_params so that Mash does not respond to :permitted?
|
|
||||||
gem 'hashie-forbidden_attributes'
|
|
||||||
|
|
||||||
# Pagination
|
|
||||||
gem 'kaminari', '~> 1.0'
|
|
||||||
|
|
||||||
# HAML
|
|
||||||
gem 'hamlit', '~> 2.8.8'
|
|
||||||
|
|
||||||
# Files attachments
|
|
||||||
gem 'carrierwave', '~> 1.3'
|
|
||||||
gem 'mini_magick'
|
|
||||||
|
|
||||||
# for backups
|
|
||||||
gem 'fog-aws', '~> 3.5'
|
|
||||||
# Locked until fog-google resolves https://github.com/fog/fog-google/issues/421.
|
|
||||||
# Also see config/initializers/fog_core_patch.rb.
|
|
||||||
gem 'fog-core', '= 2.1.0'
|
|
||||||
gem 'fog-google', '~> 1.9'
|
|
||||||
gem 'fog-local', '~> 0.6'
|
|
||||||
gem 'fog-openstack', '~> 1.0'
|
|
||||||
gem 'fog-rackspace', '~> 0.1.1'
|
|
||||||
gem 'fog-aliyun', '~> 0.3'
|
|
||||||
|
|
||||||
# for Google storage
|
|
||||||
gem 'google-api-client', '~> 0.23'
|
|
||||||
|
|
||||||
# for aws storage
|
|
||||||
gem 'unf', '~> 0.1.4'
|
|
||||||
|
|
||||||
# Seed data
|
|
||||||
gem 'seed-fu', '~> 2.3.7'
|
|
||||||
|
|
||||||
# Search
|
|
||||||
gem 'elasticsearch-model', '~> 0.1.9'
|
|
||||||
gem 'elasticsearch-rails', '~> 0.1.9', require: 'elasticsearch/rails/instrumentation'
|
|
||||||
gem 'elasticsearch-api', '5.0.3'
|
|
||||||
gem 'aws-sdk'
|
|
||||||
gem 'faraday_middleware-aws-signers-v4'
|
|
||||||
|
|
||||||
# Markdown and HTML processing
|
|
||||||
gem 'html-pipeline', '~> 2.8'
|
|
||||||
gem 'deckar01-task_list', '2.2.0'
|
|
||||||
gem 'gitlab-markup', '~> 1.7.0'
|
|
||||||
gem 'github-markup', '~> 1.7.0', require: 'github/markup'
|
|
||||||
gem 'commonmarker', '~> 0.17'
|
|
||||||
gem 'RedCloth', '~> 4.3.2'
|
|
||||||
gem 'rdoc', '~> 6.0'
|
|
||||||
gem 'org-ruby', '~> 0.9.12'
|
|
||||||
gem 'creole', '~> 0.5.0'
|
|
||||||
gem 'wikicloth', '0.8.1'
|
|
||||||
gem 'asciidoctor', '~> 2.0.10'
|
|
||||||
gem 'asciidoctor-include-ext', '~> 0.3.1', require: false
|
|
||||||
gem 'asciidoctor-plantuml', '0.0.9'
|
|
||||||
gem 'rouge', '~> 3.7'
|
|
||||||
gem 'truncato', '~> 0.7.11'
|
|
||||||
gem 'bootstrap_form', '~> 4.2.0'
|
|
||||||
gem 'nokogiri', '~> 1.10.4'
|
|
||||||
gem 'escape_utils', '~> 1.1'
|
|
||||||
|
|
||||||
# Calendar rendering
|
|
||||||
gem 'icalendar'
|
|
||||||
|
|
||||||
# Diffs
|
|
||||||
gem 'diffy', '~> 3.1.0'
|
|
||||||
|
|
||||||
# Application server
|
|
||||||
gem 'rack', '~> 2.0.7'
|
|
||||||
|
|
||||||
group :unicorn do
|
|
||||||
gem 'unicorn', '~> 5.4.1'
|
|
||||||
gem 'unicorn-worker-killer', '~> 0.4.4'
|
|
||||||
end
|
|
||||||
|
|
||||||
group :puma do
|
|
||||||
gem 'puma', '~> 3.12', require: false
|
|
||||||
gem 'puma_worker_killer', require: false
|
|
||||||
gem 'rack-timeout', require: false
|
|
||||||
end
|
|
||||||
|
|
||||||
# State machine
|
|
||||||
gem 'state_machines-activerecord', '~> 0.5.1'
|
|
||||||
|
|
||||||
# Issue tags
|
|
||||||
gem 'acts-as-taggable-on', '~> 6.0'
|
|
||||||
|
|
||||||
# Background jobs
|
|
||||||
gem 'sidekiq', '~> 5.2.7'
|
|
||||||
gem 'sidekiq-cron', '~> 1.0'
|
|
||||||
gem 'redis-namespace', '~> 1.6.0'
|
|
||||||
gem 'gitlab-sidekiq-fetcher', '0.5.2', require: 'sidekiq-reliable-fetch'
|
|
||||||
|
|
||||||
# Cron Parser
|
|
||||||
gem 'fugit', '~> 1.2.1'
|
|
||||||
|
|
||||||
# HTTP requests
|
|
||||||
gem 'httparty', '~> 0.16.4'
|
|
||||||
|
|
||||||
# Colored output to console
|
|
||||||
gem 'rainbow', '~> 3.0'
|
|
||||||
|
|
||||||
# Progress bar
|
|
||||||
gem 'ruby-progressbar'
|
|
||||||
|
|
||||||
# GitLab settings
|
|
||||||
gem 'settingslogic', '~> 2.0.9'
|
|
||||||
|
|
||||||
# Linear-time regex library for untrusted regular expressions
|
|
||||||
gem 're2', '~> 1.1.1'
|
|
||||||
|
|
||||||
# Misc
|
|
||||||
|
|
||||||
gem 'version_sorter', '~> 2.2.4'
|
|
||||||
|
|
||||||
# Export Ruby Regex to Javascript
|
|
||||||
gem 'js_regex', '~> 3.1'
|
|
||||||
|
|
||||||
# User agent parsing
|
|
||||||
gem 'device_detector'
|
|
||||||
|
|
||||||
# Redis
|
|
||||||
gem 'redis', '~> 4.0'
|
|
||||||
gem 'connection_pool', '~> 2.0'
|
|
||||||
|
|
||||||
# Redis session store
|
|
||||||
gem 'redis-rails', '~> 5.0.2'
|
|
||||||
|
|
||||||
# Discord integration
|
|
||||||
gem 'discordrb-webhooks-blackst0ne', '~> 3.3', require: false
|
|
||||||
|
|
||||||
# HipChat integration
|
|
||||||
gem 'hipchat', '~> 1.5.0'
|
|
||||||
|
|
||||||
# Jira integration
|
|
||||||
gem 'jira-ruby', '~> 1.7'
|
|
||||||
gem 'atlassian-jwt', '~> 0.2.0'
|
|
||||||
|
|
||||||
# Flowdock integration
|
|
||||||
gem 'flowdock', '~> 0.7'
|
|
||||||
|
|
||||||
# Slack integration
|
|
||||||
gem 'slack-notifier', '~> 1.5.1'
|
|
||||||
|
|
||||||
# Hangouts Chat integration
|
|
||||||
gem 'hangouts-chat', '~> 0.0.5'
|
|
||||||
|
|
||||||
# Asana integration
|
|
||||||
gem 'asana', '~> 0.8.1'
|
|
||||||
|
|
||||||
# FogBugz integration
|
|
||||||
gem 'ruby-fogbugz', '~> 0.2.1'
|
|
||||||
|
|
||||||
# Kubernetes integration
|
|
||||||
gem 'kubeclient', '~> 4.4.0'
|
|
||||||
|
|
||||||
# Sanitize user input
|
|
||||||
gem 'sanitize', '~> 4.6'
|
|
||||||
gem 'babosa', '~> 1.0.2'
|
|
||||||
|
|
||||||
# Sanitizes SVG input
|
|
||||||
gem 'loofah', '~> 2.2'
|
|
||||||
|
|
||||||
# Working with license
|
|
||||||
gem 'licensee', '~> 8.9'
|
|
||||||
|
|
||||||
# Protect against bruteforcing
|
|
||||||
gem 'rack-attack', '~> 4.4.1'
|
|
||||||
|
|
||||||
# Ace editor
|
|
||||||
gem 'ace-rails-ap', '~> 4.1.0'
|
|
||||||
|
|
||||||
# Detect and convert string character encoding
|
|
||||||
gem 'charlock_holmes', '~> 0.7.5'
|
|
||||||
|
|
||||||
# Detect mime content type from content
|
|
||||||
gem 'mimemagic', '~> 0.3.2'
|
|
||||||
|
|
||||||
# Faster blank
|
|
||||||
gem 'fast_blank'
|
|
||||||
|
|
||||||
# Parse time & duration
|
|
||||||
gem 'chronic', '~> 0.10.2'
|
|
||||||
gem 'gitlab_chronic_duration', '~> 0.10.6.1'
|
|
||||||
|
|
||||||
gem 'webpack-rails', '~> 0.9.10'
|
|
||||||
gem 'rack-proxy', '~> 0.6.0'
|
|
||||||
|
|
||||||
gem 'sassc-rails', '~> 2.1.0'
|
|
||||||
gem 'uglifier', '~> 2.7.2'
|
|
||||||
|
|
||||||
gem 'addressable', '~> 2.5.2'
|
|
||||||
gem 'font-awesome-rails', '~> 4.7'
|
|
||||||
gem 'gemojione', '~> 3.3'
|
|
||||||
gem 'gon', '~> 6.2'
|
|
||||||
gem 'request_store', '~> 1.3'
|
|
||||||
gem 'base32', '~> 0.3.0'
|
|
||||||
|
|
||||||
gem "gitlab-license", "~> 1.0"
|
|
||||||
|
|
||||||
# Sentry integration
|
|
||||||
gem 'sentry-raven', '~> 2.9'
|
|
||||||
|
|
||||||
gem 'premailer-rails', '~> 1.9.7'
|
|
||||||
|
|
||||||
# LabKit: Tracing and Correlation
|
|
||||||
gem 'gitlab-labkit', '~> 0.5'
|
|
||||||
|
|
||||||
# I18n
|
|
||||||
gem 'ruby_parser', '~> 3.8', require: false
|
|
||||||
gem 'rails-i18n', '~> 5.1'
|
|
||||||
gem 'gettext_i18n_rails', '~> 1.8.0'
|
|
||||||
gem 'gettext_i18n_rails_js', '~> 1.3'
|
|
||||||
gem 'gettext', '~> 3.2.2', require: false, group: :development
|
|
||||||
|
|
||||||
gem 'batch-loader', '~> 1.4.0'
|
|
||||||
|
|
||||||
# Perf bar
|
|
||||||
# https://gitlab.com/gitlab-org/gitlab-ee/issues/13996
|
|
||||||
gem 'gitlab-peek', '~> 0.0.1', require: 'peek'
|
|
||||||
|
|
||||||
# Snowplow events tracking
|
|
||||||
gem 'snowplow-tracker', '~> 0.6.1'
|
|
||||||
|
|
||||||
# Memory benchmarks
|
|
||||||
gem 'derailed_benchmarks', require: false
|
|
||||||
|
|
||||||
# Metrics
|
|
||||||
group :metrics do
|
|
||||||
gem 'method_source', '~> 0.8', require: false
|
|
||||||
gem 'influxdb', '~> 0.2', require: false
|
|
||||||
|
|
||||||
# Prometheus
|
|
||||||
gem 'prometheus-client-mmap', '~> 0.9.10'
|
|
||||||
gem 'raindrops', '~> 0.18'
|
|
||||||
end
|
|
||||||
|
|
||||||
group :development do
|
|
||||||
gem 'foreman', '~> 0.84.0'
|
|
||||||
gem 'brakeman', '~> 4.2', require: false
|
|
||||||
gem 'danger', '~> 6.0', require: false
|
|
||||||
|
|
||||||
gem 'letter_opener_web', '~> 1.3.4'
|
|
||||||
gem 'rblineprof', '~> 0.3.6', platform: :mri, require: false
|
|
||||||
|
|
||||||
# Better errors handler
|
|
||||||
gem 'better_errors', '~> 2.5.0'
|
|
||||||
gem 'binding_of_caller', '~> 0.8.0'
|
|
||||||
|
|
||||||
# thin instead webrick
|
|
||||||
gem 'thin', '~> 1.7.0'
|
|
||||||
end
|
|
||||||
|
|
||||||
group :development, :test do
|
|
||||||
gem 'bullet', '~> 5.5.0', require: !!ENV['ENABLE_BULLET']
|
|
||||||
gem 'pry-byebug', '~> 3.5.1', platform: :mri
|
|
||||||
gem 'pry-rails', '~> 0.3.4'
|
|
||||||
|
|
||||||
gem 'awesome_print', require: false
|
|
||||||
gem 'fuubar', '~> 2.2.0'
|
|
||||||
|
|
||||||
gem 'database_cleaner', '~> 1.7.0'
|
|
||||||
gem 'factory_bot_rails', '~> 4.8.2'
|
|
||||||
gem 'rspec-rails', '~> 3.8.0'
|
|
||||||
gem 'rspec-retry', '~> 0.6.1'
|
|
||||||
gem 'rspec_profiling', '~> 0.0.5'
|
|
||||||
gem 'rspec-set', '~> 0.1.3'
|
|
||||||
gem 'rspec-parameterized', require: false
|
|
||||||
|
|
||||||
# Prevent occasions where minitest is not bundled in packaged versions of ruby (see #3826)
|
|
||||||
gem 'minitest', '~> 5.11.0'
|
|
||||||
|
|
||||||
# Generate Fake data
|
|
||||||
gem 'ffaker', '~> 2.10'
|
|
||||||
|
|
||||||
gem 'capybara', '~> 3.22.0'
|
|
||||||
gem 'capybara-screenshot', '~> 1.0.22'
|
|
||||||
gem 'selenium-webdriver', '~> 3.141'
|
|
||||||
|
|
||||||
gem 'spring', '~> 2.0.0'
|
|
||||||
gem 'spring-commands-rspec', '~> 1.0.4'
|
|
||||||
|
|
||||||
gem 'gitlab-styles', '~> 2.7', require: false
|
|
||||||
# Pin these dependencies, otherwise a new rule could break the CI pipelines
|
|
||||||
gem 'rubocop', '~> 0.69.0'
|
|
||||||
gem 'rubocop-performance', '~> 1.1.0'
|
|
||||||
gem 'rubocop-rspec', '~> 1.22.1'
|
|
||||||
|
|
||||||
gem 'scss_lint', '~> 0.56.0', require: false
|
|
||||||
gem 'haml_lint', '~> 0.31.0', require: false
|
|
||||||
gem 'simplecov', '~> 0.16.1', require: false
|
|
||||||
gem 'bundler-audit', '~> 0.5.0', require: false
|
|
||||||
|
|
||||||
gem 'benchmark-ips', '~> 2.3.0', require: false
|
|
||||||
|
|
||||||
gem 'license_finder', '~> 5.4', require: false
|
|
||||||
gem 'knapsack', '~> 1.17'
|
|
||||||
|
|
||||||
gem 'stackprof', '~> 0.2.10', require: false
|
|
||||||
|
|
||||||
gem 'simple_po_parser', '~> 1.1.2', require: false
|
|
||||||
|
|
||||||
gem 'timecop', '~> 0.8.0'
|
|
||||||
end
|
|
||||||
|
|
||||||
group :test do
|
|
||||||
gem 'shoulda-matchers', '~> 4.0.1', require: false
|
|
||||||
gem 'email_spec', '~> 2.2.0'
|
|
||||||
gem 'json-schema', '~> 2.8.0'
|
|
||||||
gem 'webmock', '~> 3.5.1'
|
|
||||||
gem 'rails-controller-testing'
|
|
||||||
gem 'concurrent-ruby', '~> 1.1'
|
|
||||||
gem 'test-prof', '~> 0.2.5'
|
|
||||||
gem 'rspec_junit_formatter'
|
|
||||||
end
|
|
||||||
|
|
||||||
gem 'octokit', '~> 4.9'
|
|
||||||
|
|
||||||
gem 'mail_room', '~> 0.9.1'
|
|
||||||
|
|
||||||
gem 'email_reply_trimmer', '~> 0.1'
|
|
||||||
gem 'html2text'
|
|
||||||
|
|
||||||
gem 'ruby-prof', '~> 1.0.0'
|
|
||||||
gem 'rbtrace', '~> 0.4', require: false
|
|
||||||
gem 'memory_profiler', '~> 0.9', require: false
|
|
||||||
gem 'benchmark-memory', '~> 0.1', require: false
|
|
||||||
gem 'activerecord-explain-analyze', '~> 0.1', require: false
|
|
||||||
|
|
||||||
# OAuth
|
|
||||||
gem 'oauth2', '~> 1.4'
|
|
||||||
|
|
||||||
# Health check
|
|
||||||
gem 'health_check', '~> 2.6.0'
|
|
||||||
|
|
||||||
# System information
|
|
||||||
gem 'vmstat', '~> 2.3.0'
|
|
||||||
gem 'sys-filesystem', '~> 1.1.6'
|
|
||||||
|
|
||||||
# NTP client
|
|
||||||
gem 'net-ntp'
|
|
||||||
|
|
||||||
# SSH host key support
|
|
||||||
gem 'net-ssh', '~> 5.2'
|
|
||||||
gem 'sshkey', '~> 2.0'
|
|
||||||
|
|
||||||
# Required for ED25519 SSH host key support
|
|
||||||
group :ed25519 do
|
|
||||||
gem 'ed25519', '~> 1.2'
|
|
||||||
gem 'bcrypt_pbkdf', '~> 1.0'
|
|
||||||
end
|
|
||||||
|
|
||||||
# Gitaly GRPC protocol definitions
|
|
||||||
gem 'gitaly', '~> 1.58.0'
|
|
||||||
|
|
||||||
gem 'grpc', '~> 1.19.0'
|
|
||||||
|
|
||||||
gem 'google-protobuf', '~> 3.7.1'
|
|
||||||
|
|
||||||
gem 'toml-rb', '~> 1.0.0', require: false
|
|
||||||
|
|
||||||
# Feature toggles
|
|
||||||
gem 'flipper', '~> 0.13.0'
|
|
||||||
gem 'flipper-active_record', '~> 0.13.0'
|
|
||||||
gem 'flipper-active_support_cache_store', '~> 0.13.0'
|
|
||||||
gem 'unleash', '~> 0.1.5'
|
|
||||||
|
|
||||||
# Structured logging
|
|
||||||
gem 'lograge', '~> 0.5'
|
|
||||||
gem 'grape_logging', '~> 1.7'
|
|
||||||
|
|
||||||
# DNS Lookup
|
|
||||||
gem 'net-dns', '~> 0.9.0'
|
|
||||||
|
|
||||||
# Countries list
|
|
||||||
gem 'countries', '~> 3.0'
|
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -20,7 +20,7 @@ logger = logging.getLogger(__name__)
|
|||||||
|
|
||||||
class GitLabRepo:
|
class GitLabRepo:
|
||||||
version_regex = re.compile(r"^v\d+\.\d+\.\d+(\-rc\d+)?(\-ee)?")
|
version_regex = re.compile(r"^v\d+\.\d+\.\d+(\-rc\d+)?(\-ee)?")
|
||||||
def __init__(self, owner: str, repo: str):
|
def __init__(self, owner: str = 'gitlab-org', repo: str = 'gitlab'):
|
||||||
self.owner = owner
|
self.owner = owner
|
||||||
self.repo = repo
|
self.repo = repo
|
||||||
|
|
||||||
@ -68,7 +68,7 @@ class GitLabRepo:
|
|||||||
"""
|
"""
|
||||||
return requests.get(self.url + f"/raw/{rev}/{filepath}").text
|
return requests.get(self.url + f"/raw/{rev}/{filepath}").text
|
||||||
|
|
||||||
def get_data(self, rev, flavour):
|
def get_data(self, rev):
|
||||||
version = self.rev2version(rev)
|
version = self.rev2version(rev)
|
||||||
|
|
||||||
passthru = {v: self.get_file(v, rev).strip() for v in ['GITALY_SERVER_VERSION', 'GITLAB_PAGES_VERSION',
|
passthru = {v: self.get_file(v, rev).strip() for v in ['GITALY_SERVER_VERSION', 'GITLAB_PAGES_VERSION',
|
||||||
@ -81,34 +81,6 @@ class GitLabRepo:
|
|||||||
passthru=passthru)
|
passthru=passthru)
|
||||||
|
|
||||||
|
|
||||||
def _flavour2gitlabrepo(flavour: str):
|
|
||||||
if flavour not in ['ce', 'ee']:
|
|
||||||
raise Exception(f"unknown gitlab flavour: {flavour}, needs to be ce or ee")
|
|
||||||
|
|
||||||
owner = 'gitlab-org'
|
|
||||||
if flavour == 'ce':
|
|
||||||
repo = 'gitlab-foss'
|
|
||||||
else:
|
|
||||||
repo = 'gitlab'
|
|
||||||
|
|
||||||
return GitLabRepo(owner, repo)
|
|
||||||
|
|
||||||
|
|
||||||
def _update_data_json(filename: str, repo: GitLabRepo, rev: str, flavour: str):
|
|
||||||
flavour_data = repo.get_data(rev, flavour)
|
|
||||||
|
|
||||||
if not os.path.exists(filename):
|
|
||||||
with open(filename, 'w') as f:
|
|
||||||
json.dump({flavour: flavour_data}, f, indent=2)
|
|
||||||
else:
|
|
||||||
with open(filename, 'r+') as f:
|
|
||||||
data = json.load(f)
|
|
||||||
data[flavour] = flavour_data
|
|
||||||
f.seek(0)
|
|
||||||
f.truncate()
|
|
||||||
json.dump(data, f, indent=2)
|
|
||||||
|
|
||||||
|
|
||||||
def _get_data_json():
|
def _get_data_json():
|
||||||
data_file_path = pathlib.Path(__file__).parent / 'data.json'
|
data_file_path = pathlib.Path(__file__).parent / 'data.json'
|
||||||
with open(data_file_path, 'r') as f:
|
with open(data_file_path, 'r') as f:
|
||||||
@ -129,44 +101,39 @@ def cli():
|
|||||||
|
|
||||||
@cli.command('update-data')
|
@cli.command('update-data')
|
||||||
@click.option('--rev', default='latest', help='The rev to use, \'latest\' points to the latest (stable) tag')
|
@click.option('--rev', default='latest', help='The rev to use, \'latest\' points to the latest (stable) tag')
|
||||||
@click.argument('flavour')
|
def update_data(rev: str):
|
||||||
def update_data(rev: str, flavour: str):
|
"""Update data.nix"""
|
||||||
"""Update data.nix for a selected flavour"""
|
repo = GitLabRepo()
|
||||||
r = _flavour2gitlabrepo(flavour)
|
|
||||||
|
|
||||||
if rev == 'latest':
|
if rev == 'latest':
|
||||||
# filter out pre and re releases
|
# filter out pre and re releases
|
||||||
rev = next(filter(lambda x: not ('rc' in x or x.endswith('pre')), r.tags))
|
rev = next(filter(lambda x: not ('rc' in x or x.endswith('pre')), repo.tags))
|
||||||
logger.debug(f"Using rev {rev}")
|
logger.debug(f"Using rev {rev}")
|
||||||
|
|
||||||
version = r.rev2version(rev)
|
version = repo.rev2version(rev)
|
||||||
logger.debug(f"Using version {version}")
|
logger.debug(f"Using version {version}")
|
||||||
|
|
||||||
data_file_path = pathlib.Path(__file__).parent / 'data.json'
|
data_file_path = pathlib.Path(__file__).parent / 'data.json'
|
||||||
|
|
||||||
_update_data_json(filename=data_file_path.as_posix(),
|
data = repo.get_data(rev)
|
||||||
repo=r,
|
|
||||||
rev=rev,
|
with open(data_file_path.as_posix(), 'w') as f:
|
||||||
flavour=flavour)
|
json.dump(data, f, indent=2)
|
||||||
|
|
||||||
|
|
||||||
@cli.command('update-rubyenv')
|
@cli.command('update-rubyenv')
|
||||||
@click.argument('flavour')
|
def update_rubyenv():
|
||||||
def update_rubyenv(flavour):
|
"""Update rubyEnv"""
|
||||||
"""Update rubyEnv-${flavour}"""
|
repo = GitLabRepo()
|
||||||
if flavour not in ['ce', 'ee']:
|
rubyenv_dir = pathlib.Path(__file__).parent / f"rubyEnv"
|
||||||
raise Exception(f"unknown gitlab flavour: {flavour}, needs to be ce or ee")
|
|
||||||
|
|
||||||
r = _flavour2gitlabrepo(flavour)
|
|
||||||
rubyenv_dir = pathlib.Path(__file__).parent / f"rubyEnv-{flavour}"
|
|
||||||
|
|
||||||
# load rev from data.json
|
# load rev from data.json
|
||||||
data = _get_data_json()
|
data = _get_data_json()
|
||||||
rev = data[flavour]['rev']
|
rev = data['rev']
|
||||||
|
|
||||||
for fn in ['Gemfile.lock', 'Gemfile']:
|
for fn in ['Gemfile.lock', 'Gemfile']:
|
||||||
with open(rubyenv_dir / fn, 'w') as f:
|
with open(rubyenv_dir / fn, 'w') as f:
|
||||||
f.write(r.get_file(fn, rev))
|
f.write(repo.get_file(fn, rev))
|
||||||
|
|
||||||
subprocess.check_output(['bundix'], cwd=rubyenv_dir)
|
subprocess.check_output(['bundix'], cwd=rubyenv_dir)
|
||||||
|
|
||||||
@ -175,13 +142,12 @@ def update_rubyenv(flavour):
|
|||||||
def update_yarnpkgs():
|
def update_yarnpkgs():
|
||||||
"""Update yarnPkgs"""
|
"""Update yarnPkgs"""
|
||||||
|
|
||||||
# yarn.lock is identical between the repos
|
repo = GitLabRepo()
|
||||||
repo = _flavour2gitlabrepo('ee')
|
|
||||||
yarnpkgs_dir = pathlib.Path(__file__).parent
|
yarnpkgs_dir = pathlib.Path(__file__).parent
|
||||||
|
|
||||||
# load rev from data.json
|
# load rev from data.json
|
||||||
data = _get_data_json()
|
data = _get_data_json()
|
||||||
rev = data['ee']['rev']
|
rev = data['rev']
|
||||||
|
|
||||||
with open(yarnpkgs_dir / 'yarn.lock', 'w') as f:
|
with open(yarnpkgs_dir / 'yarn.lock', 'w') as f:
|
||||||
f.write(repo.get_file('yarn.lock', rev))
|
f.write(repo.get_file('yarn.lock', rev))
|
||||||
@ -196,17 +162,17 @@ def update_yarnpkgs():
|
|||||||
def update_gitaly():
|
def update_gitaly():
|
||||||
"""Update gitaly"""
|
"""Update gitaly"""
|
||||||
data = _get_data_json()
|
data = _get_data_json()
|
||||||
gitaly_server_version = data['ce']['passthru']['GITALY_SERVER_VERSION']
|
gitaly_server_version = data['passthru']['GITALY_SERVER_VERSION']
|
||||||
r = GitLabRepo('gitlab-org', 'gitaly')
|
repo = GitLabRepo(repo='gitaly')
|
||||||
gitaly_dir = pathlib.Path(__file__).parent / 'gitaly'
|
gitaly_dir = pathlib.Path(__file__).parent / 'gitaly'
|
||||||
|
|
||||||
for fn in ['Gemfile.lock', 'Gemfile']:
|
for fn in ['Gemfile.lock', 'Gemfile']:
|
||||||
with open(gitaly_dir / fn, 'w') as f:
|
with open(gitaly_dir / fn, 'w') as f:
|
||||||
f.write(r.get_file(f"ruby/{fn}", f"v{gitaly_server_version}"))
|
f.write(repo.get_file(f"ruby/{fn}", f"v{gitaly_server_version}"))
|
||||||
|
|
||||||
for fn in ['go.mod', 'go.sum']:
|
for fn in ['go.mod', 'go.sum']:
|
||||||
with open(gitaly_dir / fn, 'w') as f:
|
with open(gitaly_dir / fn, 'w') as f:
|
||||||
f.write(r.get_file(fn, f"v{gitaly_server_version}"))
|
f.write(repo.get_file(fn, f"v{gitaly_server_version}"))
|
||||||
|
|
||||||
subprocess.check_output(['bundix'], cwd=gitaly_dir)
|
subprocess.check_output(['bundix'], cwd=gitaly_dir)
|
||||||
subprocess.check_output(['vgo2nix'], cwd=gitaly_dir)
|
subprocess.check_output(['vgo2nix'], cwd=gitaly_dir)
|
||||||
@ -221,19 +187,19 @@ def update_gitaly():
|
|||||||
def update_gitlab_shell():
|
def update_gitlab_shell():
|
||||||
"""Update gitlab-shell"""
|
"""Update gitlab-shell"""
|
||||||
data = _get_data_json()
|
data = _get_data_json()
|
||||||
gitlab_shell_version = data['ce']['passthru']['GITLAB_SHELL_VERSION']
|
gitlab_shell_version = data['passthru']['GITLAB_SHELL_VERSION']
|
||||||
_call_update_source_version('gitlab-shell', gitlab_shell_version)
|
_call_update_source_version('gitlab-shell', gitlab_shell_version)
|
||||||
|
|
||||||
r = GitLabRepo('gitlab-org', 'gitlab-shell')
|
repo = GitLabRepo(repo='gitlab-shell')
|
||||||
gitlab_shell_dir = pathlib.Path(__file__).parent / 'gitlab-shell'
|
gitlab_shell_dir = pathlib.Path(__file__).parent / 'gitlab-shell'
|
||||||
|
|
||||||
for fn in ['Gemfile.lock', 'Gemfile']:
|
for fn in ['Gemfile.lock', 'Gemfile']:
|
||||||
with open(gitlab_shell_dir / fn, 'w') as f:
|
with open(gitlab_shell_dir / fn, 'w') as f:
|
||||||
f.write(r.get_file(fn, f"v{gitlab_shell_version}"))
|
f.write(repo.get_file(fn, f"v{gitlab_shell_version}"))
|
||||||
|
|
||||||
for fn in ['go.mod', 'go.sum']:
|
for fn in ['go.mod', 'go.sum']:
|
||||||
with open(gitlab_shell_dir / fn, 'w') as f:
|
with open(gitlab_shell_dir / fn, 'w') as f:
|
||||||
f.write(r.get_file(f"go/{fn}", f"v{gitlab_shell_version}"))
|
f.write(repo.get_file(f"go/{fn}", f"v{gitlab_shell_version}"))
|
||||||
|
|
||||||
subprocess.check_output(['bundix'], cwd=gitlab_shell_dir)
|
subprocess.check_output(['bundix'], cwd=gitlab_shell_dir)
|
||||||
subprocess.check_output(['vgo2nix'], cwd=gitlab_shell_dir)
|
subprocess.check_output(['vgo2nix'], cwd=gitlab_shell_dir)
|
||||||
@ -246,15 +212,15 @@ def update_gitlab_shell():
|
|||||||
def update_gitlab_workhorse():
|
def update_gitlab_workhorse():
|
||||||
"""Update gitlab-workhorse"""
|
"""Update gitlab-workhorse"""
|
||||||
data = _get_data_json()
|
data = _get_data_json()
|
||||||
gitlab_workhorse_version = data['ce']['passthru']['GITLAB_WORKHORSE_VERSION']
|
gitlab_workhorse_version = data['passthru']['GITLAB_WORKHORSE_VERSION']
|
||||||
_call_update_source_version('gitlab-workhorse', gitlab_workhorse_version)
|
_call_update_source_version('gitlab-workhorse', gitlab_workhorse_version)
|
||||||
|
|
||||||
r = GitLabRepo('gitlab-org', 'gitlab-workhorse')
|
repo = GitLabRepo('gitlab-org', 'gitlab-workhorse')
|
||||||
gitlab_workhorse_dir = pathlib.Path(__file__).parent / 'gitlab-workhorse'
|
gitlab_workhorse_dir = pathlib.Path(__file__).parent / 'gitlab-workhorse'
|
||||||
|
|
||||||
for fn in ['go.mod', 'go.sum']:
|
for fn in ['go.mod', 'go.sum']:
|
||||||
with open(gitlab_workhorse_dir / fn, 'w') as f:
|
with open(gitlab_workhorse_dir / fn, 'w') as f:
|
||||||
f.write(r.get_file(fn, f"v{gitlab_workhorse_version}"))
|
f.write(repo.get_file(fn, f"v{gitlab_workhorse_version}"))
|
||||||
|
|
||||||
subprocess.check_output(['vgo2nix'], cwd=gitlab_workhorse_dir)
|
subprocess.check_output(['vgo2nix'], cwd=gitlab_workhorse_dir)
|
||||||
|
|
||||||
@ -264,10 +230,9 @@ def update_gitlab_workhorse():
|
|||||||
@cli.command('update-all')
|
@cli.command('update-all')
|
||||||
@click.pass_context
|
@click.pass_context
|
||||||
def update_all(ctx):
|
def update_all(ctx):
|
||||||
"""Update gitlab ce and ee data.nix and rubyenvs to the latest stable release"""
|
"""Update all gitlab components to the latest stable release"""
|
||||||
for flavour in ['ce', 'ee']:
|
ctx.invoke(update_data, rev='latest')
|
||||||
ctx.invoke(update_data, rev='latest', flavour=flavour)
|
ctx.invoke(update_rubyenv)
|
||||||
ctx.invoke(update_rubyenv, flavour=flavour)
|
|
||||||
ctx.invoke(update_yarnpkgs)
|
ctx.invoke(update_yarnpkgs)
|
||||||
ctx.invoke(update_gitaly)
|
ctx.invoke(update_gitaly)
|
||||||
ctx.invoke(update_gitlab_shell)
|
ctx.invoke(update_gitlab_shell)
|
||||||
|
Loading…
Reference in New Issue
Block a user