From e7e6a81b0370827eb5320037c84a1bfb478cd26d Mon Sep 17 00:00:00 2001 From: Manuel Friedli Date: Thu, 20 Feb 2014 09:26:29 +0100 Subject: [PATCH] cvut hat fixed the manifest, so i can safely remove the ebuild for Gitlab from my overlay. --- www-apps/gitlabhq/Manifest | 18 - www-apps/gitlabhq/files/gitlab-sidekiq.init | 43 -- www-apps/gitlabhq/files/gitlab-unicorn-6.init | 67 ---- .../files/gitlabhq-6.5.1-fix-gemfile.patch | 84 ---- ...itlabhq-6.5.1-fix-project-name-regex.patch | 28 -- .../gitlabhq-6.5.1-fix-sendmail-config.patch | 20 - www-apps/gitlabhq/gitlabhq-6.5.1.ebuild | 371 ------------------ 7 files changed, 631 deletions(-) delete mode 100644 www-apps/gitlabhq/Manifest delete mode 100644 www-apps/gitlabhq/files/gitlab-sidekiq.init delete mode 100644 www-apps/gitlabhq/files/gitlab-unicorn-6.init delete mode 100644 www-apps/gitlabhq/files/gitlabhq-6.5.1-fix-gemfile.patch delete mode 100644 www-apps/gitlabhq/files/gitlabhq-6.5.1-fix-project-name-regex.patch delete mode 100644 www-apps/gitlabhq/files/gitlabhq-6.5.1-fix-sendmail-config.patch delete mode 100644 www-apps/gitlabhq/gitlabhq-6.5.1.ebuild diff --git a/www-apps/gitlabhq/Manifest b/www-apps/gitlabhq/Manifest deleted file mode 100644 index ce0e3e8..0000000 --- a/www-apps/gitlabhq/Manifest +++ /dev/null @@ -1,18 +0,0 @@ -AUX gitlab-sidekiq.init 979 SHA256 f9bc02031b0418e4c765fae37bb40cd9e16dbe5b1a7f5c105a2d7ba3568b0195 SHA512 e3311f1110fca02a378a9f74704d9241884a1973e90be1dbd663809b524528eda25e3ad0ac5d20737f6ccd78343582557ac579adb976473f8aabc0320172921f WHIRLPOOL 365d539cceacb5ff9171aa7316ac061ef4b4a8d63e6d4a26395afb841878a08bdd1b9bf2709602dc90f15a1ed5ff8566a0e8239e8ab9184e84814a16993f3aeb -AUX gitlab-unicorn-6.init 1663 SHA256 ba211c63d559cbca510483d5536d28131e08f67dc8914444a2c85b27c7a92b60 SHA512 a574b3bb5b9af3e3a707045ac6d783bab73bab1db033d07999b3d06789da0853bc3de0bba39a3c154e5b1ab385926ee3ec4487f4c797708a318fa5df22827069 WHIRLPOOL 497cf52ebb4b33cc6bbd81e53d4961878b2ea9dc42bacabf7a32686e52a54c22eed73836705e80714d7b759cfd2ee1929e6aa12083435f265c472270e158f72a -AUX gitlabhq-6.4.3-fix-gemfile.patch 2168 SHA256 dafa8390b1b3421d174a4f3f4e1f4fcb65be4c972aae89c4cc0f61c8492a136c SHA512 123a8f2d893159f7da235a3b7c8913686bace04eb36dbee110ebddbfbc2c4a166338e41a030f86d4b5ae7e86fdb367035b3612e62a668e365ecde1ce2e16c39a WHIRLPOOL 2ee7c88d42273d1547cdb1f27c1fe550fe29003d5f308c61d57457723658675b7cfd91fdd37a095a30810e3e55cadc1ba1b080b679875ee4bf618fd563d8dfcc -AUX gitlabhq-6.4.3-fix-project-name-regex.patch 1143 SHA256 6f12268ae65ea0fbb80a8eed0740f7270d22d2b17f7768d5d2f0feddf38301ea SHA512 3d70766c0cb0fda5f57235424633d507f30005edbf569b03af99965e26d758e7ecd3669f20c7f06350b277529f5be63e99814eed5ac74eacaec5a1f85199a25f WHIRLPOOL d2acb2ea30f44166e6164913d7345366ed9ff5646832240c6287745c1c86915b5661eaea68a3d842a363fff8301a4bcdaf71563d1c768d30c163fd396757f833 -AUX gitlabhq-6.4.3-fix-sendmail-config.patch 731 SHA256 51f0d0af2a7c048d7cff56cf27955632f340ca67f9d460af840cf34ed60ca574 SHA512 b10d5b8d89927404d25345e17ba37ca4e7848b04c2ca20c5eef14eaac43d9ba14b62ae4c0d532eefaf6f9a2944578e84eb65a3420335d32495855c4807eec356 WHIRLPOOL 66f6443f311f2355ffd4efaea914f462816a1966a715b3b5ffaaa26b41bdced928b9905b8606f06fac3c2ccf20741553cfed2615430287bede01cf376aae2a60 -AUX gitlabhq-6.5.0-fix-gemfile.patch 2142 SHA256 801a9b4e9333a3f780cb7ad66dc0a683a6b4b8b5fab5279f63f13ef7ae307721 SHA512 64cb1e667e594072a0df1ba2f1d7f3c72add59f8d98ae6384b9bf15fcbd0f97d4f22f27f55db752090fe464044002db8c71574d8cfdcaa30d82d1ab1eb389b83 WHIRLPOOL 5f953afcf6fe4c4daf9dccc588bd588c0864ef796a0e3dd1a3466a424379f2b0510fa54ea043b641ec86d8191baaf5ccc920e293994b17fbf1078f5d299c2d79 -AUX gitlabhq-6.5.0-fix-login-over-ssl.patch 613 SHA256 1b29a172f05d42ae3a2e4840dc136a98e39e7a9f7ec493cd4446051ffac64786 SHA512 4f73ba90413d859104ff7036566950b47e291ce596eaf85b0fa7a0ecdec4e31b3ff741918a82fdb79a3c4fb743a81aaca5c8b3c70e0510a13a7bf728bb87b11e WHIRLPOOL ed1f2f688f0a2df347029c32b82dfe0e241a874680fb8f056f2e4bd0911d9c2c89b70189629876fe37409a6737f16e60e97230023cd0d907390e678c92b64fb6 -AUX gitlabhq-6.5.0-fix-project-name-regex.patch 1143 SHA256 6f12268ae65ea0fbb80a8eed0740f7270d22d2b17f7768d5d2f0feddf38301ea SHA512 3d70766c0cb0fda5f57235424633d507f30005edbf569b03af99965e26d758e7ecd3669f20c7f06350b277529f5be63e99814eed5ac74eacaec5a1f85199a25f WHIRLPOOL d2acb2ea30f44166e6164913d7345366ed9ff5646832240c6287745c1c86915b5661eaea68a3d842a363fff8301a4bcdaf71563d1c768d30c163fd396757f833 -AUX gitlabhq-6.5.0-fix-sendmail-config.patch 731 SHA256 51f0d0af2a7c048d7cff56cf27955632f340ca67f9d460af840cf34ed60ca574 SHA512 b10d5b8d89927404d25345e17ba37ca4e7848b04c2ca20c5eef14eaac43d9ba14b62ae4c0d532eefaf6f9a2944578e84eb65a3420335d32495855c4807eec356 WHIRLPOOL 66f6443f311f2355ffd4efaea914f462816a1966a715b3b5ffaaa26b41bdced928b9905b8606f06fac3c2ccf20741553cfed2615430287bede01cf376aae2a60 -AUX gitlabhq-6.5.1-fix-gemfile.patch 2142 SHA256 801a9b4e9333a3f780cb7ad66dc0a683a6b4b8b5fab5279f63f13ef7ae307721 SHA512 64cb1e667e594072a0df1ba2f1d7f3c72add59f8d98ae6384b9bf15fcbd0f97d4f22f27f55db752090fe464044002db8c71574d8cfdcaa30d82d1ab1eb389b83 WHIRLPOOL 5f953afcf6fe4c4daf9dccc588bd588c0864ef796a0e3dd1a3466a424379f2b0510fa54ea043b641ec86d8191baaf5ccc920e293994b17fbf1078f5d299c2d79 -AUX gitlabhq-6.5.1-fix-project-name-regex.patch 1143 SHA256 6f12268ae65ea0fbb80a8eed0740f7270d22d2b17f7768d5d2f0feddf38301ea SHA512 3d70766c0cb0fda5f57235424633d507f30005edbf569b03af99965e26d758e7ecd3669f20c7f06350b277529f5be63e99814eed5ac74eacaec5a1f85199a25f WHIRLPOOL d2acb2ea30f44166e6164913d7345366ed9ff5646832240c6287745c1c86915b5661eaea68a3d842a363fff8301a4bcdaf71563d1c768d30c163fd396757f833 -AUX gitlabhq-6.5.1-fix-sendmail-config.patch 731 SHA256 51f0d0af2a7c048d7cff56cf27955632f340ca67f9d460af840cf34ed60ca574 SHA512 b10d5b8d89927404d25345e17ba37ca4e7848b04c2ca20c5eef14eaac43d9ba14b62ae4c0d532eefaf6f9a2944578e84eb65a3420335d32495855c4807eec356 WHIRLPOOL 66f6443f311f2355ffd4efaea914f462816a1966a715b3b5ffaaa26b41bdced928b9905b8606f06fac3c2ccf20741553cfed2615430287bede01cf376aae2a60 -DIST gitlabhq-6.4.3.tar.gz 10979694 SHA256 a2df6ec3de927a45fdaec70b806f731d66694db54dc674cd8b3378703d28114b SHA512 df06c07434ca45273e4988827d11a287249f2f3baddd799c45fafc56661ba4e1d872536f233eac7ac5aa704ddae0bcc92850af926a07f42f399873e1eda4e8f7 WHIRLPOOL 33e6199f2955fcbe65177c4f0520ceeaed82b9c1df94721048eeb8cefc798b9c83beb66f8ddec3cc91a848ba056f39e633ffba2f588880828bcae4a52d560dbc -DIST gitlabhq-6.5.0.tar.gz 10987422 SHA256 777294b0fe0a42181e33661cad7a72f722350ed8c701f8ac26bcd9df1bb2a511 SHA512 7dbb469768456d251d497a1420eb0f313aae5b873434f46cb051edd8a41b95dcd36693c1b3dc170354127e6e381148eb5ea687644416036efc85814aab8967a9 WHIRLPOOL ec0856c38175cf92f82ab561fc5511877f827db51d044cac66308d7eb1acb422c329f479e4a15b32da37bb2009c39e6589e56eda84a9ed9c16f9aa2a704230ae -DIST gitlabhq-6.5.1.tar.gz 10987382 SHA256 f3058658727a164fd11fdaa0dd25aadaf1a2dac59ea5017d384fd6d55da1fd54 SHA512 cdd9a87a74afaa7e38d507a84d9c9adc9b6247d7b6779f29d9eb332ebe3c5e12794bee1f901d7901c797e2d2e0b3ec6c30483e73e55861841227ecdb8c161668 WHIRLPOOL 99c296463e46e1682bd2cdd9ec00a96ff53cacebd5f32d531841fadccaac9d38b4924ca70a9c356a99327610151c576b3b3a6b1cac92dab1a487b78f1ee74912 -EBUILD gitlabhq-6.4.3.ebuild 10673 SHA256 6856eeb5a2e778bc80237443fc997efd93c1ff60eda1ce6319a88298012c7eaf SHA512 130eb1b15eab517a5b80acfb51b888b4eb7fbe335c037df41b74dddd4f3d9d93f55aa0adb893b54f8f1e4e4f950fbcc278d2a5f142d76bea8535f78fd2f1f9d6 WHIRLPOOL 9531f4978c72c4a172c2fa6dd790c37e285169d2763e5d9da5b97755c4a9cb9710e45ff745ab4540873cbf7d591e538b14ebf1eb54469c57742f3c0935a976eb -EBUILD gitlabhq-6.5.0.ebuild 10706 SHA256 f93a3ee7e1388f35c64fbd18227b7af174335bfad634dfea27f8c172b5467ffa SHA512 6835f966d5fabca888d176704cd92e0e8441ad60e6029e8f8c06cacaa672805bd9364ce1d9fabf3515ecb265572a2e25a4aad8ebe54ac3ca316838c3fdd64281 WHIRLPOOL b34ae343ba9a8aa1d0da4fb374a55871a411fdaa290ca25680b9d04aba62c78e9dabc5753b81ed2c833491c277fda9746a6a99b94472350ca4ac52bbab179334 -EBUILD gitlabhq-6.5.1.ebuild 11195 SHA256 de9c8edfbcda64a10c33754ce8ab4b3d717c83277cead6af89d3b17351f5275a SHA512 1fd06435a4e5996fd9258f09aabd287968a82b404210115da7ee33c7ce1cf817dcc1bdcde86f07ec255d06c630529b791968ad644cdbd13660955c27892ddf08 WHIRLPOOL b9f4695479af029589037aba780e2b87c06eae3d0f087653520c1493d33c4259dbbd1257ea62acef0ec47f179ff7c36473f9db851c45aaf0e537804b324919bb diff --git a/www-apps/gitlabhq/files/gitlab-sidekiq.init b/www-apps/gitlabhq/files/gitlab-sidekiq.init deleted file mode 100644 index 99b2d17..0000000 --- a/www-apps/gitlabhq/files/gitlab-sidekiq.init +++ /dev/null @@ -1,43 +0,0 @@ -#!/sbin/runscript - -name="GitLab Sidekiq" -description="Sidekiq for GitLab @SLOT@" - -: ${gitlab_user:=@USER@} -: ${gitlab_base:="@GITLAB_BASE@"} -: ${rails_env:=production} - -: ${sidekiq_pidfile:="/run/gitlab/sidekiq.pid"} -: ${sidekiq_logfile:="@LOGS_DIR@/sidekiq.log"} -: ${sidekiq_queues:="@QUEUES@"} - -sidekiq_command="/usr/bin/bundle" -sidekiq_command_args="exec sidekiq -q ${sidekiq_queues} -P ${sidekiq_pidfile} -L ${sidekiq_logfile}" - -depend() { - need redis - use net -} - -start() { - checkpath -d -o ${gitlab_user} -m755 "$(dirname "${sidekiq_pidfile}")" - - ebegin "Starting ${name} - Sidekiq" - - start-stop-daemon --start \ - --background --quiet \ - --chdir "${gitlab_base}" \ - --user=${gitlab_user} \ - --pidfile="${sidekiq_pidfile}" \ - --env RAILS_ENV=${rails_env} \ - --exec ${sidekiq_command} -- ${sidekiq_command_args} - eend $? -} - -stop() { - ebegin "Stopping ${name} - Sidekiq" - start-stop-daemon --stop \ - --pidfile=${sidekiq_pidfile} \ - --exec ${sidekiq_command} - eend $? -} diff --git a/www-apps/gitlabhq/files/gitlab-unicorn-6.init b/www-apps/gitlabhq/files/gitlab-unicorn-6.init deleted file mode 100644 index 382be7a..0000000 --- a/www-apps/gitlabhq/files/gitlab-unicorn-6.init +++ /dev/null @@ -1,67 +0,0 @@ -#!/sbin/runscript - -name="GitLab-@SLOT@" -description="GitLab @SLOT@ on Unicorns" - -: ${gitlab_user:=@USER@} -: ${gitlab_base:="@GITLAB_BASE@"} -: ${rails_env:=production} - -: ${server_pidfile:="/run/gitlab/unicorn.pid"} - -: ${sidekiq_pidfile:="/run/gitlab/sidekiq.pid"} -: ${sidekiq_logfile:="@LOGS_DIR@/sidekiq.log"} -: ${sidekiq_queues:="@QUEUES@"} - -server_command="/usr/bin/bundle" -server_command_args="exec unicorn_rails -c ${gitlab_base}/config/unicorn.rb -E ${rails_env} -D" - -sidekiq_command="/usr/bin/bundle" -sidekiq_command_args="exec sidekiq -q ${sidekiq_queues} -P ${sidekiq_pidfile} -L ${sidekiq_logfile}" - -depend() { - provide gitlab - need redis - use net -} - -start() { - ebegin "Starting ${name} - Unicorn servers" - - checkpath -d -o ${gitlab_user} -m755 "$(dirname "${server_pidfile}")" - checkpath -d -o ${gitlab_user} -m755 "$(dirname "${sidekiq_pidfile}")" - - start-stop-daemon --start \ - --chdir "${gitlab_base}" \ - --user=${gitlab_user} \ - --pidfile="${server_pidfile}" \ - --env RAILS_ENV=${rails_env} \ - --exec ${server_command} -- ${server_command_args} - eend $? - - ebegin "Starting ${name} - Sidekiq" - - start-stop-daemon --start \ - --background --quiet \ - --chdir "${gitlab_base}" \ - --user=${gitlab_user} \ - --pidfile="${sidekiq_pidfile}" \ - --env RAILS_ENV=${rails_env} \ - --exec ${sidekiq_command} -- ${sidekiq_command_args} - eend $? -} - -stop() { - ebegin "Stopping ${name} - Sidekiq" - start-stop-daemon --stop \ - --pidfile=${sidekiq_pidfile} \ - --exec ${sidekiq_command} - eend $? - - ebegin "Stopping ${name} - Unicorn servers" - start-stop-daemon --stop \ - --signal QUIT \ - --pidfile=${server_pidfile} \ - --exec ${server_command} - eend $? -} diff --git a/www-apps/gitlabhq/files/gitlabhq-6.5.1-fix-gemfile.patch b/www-apps/gitlabhq/files/gitlabhq-6.5.1-fix-gemfile.patch deleted file mode 100644 index dba7d4a..0000000 --- a/www-apps/gitlabhq/files/gitlabhq-6.5.1-fix-gemfile.patch +++ /dev/null @@ -1,84 +0,0 @@ ---- Gemfile.orig 2014-01-22 14:39:19.620000000 +0100 -+++ Gemfile 2014-01-22 14:40:24.120000000 +0100 -@@ -137,13 +137,16 @@ - # Sanitize user input - gem "sanitize" - -+# The newer revision of charlock_holmes that is finally fixed to -+# be compatible with Gentoo -+gem "charlock_holmes", git: "https://github.com/brianmario/charlock_holmes.git", ref: "dde194609b3513b0d2369ce8f916ae52566154b4" -+ - # Protect against bruteforcing - gem "rack-attack" - - gem "sass-rails" - gem "coffee-rails" - gem "uglifier" --gem "therubyracer" - gem 'turbolinks' - gem 'jquery-turbolinks' - ---- Gemfile.lock.orig 2014-01-22 14:40:35.780000000 +0100 -+++ Gemfile.lock 2014-01-22 14:52:42.590000000 +0100 -@@ -1,4 +1,11 @@ - GIT -+ remote: https://github.com/brianmario/charlock_holmes.git -+ revision: dde194609b3513b0d2369ce8f916ae52566154b4 -+ ref: dde194609b3513b0d2369ce8f916ae52566154b4 -+ specs: -+ charlock_holmes (0.6.9.4) -+ -+GIT - remote: https://github.com/gitlabhq/markup.git - revision: 61ade389c1e1c159359338f570d18464a44ddbc4 - ref: 61ade389c1e1c159359338f570d18464a44ddbc4 -@@ -70,7 +77,6 @@ - json (>= 1.7) - celluloid (0.15.2) - timers (~> 1.1.0) -- charlock_holmes (0.6.9.4) - cliver (0.2.2) - code_analyzer (0.4.3) - sexp_processor -@@ -267,7 +273,6 @@ - addressable (~> 2.3) - letter_opener (1.1.2) - launchy (~> 2.2) -- libv8 (3.16.14.3) - listen (2.3.1) - celluloid (>= 0.15.2) - rb-fsevent (>= 0.9.3) -@@ -401,7 +406,6 @@ - redis-store (~> 1.1.0) - redis-store (1.1.4) - redis (>= 2.2) -- ref (1.0.5) - require_all (1.3.2) - rest-client (1.6.7) - mime-types (>= 1.16) -@@ -488,9 +492,6 @@ - term-ansicolor (1.2.2) - tins (~> 0.8) - test_after_commit (0.2.2) -- therubyracer (0.12.0) -- libv8 (~> 3.16.14.0) -- ref - thin (1.6.1) - daemons (>= 1.0.9) - eventmachine (>= 1.0.0) -@@ -561,6 +562,7 @@ - bootstrap-sass (~> 3.0) - capybara - carrierwave -+ charlock_holmes! - coffee-rails - colored - coveralls -@@ -644,7 +646,6 @@ - stamp - state_machine - test_after_commit -- therubyracer - thin - tinder (~> 1.9.2) - turbolinks diff --git a/www-apps/gitlabhq/files/gitlabhq-6.5.1-fix-project-name-regex.patch b/www-apps/gitlabhq/files/gitlabhq-6.5.1-fix-project-name-regex.patch deleted file mode 100644 index e0c7fa3..0000000 --- a/www-apps/gitlabhq/files/gitlabhq-6.5.1-fix-project-name-regex.patch +++ /dev/null @@ -1,28 +0,0 @@ ---- lib/gitlab/regex.rb.orig 2013-12-23 19:43:59.000000000 +0100 -+++ lib/gitlab/regex.rb 2014-01-17 17:43:00.020000000 +0100 -@@ -1,3 +1,5 @@ -+# encoding: utf-8 -+ - module Gitlab - module Regex - extend self -@@ -7,7 +9,7 @@ - end - - def project_name_regex -- /\A[a-zA-Z0-9][a-zA-Z0-9_\-\. ]*\z/ -+ /\A\p{Word}[\p{Word}\-:\. ]*\z/ - end - - def name_regex ---- app/models/project.rb.orig 2014-01-17 17:40:02.050000000 +0100 -+++ app/models/project.rb 2014-01-17 17:44:09.150000000 +0100 -@@ -85,7 +85,7 @@ - validates :description, length: { maximum: 2000 }, allow_blank: true - validates :name, presence: true, length: { within: 0..255 }, - format: { with: Gitlab::Regex.project_name_regex, -- message: "only letters, digits, spaces & '_' '-' '.' allowed. Letter or digit should be first" } -+ message: "only letters, digits, spaces & '_' '-' '.' ':' allowed. Letter or digit should be first" } - validates :path, presence: true, length: { within: 0..255 }, - exclusion: { in: Gitlab::Blacklist.path }, - format: { with: Gitlab::Regex.path_regex, diff --git a/www-apps/gitlabhq/files/gitlabhq-6.5.1-fix-sendmail-config.patch b/www-apps/gitlabhq/files/gitlabhq-6.5.1-fix-sendmail-config.patch deleted file mode 100644 index 0a6e8d9..0000000 --- a/www-apps/gitlabhq/files/gitlabhq-6.5.1-fix-sendmail-config.patch +++ /dev/null @@ -1,20 +0,0 @@ -diff --git a/config/environments/production.rb b/gitlab-6/environments/production.rb -index 82eb250..10e25e5 100644 ---- a/config/environments/production.rb -+++ b/config/environments/production.rb -@@ -73,11 +73,10 @@ Gitlab::Application.configure do - # config.active_record.auto_explain_threshold_in_seconds = 0.5 - - config.action_mailer.delivery_method = :sendmail -- # Defaults to: -- # # config.action_mailer.sendmail_settings = { -- # # location: '/usr/sbin/sendmail', -- # # arguments: '-i -t' -- # # } -+ config.action_mailer.sendmail_settings = { -+ location: '/usr/sbin/sendmail', -+ arguments: '-i' -+ } - config.action_mailer.perform_deliveries = true - config.action_mailer.raise_delivery_errors = true - end diff --git a/www-apps/gitlabhq/gitlabhq-6.5.1.ebuild b/www-apps/gitlabhq/gitlabhq-6.5.1.ebuild deleted file mode 100644 index 65aa567..0000000 --- a/www-apps/gitlabhq/gitlabhq-6.5.1.ebuild +++ /dev/null @@ -1,371 +0,0 @@ -# Copyright 1999-2013 Gentoo Foundation -# Distributed under the terms of the GNU General Public License v2 -# $Header: $ - -EAPI="5" - -# Mainteiner notes: -# - This ebuild uses Bundler to download and install all gems in deployment mode -# (i.e. into isolated directory inside application). That's not Gentoo way how -# it should be done, but GitLab has too many dependencies that it will be too -# difficult to maintain them via ebuilds. -# - -USE_RUBY="ruby19 ruby20" -PYTHON_DEPEND="2:2.7" - -inherit eutils python ruby-ng - -DESCRIPTION="GitLab is a free project and repository management application" -HOMEPAGE="https://github.com/gitlabhq/gitlabhq" -SRC_URI="https://github.com/gitlabhq/gitlabhq/archive/v${PV}.tar.gz -> ${P}.tar.gz" - -RESTRICT="mirror" - -LICENSE="MIT" -SLOT="6" -KEYWORDS="~amd64 ~x86" -IUSE="mysql +postgres +unicorn" - -## Gems dependencies: -# charlock_holmes dev-libs/icu -# grape, capybara dev-libs/libxml2, dev-libs/libxslt -# json dev-util/ragel -# pygments.rb python 2.7+ -# execjs net-libs/nodejs, or any other JS runtime -# pg dev-db/postgresql-base -# mysql virtual/mysql -# -GEMS_DEPEND=" - dev-libs/icu - dev-libs/libxml2 - dev-libs/libxslt - dev-util/ragel - net-libs/nodejs - postgres? ( dev-db/postgresql-base ) - mysql? ( virtual/mysql )" -DEPEND="${GEMS_DEPEND} - >=dev-vcs/gitlab-shell-1.8 - dev-vcs/git" -RDEPEND="${DEPEND} - dev-db/redis - virtual/mta" -ruby_add_bdepend " - virtual/rubygems - >=dev-ruby/bundler-1.0" - -# -# fix-gemfile: -# Remove therubyracer that doesn't compile well on Gentoo (we're using -# nodejs instead that is faster and better). Also replace broken -# charlock_holmes version with fixed one. -# -# fix-project-name-regex: -# Allow project name to contain non-ASCII characters. -# -# fix-sendmail-config: -# Fix default settings to work with ssmtp that doesn't know '-t' argument. -# -RUBY_PATCHES=( - "${P}-fix-gemfile.patch" - "${P}-fix-project-name-regex.patch" - "${P}-fix-sendmail-config.patch" -) - -MY_NAME="gitlab" -MY_USER="git" # should be same as in gitlab-shell - -DEST_DIR="/opt/${MY_NAME}-${SLOT}" -CONF_DIR="/etc/${MY_NAME}-${SLOT}" -LOGS_DIR="/var/log/${MY_NAME}" -TEMP_DIR="/var/tmp/${MY_NAME}" - -# When updating ebuild to newer version, check list of the queues in -# https://github.com/gitlabhq/gitlabhq/blob/${PV}/lib/tasks/sidekiq.rake -# TODO fritteli: I don't know what to look for in that file ... so I left this unchanged from gitlabhq-6.0.2-r2.ebuild -SIDEKIQ_QUEUES="post_receive,mailer,system_hook,project_web_hook,gitlab_shell,common,default" - -all_ruby_prepare() { - - # fix paths - local satellites_path="${TEMP_DIR}/repo_satellites" - local repos_path=/var/lib/git/repositories - local hooks_path=/usr/share/gitlab-shell/hooks - sed -i -E \ - -e "/satellites:$/,/\w:$/ s|(\s*path:\s).*|\1${satellites_path}/|" \ - -e "/gitlab_shell:$/,/\w:$/ s|(\s*repos_path:\s).*|\1${repos_path}/|" \ - -e "/gitlab_shell:$/,/\w:$/ s|(\s*hooks_path:\s).*|\1${hooks_path}/|" \ - config/gitlab.yml.example || die "failed to filter gitlab.yml.example" - - local run_path=/run/${MY_NAME} - sed -i -E \ - -e "s|/home/git/gitlab/tmp/(pids\|sockets)|${run_path}|" \ - -e "s|/home/git/gitlab/log|${LOGS_DIR}|" \ - -e "s|/home/git/gitlab|${DEST_DIR}|" \ - config/unicorn.rb.example || die "failed to filter unicorn.rb.example" - - sed -i \ - -e "s|/home/git/gitlab/tmp/sockets|${run_path}|" \ - lib/support/nginx/gitlab || die "failed to filter nginx/gitlab" - - # modify default database settings for PostgreSQL - sed -i -E \ - -e 's|(username:).*|\1 gitlab|' \ - -e 's|(password:).*|\1 gitlab|' \ - -e 's|(socket:).*|/run/postgresql/.s.PGSQL.5432|' \ - config/database.yml.postgresql \ - || die "failed to filter database.yml.postgresql" - - # rename config files - mv config/gitlab.yml.example config/gitlab.yml - mv config/unicorn.rb.example config/unicorn.rb - - local dbconf=config/database.yml - if use postgres && ! use mysql; then - mv ${dbconf}.postgresql ${dbconf} - rm ${dbconf}.mysql - elif use mysql && ! use postgres; then - mv ${dbconf}.mysql ${dbconf} - rm ${dbconf}.postgresql - fi - - # remove zzet's stupid migration which expetcs that users are so foolish - # to run GitLab with PostgreSQL's superuser... - rm db/migrate/20121009205010_postgres_create_integer_cast.rb - - # remove useless files - rm -r lib/support/{deploy,init.d} - use unicorn || rm config/unicorn.rb -} - -all_ruby_install() { - local dest=${DEST_DIR} - local conf=${CONF_DIR} - local logs=${LOGS_DIR} - local temp=${TEMP_DIR} - - # prepare directories - diropts -m750 - dodir ${logs} ${temp} ${temp}/repo_satellites - - diropts -m755 - dodir ${conf} ${dest}/public/uploads - - dosym ${temp} ${dest}/tmp - dosym ${logs} ${dest}/log - - # install configs - insinto ${conf} - doins -r config/* - dosym ${conf} ${dest}/config - - echo 'export RAILS_ENV=production' > "${D}/${dest}/.profile" - - # remove needless dirs - rm -Rf config tmp log - - # install the rest files - insinto ${dest} - doins -r ./ - - # install logrotate config - dodir /etc/logrotate.d - cat > "${D}/etc/logrotate.d/${MY_NAME}" <<-EOF - ${logs}/*.log { - missingok - delaycompress - compress - copytruncate - } - EOF - - ## Install gems via bundler ## - - cd "${D}/${dest}" - - local without="development test aws" - local flag; for flag in mysql postgres unicorn; do - without+="$(use $flag || echo ' '$flag)" - done - local bundle_args="--deployment ${without:+--without ${without}}" - - einfo "Running bundle install ${bundle_args} ..." - ${RUBY} /usr/bin/bundle install ${bundle_args} || die "bundler failed" - - # clean gems cache - rm -Rf vendor/bundle/ruby/*/cache - - # fix permissions - fowners -R ${MY_USER}:${MY_USER} ${dest} ${temp} ${logs} - fperms +x script/{rails,check} - - ## RC script ## - - local rcscript=gitlab-sidekiq.init - use unicorn && rcscript=gitlab-unicorn-6.init - - cp "${FILESDIR}/${rcscript}" "${T}" || die - sed -i \ - -e "s|@USER@|${MY_USER}|" \ - -e "s|@SLOT@|${SLOT}|" \ - -e "s|@GITLAB_BASE@|${dest}|" \ - -e "s|@LOGS_DIR@|${logs}|" \ - -e "s|@QUEUES@|${SIDEKIQ_QUEUES}|" \ - "${T}/${rcscript}" \ - || die "failed to filter ${rcscript}" - - newinitd "${T}/${rcscript}" "${MY_NAME}-${SLOT}" -} - -pkg_postinst() { - elog - elog "1. Configure your GitLab's settings in ${CONF_DIR}/gitlab.yml." - elog - elog "2. Configure your database settings in ${CONF_DIR}/database.yml" - elog " for \"production\" environment." - elog - elog "3. Then you should create a database for your GitLab instance, if you" - elog "haven't done so already." - elog - if use postgres; then - elog "If you have local PostgreSQL running, just copy&run:" - elog " su postgres" - elog " psql -c \"CREATE ROLE gitlab PASSWORD 'gitlab' \\" - elog " NOSUPERUSER NOCREATEDB NOCREATEROLE INHERIT LOGIN;\"" - elog " createdb -E UTF-8 -O gitlab gitlabhq_production" - elog " Note: You should change your password to something more random..." - elog - fi - elog "4. Finally execute the following command to initlize environment:" - elog " emerge --config \"=${CATEGORY}/${PF}\"" - elog " Note: Do not forget to start Redis server first!" - elog - elog "If this is an update from previous version, it's HIGHLY recommended" - elog "to backup your database before running the config phase!" - elog - elog "If you're running Gitlabhq behind an SSL proxy such as Apache or nginx and" - elog "you can't login after the upgrade, be sure to read the Gitlabhq trouble-" - elog "shooting guide at" - elog "https://github.com/gitlabhq/gitlab-public-wiki/wiki/Trouble-Shooting-Guide" - elog "especially the section about the verification of the CSRF token:" - elog "https://github.com/gitlabhq/gitlab-public-wiki/wiki/Trouble-Shooting-Guide#wiki-cant-verify-csrf-token-authenticitycant-get-past-login-pageredirected-to-login-page" -} - -pkg_config() { - local shell_conf='/etc/gitlab-shell.yml' - - einfo "Checking configuration files" - - if [ ! -r "${CONF_DIR}/database.yml" ]; then - eerror "Copy ${CONF_DIR}/database.yml.* to" - eerror "${CONF_DIR}/database.yml and edit this file in order to configure your" - eerror "database settings for \"production\" environment."; die - fi - - # check gitlab-shell configuration - if [ -r ${shell_conf} ]; then - local shell_repos_path="$(ryaml ${shell_conf} repos_path)" - local gitlab_repos_path="$(ryaml ${CONF_DIR}/gitlab.yml \ - production gitlab_shell repos_path)" - - if [ ! "${shell_repos_path}" -ef "${gitlab_repos_path}" ]; then - eerror "repos_path in ${CONF_DIR}/gitlab.yml and ${shell_conf}" - eerror "must points to the same location! Fix the repos_path location and" - eerror "run this again."; die - fi - else - ewarn "GitLab Shell checks skipped, could not find config file at" - ewarn "${shell_conf}. Make sure that you have gitlab-shell properly" - ewarn "installed and that repos_path is the same as in GitLab." - fi - - local email_from="$(ryaml ${CONF_DIR}/gitlab.yml production gitlab email_from)" - local git_home=$(getent passwd ${MY_USER} | cut -d: -f6) - - # configure Git global settings - if [ ! -e "${git_home}/.gitconfig" ]; then - einfo "Setting git user" - su -l ${MY_USER} -c " - git config --global user.email '${email_from}'; - git config --global user.name 'GitLab'" \ - || die "failed to setup git name and email" - fi - - if [ ! -d "${DEST_DIR}/.git" ]; then - # create dummy git repo as workaround for - # https://github.com/bundler/bundler/issues/2039 - einfo "Initializing dummy git repository to avoid false errors from bundler" - su -l ${MY_USER} -c " - cd ${DEST_DIR} - git init - git add README.md - git commit -m 'Dummy repository'" >/dev/null - fi - - ## Initialize app ## - - local RAILS_ENV="production" - local RUBY=${RUBY:-/usr/bin/ruby} - local BUNDLE="${RUBY} /usr/bin/bundle" - - local dbname="$(ryaml ${CONF_DIR}/database.yml production database)" - - local update= - while [ ! -n "${update}" ] ; do - echo - echo " Is this an update from previous version (fresh install otherwise)? (y/n)" - read answer - if [[ ${answer} =~ ^[Yy]([Ee][Ss])?$ ]]; then - update=true - elif [[ ${answer} =~ ^[Nn]([Oo])?$ ]]; then - update=false - else - echo "Answer not recognized" - fi - done - - if [ "${update}" = 'true' ]; then - einfo "Migrating database ..." - exec_rake db:migrate - - einfo "Cleaning old precompiled assets ..." - exec_rake assets:clean - - einfo "Cleaning cache ..." - exec_rake cache:clear - - # https://github.com/gitlabhq/gitlabhq/issues/5311#issuecomment-31656496 - einfo "Migrating iids ..." - exec_rake migrate_iids - else - einfo "Initializing database ..." - exec_rake gitlab:setup - fi - - einfo "Precompiling assests ..." - exec_rake assets:precompile - - if [ "${update}" = 'true' ]; then - ewarn - ewarn "This configuration script runs only common migration tasks." - ewarn "Please read guides on" - ewarn " https://github.com/gitlabhq/gitlabhq/blob/master/doc/update/" - ewarn "for any additional migration tasks specific to your previous GitLab" - ewarn "version." - fi -} - -ryaml() { - ruby -ryaml -e 'puts ARGV[1..-1].inject(YAML.load(File.read(ARGV[0]))) {|acc, key| acc[key] }' "$@" -} - -exec_rake() { - local command="${BUNDLE} exec rake $@ RAILS_ENV=${RAILS_ENV}" - - echo " ${command}" - su -l ${MY_USER} -c " - export LANG=en_US.UTF-8; export LC_ALL=en_US.UTF-8 - cd ${DEST_DIR} - ${command}" \ - || die "failed to run rake $@" -}