Commit 04640dbbf3098e061550b2d6e57c6771765d8371
1 parent
d0566313
Exists in
master
and in
1 other branch
Tweak configurable deploy.rb
Showing
3 changed files
with
14 additions
and
80 deletions
Show diff stats
.gitignore
config/deploy.example.rb
@@ -6,21 +6,27 @@ | @@ -6,21 +6,27 @@ | ||
6 | # `cap deploy` whenever you would like to deploy Errbit. Refer | 6 | # `cap deploy` whenever you would like to deploy Errbit. Refer |
7 | # to the Readme for more information. | 7 | # to the Readme for more information. |
8 | 8 | ||
9 | +config = YAML.load_file('config/config.yml')['deployment'] || {} | ||
10 | + | ||
9 | require 'bundler/capistrano' | 11 | require 'bundler/capistrano' |
10 | 12 | ||
11 | set :application, "errbit" | 13 | set :application, "errbit" |
12 | -set :repository, "http://github.com/jdpace/errbit.git" | 14 | +set :repository, config['repository'] || "http://github.com/errbit/errbit.git" |
13 | 15 | ||
14 | -role :web, "errbit.example.com" | ||
15 | -role :app, "errbit.example.com" | ||
16 | -role :db, "errbit.example.com", :primary => true | 16 | +role :web, config['hosts']['web'] || "errbit.example.com" |
17 | +role :app, config['hosts']['app'] || "errbit.example.com" | ||
18 | +role :db, config['hosts']['db'] || "errbit.example.com", :primary => true | ||
17 | 19 | ||
18 | -set :user, :deploy | 20 | +set :user, config['user'] || :deploy |
19 | set :use_sudo, false | 21 | set :use_sudo, false |
20 | -set :ssh_options, { :forward_agent => true } | 22 | +if config.has_key?('ssh_key') |
23 | + set :ssh_options, { :forward_agent => true, :keys => [ config['ssh_key'] ] } | ||
24 | +else | ||
25 | + set :ssh_options, { :forward_agent => true } | ||
26 | +end | ||
21 | default_run_options[:pty] = true | 27 | default_run_options[:pty] = true |
22 | 28 | ||
23 | -set :deploy_to, "/var/www/apps/#{application}" | 29 | +set :deploy_to, config['deploy_to'] || "/var/www/apps/#{application}" |
24 | set :deploy_via, :remote_cache | 30 | set :deploy_via, :remote_cache |
25 | set :copy_cache, true | 31 | set :copy_cache, true |
26 | set :copy_exclude, [".git"] | 32 | set :copy_exclude, [".git"] |
config/deploy.rb
@@ -1,73 +0,0 @@ | @@ -1,73 +0,0 @@ | ||
1 | -# Deploy Config | ||
2 | -# ============= | ||
3 | -# | ||
4 | -# Copy this file to config/deploy.rb and customize it as needed. | ||
5 | -# Then run `cap deploy:setup` to set up your server and finally | ||
6 | -# `cap deploy` whenever you would like to deploy Errbit. Refer | ||
7 | -# to the Readme for more information. | ||
8 | - | ||
9 | -config = YAML.load_file('config/config.yml')['deployment'] | ||
10 | - | ||
11 | -require 'bundler/capistrano' | ||
12 | - | ||
13 | -set :application, "errbit" | ||
14 | -set :repository, config['repository'] | ||
15 | - | ||
16 | -role :web, config['hosts']['web'] | ||
17 | -role :app, config['hosts']['app'] | ||
18 | -role :db, config['hosts']['db'], :primary => true | ||
19 | - | ||
20 | -set :user, config['user'] | ||
21 | -set :use_sudo, false | ||
22 | -# if config.has_key?('ssh_key') | ||
23 | - set :ssh_options, { :forward_agent => true, :keys => [ config['ssh_key'] ] } | ||
24 | -# else | ||
25 | - # set :ssh_options, { :forward_agent => true } | ||
26 | -# end | ||
27 | -default_run_options[:pty] = true | ||
28 | - | ||
29 | -set :deploy_to, config['deploy_to'] | ||
30 | -set :deploy_via, :remote_cache | ||
31 | -set :copy_cache, true | ||
32 | -set :copy_exclude, [".git"] | ||
33 | -set :copy_compression, :bz2 | ||
34 | - | ||
35 | -set :scm, :git | ||
36 | -set :scm_verbose, true | ||
37 | -set(:current_branch) { `git branch`.match(/\* (\S+)\s/m)[1] || raise("Couldn't determine current branch") } | ||
38 | -set :branch, defer { current_branch } | ||
39 | - | ||
40 | -after 'deploy:update_code', 'errbit:symlink_configs' | ||
41 | - | ||
42 | -namespace :deploy do | ||
43 | - task :start do ; end | ||
44 | - task :stop do ; end | ||
45 | - task :restart, :roles => :app, :except => { :no_release => true } do | ||
46 | - run "#{try_sudo} touch #{File.join(current_path,'tmp','restart.txt')}" | ||
47 | - end | ||
48 | -end | ||
49 | - | ||
50 | -namespace :errbit do | ||
51 | - task :setup_configs do | ||
52 | - shared_configs = File.join(shared_path,'config') | ||
53 | - run "mkdir -p #{shared_configs}" | ||
54 | - run "if [ ! -f #{shared_configs}/config.yml ]; then cp #{latest_release}/config/config.example.yml #{shared_configs}/config.yml; fi" | ||
55 | - run "if [ ! -f #{shared_configs}/mongoid.yml ]; then cp #{latest_release}/config/mongoid.example.yml #{shared_configs}/mongoid.yml; fi" | ||
56 | - end | ||
57 | - | ||
58 | - task :symlink_configs do | ||
59 | - errbit.setup_configs | ||
60 | - shared_configs = File.join(shared_path,'config') | ||
61 | - release_configs = File.join(release_path,'config') | ||
62 | - run("ln -nfs #{shared_configs}/config.yml #{release_configs}/config.yml") | ||
63 | - run("ln -nfs #{shared_configs}/mongoid.yml #{release_configs}/mongoid.yml") | ||
64 | - end | ||
65 | -end | ||
66 | - | ||
67 | -namespace :db do | ||
68 | - desc "Create the indexes defined on your mongoid models" | ||
69 | - task :create_mongoid_indexes do | ||
70 | - run "cd #{current_path} && bundle exec rake db:mongoid:create_indexes" | ||
71 | - end | ||
72 | -end | ||
73 | - |