diff options
author | Marc Schiffbauer <mschiff@gentoo.org> | 2014-05-22 00:47:03 +0200 |
---|---|---|
committer | Marc Schiffbauer <mschiff@gentoo.org> | 2014-05-22 00:47:03 +0200 |
commit | e7dcf1da9772f20f4a02492c26ff057efbc629f6 (patch) | |
tree | fd16ec7cb634c2b80b71a3fb90888e2620c0f96c /www-apps | |
parent | added 0.9.1 (diff) | |
download | mschiff-e7dcf1da9772f20f4a02492c26ff057efbc629f6.tar.gz mschiff-e7dcf1da9772f20f4a02492c26ff057efbc629f6.tar.bz2 mschiff-e7dcf1da9772f20f4a02492c26ff057efbc629f6.zip |
added gitlabhq ebuidld (based on cvut overlay)
Diffstat (limited to 'www-apps')
-rw-r--r-- | www-apps/gitlabhq/Manifest | 10 | ||||
-rw-r--r-- | www-apps/gitlabhq/files/gitlab-sidekiq.init | 43 | ||||
-rw-r--r-- | www-apps/gitlabhq/files/gitlab-unicorn-6.init | 67 | ||||
-rw-r--r-- | www-apps/gitlabhq/files/gitlabhq-6.0.2-fix-sendmail-config.patch | 20 | ||||
-rw-r--r-- | www-apps/gitlabhq/files/gitlabhq-6.8.2-email-custom-reply_to.patch | 36 | ||||
-rw-r--r-- | www-apps/gitlabhq/files/gitlabhq-6.8.2-fix-gemfile.patch | 86 | ||||
-rw-r--r-- | www-apps/gitlabhq/files/gitlabhq-6.8.2-fix-project-name-regex.patch | 30 | ||||
-rw-r--r-- | www-apps/gitlabhq/files/gitlabhq-6.8.2-ldap-custom-mapping.patch | 99 | ||||
-rw-r--r-- | www-apps/gitlabhq/gitlabhq-6.8.2.ebuild | 362 | ||||
-rw-r--r-- | www-apps/gitlabhq/metadata.xml | 19 |
10 files changed, 772 insertions, 0 deletions
diff --git a/www-apps/gitlabhq/Manifest b/www-apps/gitlabhq/Manifest new file mode 100644 index 0000000..e0c345b --- /dev/null +++ b/www-apps/gitlabhq/Manifest @@ -0,0 +1,10 @@ +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.0.2-fix-sendmail-config.patch 731 SHA256 51f0d0af2a7c048d7cff56cf27955632f340ca67f9d460af840cf34ed60ca574 SHA512 b10d5b8d89927404d25345e17ba37ca4e7848b04c2ca20c5eef14eaac43d9ba14b62ae4c0d532eefaf6f9a2944578e84eb65a3420335d32495855c4807eec356 WHIRLPOOL 66f6443f311f2355ffd4efaea914f462816a1966a715b3b5ffaaa26b41bdced928b9905b8606f06fac3c2ccf20741553cfed2615430287bede01cf376aae2a60 +AUX gitlabhq-6.8.2-email-custom-reply_to.patch 2014 SHA256 7b0a66c3dde960aac805d1b2780be1166135f7b124e1f3a4861fae2f04543c01 SHA512 2c1da90d46ce57dad00df7a55f0af6ab1eca4e09a96580f8482dcff2188d351ce21f1bd366894e64eb1888904f6a8fddc4dec34d88af06e95946c0be834364e2 WHIRLPOOL bf126a9486fab62bdd921459c8d21e13c5de85542dde129e773057ccf9e80662b923f0bc84e2476735c8dafdb5800c6e7249450a37ad04be39d70e766af2ffd3 +AUX gitlabhq-6.8.2-fix-gemfile.patch 2263 SHA256 584966eb3efc63a6102754e165c46d50b037e3ea046a2fe1cfc24b53bf03bdea SHA512 9bd6490e86dcc830c759210dc6ceed101c177cee06bc4427398ed03fba8e128413b4cb04317e081b765df5c39987219c2bc1ce5538479ec39d3bcf5d253bb9e0 WHIRLPOOL 8d9dbafd45d61cb23e3126192666e671b8b8d46bc1898c976aa335fb58546c11885b14e370e45ca5dff01a68de7b555a9ae0a8a325f818c54e4e617704c360dd +AUX gitlabhq-6.8.2-fix-project-name-regex.patch 1376 SHA256 71f6c2ebbe3af6012cf523535699001d86c4ad925cc7b78d179a3ec7002ddf9b SHA512 c2fe0959486e2bd05b856a8c9f710a89709fee77bf0c490fffcbf2b014223aed761ad1e1ef42ea3412f595066cf109937fb02135ec4c70c64330c48780bb7655 WHIRLPOOL 8003eb841390e5c5edde24b05a408d9982aeaba0cbccbd7824fbd8d469c445be3bcc46e2d58712fa7de0b8d3aabc9e85a33211071a58b9d2a0f43d97eb8b44ba +AUX gitlabhq-6.8.2-ldap-custom-mapping.patch 3276 SHA256 d335fc980a891a7a24cbb96ec7a4109bb3fc3a89ebc8c797d787e69fff74e7d2 SHA512 7cb523db97986eb94d0feda7be0eb8f400b9df744f25a44a783925059ae97671400bebfbe75b6d803640e4eb828abea193dcde26a2e6d5f103dc9d0913772365 WHIRLPOOL 76d81fd7075bb6dd52b622c6f2147393dd5fcf8e42addb82e9431a019c445f5703a77f31db71a62e05561eb05be8195bf05da0be83cd20db57659a057f7b0481 +DIST gitlabhq-6.8.2.tar.gz 10558471 SHA256 db9400d5ffadd3564bbee6e388c90d7f4c8f88450e67213aad11df2d137534ec SHA512 0f57c6bb3b9e89a5bbf7ae4c774e54480518f185f2e50270a7dd921eb2a2322f3e6866ca70741582fad4f99b372ba025fbab15108c291d53ebf04cfaec2f9b75 WHIRLPOOL 73ebd0fb0faef7afd48398ec4e73c8f4175f3dc2a9450ae391b4d3a66b54e0d77f901f518738eb98cc267691559094d4ebecd4c0a7c18fa671c3a1aee4dfe4d2 +EBUILD gitlabhq-6.8.2.ebuild 10719 SHA256 cf723823af2609d9918dbe91302d7795ba49d57f2861ba98fb3512c05c6160fc SHA512 292f615eba6d5cd0e5b9789a94d114dc4299663fcfd4a4a839f769ae141a4d9deae030b6f69c7ad66da9b39ae9502cb284259515d5f584138ab7f86fbc5860ad WHIRLPOOL e4ec260a9ceecb8f18c44f0ba5ff5707bb40324d9fb17cdc331cd08de668ae818d11d9db7bf6534c03bcbd3b8c9f4dd91af55b1670b830b95636699436e398b4 +MISC metadata.xml 475 SHA256 65a46fa9904c8b7657181e4929f304675a2173e9329aa8fb5d8645515032168f SHA512 b2aa4c167c6287e60bb62a45e3d48fa00a8b080e0f81a966388dd8a1fbc2012f9737d5f02134382e5a0b212b38781c15b0fdf2508fe6b4b7630a8fcebe713065 WHIRLPOOL 5b5f73953ba7b23b7f9590da5f2e22a0930880ceb37eb87c25a8e043943671da1fcf8f561f76d2c262a1f514cb917140c99d77d9f4e448ed260b1a5127603195 diff --git a/www-apps/gitlabhq/files/gitlab-sidekiq.init b/www-apps/gitlabhq/files/gitlab-sidekiq.init new file mode 100644 index 0000000..99b2d17 --- /dev/null +++ b/www-apps/gitlabhq/files/gitlab-sidekiq.init @@ -0,0 +1,43 @@ +#!/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 new file mode 100644 index 0000000..382be7a --- /dev/null +++ b/www-apps/gitlabhq/files/gitlab-unicorn-6.init @@ -0,0 +1,67 @@ +#!/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.0.2-fix-sendmail-config.patch b/www-apps/gitlabhq/files/gitlabhq-6.0.2-fix-sendmail-config.patch new file mode 100644 index 0000000..0a6e8d9 --- /dev/null +++ b/www-apps/gitlabhq/files/gitlabhq-6.0.2-fix-sendmail-config.patch @@ -0,0 +1,20 @@ +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/files/gitlabhq-6.8.2-email-custom-reply_to.patch b/www-apps/gitlabhq/files/gitlabhq-6.8.2-email-custom-reply_to.patch new file mode 100644 index 0000000..319da52 --- /dev/null +++ b/www-apps/gitlabhq/files/gitlabhq-6.8.2-email-custom-reply_to.patch @@ -0,0 +1,36 @@ +diff -ur gitlabhq-6.8.2.orig/app/mailers/notify.rb gitlabhq-6.8.2/app/mailers/notify.rb +--- gitlabhq-6.8.2.orig/app/mailers/notify.rb 2014-05-12 11:15:38.000000000 +0200 ++++ gitlabhq-6.8.2/app/mailers/notify.rb 2014-05-21 21:15:49.607758248 +0200 +@@ -16,7 +16,7 @@ + default_url_options[:script_name] = Gitlab.config.gitlab.relative_url_root + + default from: Proc.new { default_sender_address.format } +- default reply_to: "noreply@#{Gitlab.config.gitlab.host}" ++ default reply_to: Gitlab.config.gitlab.email_reply_to + + # Just send email with 2 seconds delay + def self.delay +diff -ur gitlabhq-6.8.2.orig/config/gitlab.yml.example gitlabhq-6.8.2/config/gitlab.yml.example +--- gitlabhq-6.8.2.orig/config/gitlab.yml.example 2014-05-12 11:15:38.000000000 +0200 ++++ gitlabhq-6.8.2/config/gitlab.yml.example 2014-05-21 21:16:46.744345902 +0200 +@@ -37,6 +37,9 @@ + # Email address used in the "From" field in mails sent by GitLab + email_from: gitlab@localhost + ++ # Email address used in the "Reply-To" field in mails send by GitLab (default: no-reply@<host>) ++ email_reply_to: no-reply@localhost ++ + # Email address of your support contact (default: same as email_from) + support_email: support@localhost + +diff -ur gitlabhq-6.8.2.orig/config/initializers/1_settings.rb gitlabhq-6.8.2/config/initializers/1_settings.rb +--- gitlabhq-6.8.2.orig/config/initializers/1_settings.rb 2014-05-12 11:15:38.000000000 +0200 ++++ gitlabhq-6.8.2/config/initializers/1_settings.rb 2014-05-21 21:17:24.905406287 +0200 +@@ -78,6 +78,7 @@ + Settings.gitlab['relative_url_root'] ||= ENV['RAILS_RELATIVE_URL_ROOT'] || '' + Settings.gitlab['protocol'] ||= Settings.gitlab.https ? "https" : "http" + Settings.gitlab['email_from'] ||= "gitlab@#{Settings.gitlab.host}" ++Settings.gitlab['email_reply_to'] ||= "no-reply@#{Settings.gitlab.host}" + Settings.gitlab['support_email'] ||= Settings.gitlab.email_from + Settings.gitlab['url'] ||= Settings.send(:build_gitlab_url) + Settings.gitlab['user'] ||= 'git' diff --git a/www-apps/gitlabhq/files/gitlabhq-6.8.2-fix-gemfile.patch b/www-apps/gitlabhq/files/gitlabhq-6.8.2-fix-gemfile.patch new file mode 100644 index 0000000..7bc7218 --- /dev/null +++ b/www-apps/gitlabhq/files/gitlabhq-6.8.2-fix-gemfile.patch @@ -0,0 +1,86 @@ +diff -ur gitlabhq-6.8.2.orig/Gemfile gitlabhq-6.8.2/Gemfile +--- gitlabhq-6.8.2.orig/Gemfile 2014-05-12 11:15:38.000000000 +0200 ++++ gitlabhq-6.8.2/Gemfile 2014-05-22 00:21:48.158938691 +0200 +@@ -142,6 +142,10 @@ + # Sanitize user input + gem "sanitize", '~> 2.0' + ++# 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" + +@@ -151,7 +155,6 @@ + gem "sass-rails", '~> 4.0.2' + gem "coffee-rails" + gem "uglifier" +-gem "therubyracer" + gem 'turbolinks' + gem 'jquery-turbolinks' + +diff -ur gitlabhq-6.8.2.orig/Gemfile.lock gitlabhq-6.8.2/Gemfile.lock +--- gitlabhq-6.8.2.orig/Gemfile.lock 2014-05-12 11:15:38.000000000 +0200 ++++ gitlabhq-6.8.2/Gemfile.lock 2014-05-22 00:24:39.954746019 +0200 +@@ -1,3 +1,10 @@ ++GIT ++ remote: https://github.com/brianmario/charlock_holmes.git ++ revision: dde194609b3513b0d2369ce8f916ae52566154b4 ++ ref: dde194609b3513b0d2369ce8f916ae52566154b4 ++ specs: ++ charlock_holmes (0.6.9.4) ++ + GEM + remote: https://rubygems.org/ + specs: +@@ -60,7 +67,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) +@@ -402,7 +407,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) +@@ -496,9 +500,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) +@@ -567,6 +568,7 @@ + bootstrap-sass (~> 3.0) + capybara + carrierwave ++ charlock_holmes! + coffee-rails + colored + coveralls +@@ -654,7 +656,6 @@ + stamp + state_machine + test_after_commit +- therubyracer + thin + tinder (~> 1.9.2) + turbolinks diff --git a/www-apps/gitlabhq/files/gitlabhq-6.8.2-fix-project-name-regex.patch b/www-apps/gitlabhq/files/gitlabhq-6.8.2-fix-project-name-regex.patch new file mode 100644 index 0000000..8f986c1 --- /dev/null +++ b/www-apps/gitlabhq/files/gitlabhq-6.8.2-fix-project-name-regex.patch @@ -0,0 +1,30 @@ +diff -ur gitlabhq-6.8.2.orig/app/models/project.rb gitlabhq-6.8.2/app/models/project.rb +--- gitlabhq-6.8.2.orig/app/models/project.rb 2014-05-12 11:15:38.000000000 +0200 ++++ gitlabhq-6.8.2/app/models/project.rb 2014-05-21 21:05:09.641976937 +0200 +@@ -90,7 +90,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 -ur gitlabhq-6.8.2.orig/lib/gitlab/regex.rb gitlabhq-6.8.2/lib/gitlab/regex.rb +--- gitlabhq-6.8.2.orig/lib/gitlab/regex.rb 2014-05-12 11:15:38.000000000 +0200 ++++ gitlabhq-6.8.2/lib/gitlab/regex.rb 2014-05-21 21:03:43.872609059 +0200 +@@ -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 diff --git a/www-apps/gitlabhq/files/gitlabhq-6.8.2-ldap-custom-mapping.patch b/www-apps/gitlabhq/files/gitlabhq-6.8.2-ldap-custom-mapping.patch new file mode 100644 index 0000000..c8c8f55 --- /dev/null +++ b/www-apps/gitlabhq/files/gitlabhq-6.8.2-ldap-custom-mapping.patch @@ -0,0 +1,99 @@ +diff --git a/Gemfile b/Gemfile +index fe8e54e..b33a74e 100644 +--- a/Gemfile ++++ b/Gemfile +@@ -36,7 +36,8 @@ gem "gitlab_git", "~> 4.0.0" + gem 'gitlab-grack', '~> 2.0.0.pre', require: 'grack' + + # LDAP Auth +-gem 'gitlab_omniauth-ldap', '1.0.3', require: "omniauth-ldap" ++# Patched for attributes mapping customization ++gem 'gitlab_omniauth-ldap', '1.0.4', require: 'omniauth-ldap', git: 'https://github.com/jirutka/omniauth-ldap.git', ref: 'b55852bfc9b46ecf790a2c5526386702350eab89' + + # Syntax highlighter + gem "gitlab-pygments.rb", '~> 0.5.4', require: 'pygments.rb' +diff --git a/Gemfile.lock b/Gemfile.lock +index d0f185b..46543e3 100644 +--- a/Gemfile.lock ++++ b/Gemfile.lock +@@ -6,6 +6,17 @@ GIT + charlock_holmes (0.6.9.4) + + GIT ++ remote: https://github.com/jirutka/omniauth-ldap.git ++ revision: b55852bfc9b46ecf790a2c5526386702350eab89 ++ ref: b55852bfc9b46ecf790a2c5526386702350eab89 ++ specs: ++ gitlab_omniauth-ldap (1.0.4) ++ net-ldap (~> 0.3.1) ++ omniauth (~> 1.0) ++ pyu-ruby-sasl (~> 0.0.3.1) ++ rubyntlm (~> 0.1.1) ++ ++GIT + remote: https://github.com/gitlabhq/markup.git + revision: 61ade389c1e1c159359338f570d18464a44ddbc4 + ref: 61ade389c1e1c159359338f570d18464a44ddbc4 +@@ -193,11 +204,6 @@ GEM + gitlab-linguist (~> 2.9.5) + gitlab-pygments.rb (~> 0.5.4) + gitlab_meta (6.0) +- gitlab_omniauth-ldap (1.0.3) +- net-ldap (~> 0.3.1) +- omniauth (~> 1.0) +- pyu-ruby-sasl (~> 0.0.3.1) +- rubyntlm (~> 0.1.1) + gon (5.0.1) + actionpack (>= 2.3.0) + json +@@ -587,7 +593,7 @@ DEPENDENCIES + gitlab-pygments.rb (~> 0.5.4) + gitlab_git (~> 4.0.0) + gitlab_meta (= 6.0) +- gitlab_omniauth-ldap (= 1.0.3) ++ gitlab_omniauth-ldap (= 1.0.4)! + gon (~> 5.0.0) + grape (~> 0.6.1) + grape-entity (~> 0.3.0) +diff --git a/config/gitlab.yml.example b/config/gitlab.yml.example +index 776d930..a5b96e4 100644 +--- a/config/gitlab.yml.example ++++ b/config/gitlab.yml.example +@@ -130,6 +130,10 @@ production: &base + method: 'ssl' # "ssl" or "plain" + bind_dn: '_the_full_dn_of_the_user_you_will_bind_with' + password: '_the_password_of_the_bind_user' ++ mapping: ++ username: 'uid' ++ name: 'cn' ++ email: 'mail' + # If allow_username_or_email_login is enabled, GitLab will ignore everything + # after the first '@' in the LDAP username submitted by the user on login. + # +diff --git a/config/initializers/devise.rb b/config/initializers/devise.rb +index 2539097..739de8e 100644 +--- a/config/initializers/devise.rb ++++ b/config/initializers/devise.rb +@@ -223,6 +223,7 @@ Devise.setup do |config| + method: Gitlab.config.ldap['method'], + bind_dn: Gitlab.config.ldap['bind_dn'], + password: Gitlab.config.ldap['password'], ++ mapping: Gitlab.config.ldap['mapping'], + name_proc: email_stripping_proc + end + +diff --git a/lib/gitlab/ldap/user.rb b/lib/gitlab/ldap/user.rb +index 8afd64f..f1f1bea 100644 +--- a/lib/gitlab/ldap/user.rb ++++ b/lib/gitlab/ldap/user.rb +@@ -97,6 +97,10 @@ module Gitlab + 'ldap' + end + ++ def username ++ (auth.info.username || auth.info.nickname).to_s.force_encoding('utf-8') ++ end ++ + def raise_error(message) + raise OmniAuth::Error, "(LDAP) " + message + end diff --git a/www-apps/gitlabhq/gitlabhq-6.8.2.ebuild b/www-apps/gitlabhq/gitlabhq-6.8.2.ebuild new file mode 100644 index 0000000..8c89e5b --- /dev/null +++ b/www-apps/gitlabhq/gitlabhq-6.8.2.ebuild @@ -0,0 +1,362 @@ +# Copyright 1999-2014 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_COMPAT=( python{2_7,3_{1,2,3}} ) + +inherit eutils python-r1 ruby-ng user + +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" + +# +# 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. +# +# "${P}-ldap-custom-mapping.patch" +RUBY_PATCHES=( + "${P}-fix-gemfile.patch" + "${P}-fix-project-name-regex.patch" + "${PN}-6.0.2-fix-sendmail-config.patch" + "${P}-email-custom-reply_to.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/v${PV}/script/background_jobs +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 shell_path=/usr/share/gitlab-shell + sed -i -E \ + -e "/satellites:$/,/\w:$/ s|(\s*path:\s).*|\1${satellites_path}/|" \ + -e "/gitlab_shell:$/,/\w:$/ s|(\s*path:\s).*|\1${shell_path}/|" \ + -e "/gitlab_shell:$/,/\w:$/ s|(\s*repos_path:\s).*|\1${repos_path}/|" \ + -e "/gitlab_shell:$/,/\w:$/ s|(\s*hooks_path:\s).*|\1${shell_path}/hooks/|" \ + 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} + rm -r script/{background_jobs,web} + 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 + # using cp 'cause doins is slow + cp -Rl * "${D}/${dest}"/ + + # 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 GitLab behind an SSL proxy such as nginx or Apache and" + elog "you can't login after the upgrade, be sure to read the section about the" + elog "verification of the CSRF token in GitLab's trouble-shooting guide at" + elog "http://goo.gl/5XGRGv." +} + +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="$(egethome ${MY_USER})" + + # 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)" + + if [ -f "${DEST_DIR}/.secret" ]; then + local update=true + + einfo "Migrating database ..." + exec_rake db:migrate + + # https://github.com/gitlabhq/gitlabhq/issues/5311#issuecomment-31656496 + einfo "Migrating iids ..." + exec_rake migrate_iids + + einfo "Cleaning old precompiled assets ..." + exec_rake assets:clean + + einfo "Cleaning cache ..." + exec_rake cache:clear + else + local update=false + + 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 $@" +} diff --git a/www-apps/gitlabhq/metadata.xml b/www-apps/gitlabhq/metadata.xml new file mode 100644 index 0000000..d68dded --- /dev/null +++ b/www-apps/gitlabhq/metadata.xml @@ -0,0 +1,19 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd"> +<pkgmetadata> + <maintainer> + <email>mschiff@gentoo.org</email> + <name>Marc Schiffbauer</name> + </maintainer> + <use> + <flag name="mysql"> + Adds support for the MySQL database. + </flag> + <flag name="postgres"> + Adds support for the PostgreSQL database. + </flag> + <flag name="unicorn"> + Build with bundled Unicorn server. + </flag> + </use> +</pkgmetadata> |