gitlab-core.rb
3.03 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
#
# Copyright:: Copyright (c) 2012 Opscode, Inc.
# License:: Apache License, Version 2.0
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
name "gitlab-core"
version "master"
dependency "ruby"
dependency "bundler"
dependency "libxml2"
dependency "libxslt"
dependency "curl"
dependency "rsync"
dependency "libicu"
dependency "postgresql"
source :git => "https://gitlab.com/gitlab-org/gitlab-ce.git"
build do
# GitLab assumes it can extract the Git revision of the currently version
# from the Git repo the code lives in at boot. Because of our rsync later on,
# this assumption does not hold. The sed command below patches the GitLab
# source code to include the Git revision of the code included in the omnibus
# build.
command "sed -i 's/.*REVISION.*/REVISION = \"#{version_guid.split(':').last[0,10]}\"/' config/initializers/2_app.rb"
bundle "install --without mysql development test --path=#{install_dir}/embedded/service/gem"
# In order to precompile the assets, we need to get to a state where rake can
# load the Rails environment.
command "cp config/gitlab.yml.example config/gitlab.yml"
command "cp config/database.yml.postgresql config/database.yml"
# There is a bug in the acts-as-taggable-on gem that makes
# rake assets:precompile check for a database connection. We do not have a
# database at this point so that is a problem. This bug is fixed in
# acts-as-taggable-on 3.0.0 by
# https://github.com/mbleigh/acts-as-taggable-on/commit/ad02dc9bb24ec8e1e79e7e35e2d4bb5910a66d8e
command "git apply #{Omnibus.project_root}/config/patches/acts-as-taggable-on-ad02dc9bb24ec8e1e79e7e35e2d4bb5910a66d8e.diff",
:cwd => "#{install_dir}/embedded/service/gem/ruby/1.9.1/gems/acts-as-taggable-on-2.4.1"
rake "assets:precompile", :env => {"RAILS_ENV" => "production"}
# Tear down now that the assets:precompile is done.
command "rm config/gitlab.yml config/database.yml"
command "mkdir -p #{install_dir}/embedded/service/gitlab-core"
command "#{install_dir}/embedded/bin/rsync -a --delete --exclude=.git/*** --exclude=.gitignore ./ #{install_dir}/embedded/service/gitlab-core/"
block do
open("#{install_dir}/bin/gitlab-rake", "w") do |file|
file.print <<-EOH
#!/bin/bash
export PATH=/opt/gitlab/bin:/opt/gitlab/embedded/bin:$PATH
# default to RAILS_ENV=production
if [[ -z $RAILS_ENV ]]; then
export RAILS_ENV=production
fi
cd /opt/gitlab/embedded/service/gitlab-core
/opt/gitlab/embedded/bin/chpst -u git -U git /opt/gitlab/embedded/bin/bundle exec rake "$@"
EOH
end
end
command "chmod +x #{install_dir}/bin/gitlab-rake"
end