Commit 23a7805fe29848a647b2ac5347a39c4188e869a8
1 parent
3e39c878
Exists in
master
and in
65 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' |