X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/dc1967cf9fbd59498f6a0e86f082f56fae9d5b10..c0eba3250e02beec9eae3c9c6a8df1b7a3188fb2:/docker/config.rb diff --git a/docker/config.rb b/docker/config.rb index 8f2f72402b..81642bfb41 100755 --- a/docker/config.rb +++ b/docker/config.rb @@ -9,19 +9,10 @@ config = YAML.load_file('config.yml') # Add dynamically chosen config settings. These settings should # be suitable for any installation. -# The APP_SECRET the application uses (with OMNIAUTH_APP_ID) to -# authenticate itself to Omniauth. By default this is generated -# randomly when the application is built; you can instead -# substitute a hardcoded string. -config['OMNIAUTH_APP_SECRET'] = rand(2**512).to_s(36) - -# The secret token in services/api/config/initializers/secret_token.rb. -config['API_SECRET'] = rand(2**256).to_s(36) - -# Any _PW config settings represent a database password. If it -# is blank, choose a password randomly. +# Any _PW/_SECRET config settings represent passwords/secrets. If they +# are blank, choose a password randomly. config.each_key do |var| - if var.end_with?('_PW') and (config[var].nil? or config[var].empty?) + if (var.end_with?('_PW') || var.end_with?('_SECRET')) && (config[var].nil? || config[var].empty?) config[var] = rand(2**256).to_s(36) end end @@ -29,7 +20,7 @@ end # ============================================================ # For each *.in file in the docker directories, substitute any # @@variables@@ found in the file with the appropriate config -# variable. +# variable. Support up to 10 levels of nesting. # # TODO(twp): add the *.in files directory to the source tree, and # when expanding them, add them to the "generated" directory with @@ -47,7 +38,21 @@ Dir.glob('*/*.in') do |template_file| output = File.open(output_path, "w") File.open(template_file) do |input| input.each_line do |line| - output.write(line.gsub(/@@(.*?)@@/) { |var| config[$1] || var }) + + @count = 0 + while @count < 10 + @out = line.gsub!(/@@(.*?)@@/) do |var| + if config.key?(Regexp.last_match[1]) + config[Regexp.last_match[1]] + else + var.gsub!(/@@/, '@_NOT_FOUND_@') + end + end + break if @out.nil? + @count += 1 + end + + output.write(line) end end output.close