|
|
|
|
@ -1,6 +1,21 @@
|
|
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
|
|
if ENV['RAILS_ENV'] == 'production' && ENV['SECRET_KEY_BASE'].to_s.empty?
|
|
|
|
|
if ENV['RAILS_ENV'] == 'production'
|
|
|
|
|
if !ENV['AWS_SECRET_MANAGER_ID'].to_s.empty?
|
|
|
|
|
require 'aws-sdk-secretsmanager'
|
|
|
|
|
|
|
|
|
|
client = Aws::SecretsManager::Client.new
|
|
|
|
|
|
|
|
|
|
secret_id = ENV.fetch('AWS_SECRET_MANAGER_ID', '')
|
|
|
|
|
|
|
|
|
|
client.get_secret_value(secret_id:).secret_string.split("\n").each do |line|
|
|
|
|
|
key, value = line.split('=', 2)
|
|
|
|
|
|
|
|
|
|
ENV[key] = value if !key.to_s.empty? && !value.to_s.empty?
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
RubyVM::YJIT.enable if ENV['RUBY_YJIT_ENABLE'] == 'true'
|
|
|
|
|
elsif ENV['SECRET_KEY_BASE'].to_s.empty?
|
|
|
|
|
require 'dotenv'
|
|
|
|
|
require 'securerandom'
|
|
|
|
|
|
|
|
|
|
@ -20,6 +35,7 @@ if ENV['RAILS_ENV'] == 'production' && ENV['SECRET_KEY_BASE'].to_s.empty?
|
|
|
|
|
Dotenv.load(dotenv_path)
|
|
|
|
|
|
|
|
|
|
ENV['DATABASE_URL'] = ENV['DATABASE_URL'].to_s.empty? ? database_url : ENV.fetch('DATABASE_URL', nil)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
if ENV['DATABASE_URL'].to_s.split('@').last.to_s.split('/').first.to_s.include?('_')
|
|
|
|
|
|