Commit 23a7805fe29848a647b2ac5347a39c4188e869a8
1 parent
3e39c878
Exists in
master
and in
67 other branches
Use separate SSH configs per environment
Requires chake > 0.4
Showing
2 changed files
with
12 additions
and
5 deletions
Show diff stats
.gitignore
Rakefile
| 1 | -require 'chake' | ||
| 2 | - | ||
| 3 | $SPB_ENV = ENV.fetch('SPB_ENV', 'development') | 1 | $SPB_ENV = ENV.fetch('SPB_ENV', 'development') |
| 4 | 2 | ||
| 3 | +ssh_config_file = "config/#{$SPB_ENV}/ssh_config" | ||
| 5 | ips_file = "config/#{$SPB_ENV}/ips.yaml" | 4 | ips_file = "config/#{$SPB_ENV}/ips.yaml" |
| 6 | config_file = "config/#{$SPB_ENV}/config.yaml" | 5 | config_file = "config/#{$SPB_ENV}/config.yaml" |
| 7 | 6 | ||
| 7 | +ENV['CHAKE_SSH_CONFIG'] = ssh_config_file | ||
| 8 | + | ||
| 9 | +require 'chake' | ||
| 10 | + | ||
| 11 | +if Chake::VERSION < '0.4' | ||
| 12 | + fail "Please upgrade to chake 0.4+" | ||
| 13 | +end | ||
| 14 | + | ||
| 8 | config = YAML.load_file(config_file) | 15 | config = YAML.load_file(config_file) |
| 9 | ips = YAML.load_file(ips_file) | 16 | ips = YAML.load_file(ips_file) |
| 10 | $nodes.each do |node| | 17 | $nodes.each do |node| |
| @@ -24,7 +31,7 @@ end | @@ -24,7 +31,7 @@ end | ||
| 24 | task :default => :test | 31 | task :default => :test |
| 25 | 32 | ||
| 26 | file 'ssh_config.erb' | 33 | file 'ssh_config.erb' |
| 27 | -file '.ssh_config' => ['nodes.yaml', ips_file,'ssh_config.erb'] do |t| | 34 | +file 'config/development/ssh_config' => ['nodes.yaml', 'config/development/ips.yaml', 'ssh_config.erb'] do |t| |
| 28 | require 'erb' | 35 | require 'erb' |
| 29 | template = ERB.new(File.read('ssh_config.erb')) | 36 | template = ERB.new(File.read('ssh_config.erb')) |
| 30 | File.open(t.name, 'w') do |f| | 37 | File.open(t.name, 'w') do |f| |
| @@ -33,7 +40,7 @@ file '.ssh_config' => ['nodes.yaml', ips_file,'ssh_config.erb'] do |t| | @@ -33,7 +40,7 @@ file '.ssh_config' => ['nodes.yaml', ips_file,'ssh_config.erb'] do |t| | ||
| 33 | puts 'ERB %s' % t.name | 40 | puts 'ERB %s' % t.name |
| 34 | end | 41 | end |
| 35 | 42 | ||
| 36 | -task :bootstrap_common => '.ssh_config' | 43 | +task :bootstrap_common => 'config/development/ssh_config' |
| 37 | 44 | ||
| 38 | unless ENV['nodeps'] | 45 | unless ENV['nodeps'] |
| 39 | task 'converge:integration' => 'converge:database' | 46 | task 'converge:integration' => 'converge:database' |