mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
Do not add master key when RAILS_MASTER_KEY
env specified (#31922)
Fixes #31917
This commit is contained in:
parent
cc523fba9b
commit
5d75ef72e6
4 changed files with 27 additions and 2 deletions
|
@ -20,7 +20,7 @@ module Rails
|
|||
require_application_and_environment!
|
||||
|
||||
ensure_editor_available(command: "bin/rails credentials:edit") || (return)
|
||||
ensure_master_key_has_been_added
|
||||
ensure_master_key_has_been_added if Rails.application.credentials.key.nil?
|
||||
ensure_credentials_have_been_added
|
||||
|
||||
catch_editing_exceptions do
|
||||
|
|
|
@ -21,9 +21,10 @@ module Rails
|
|||
|
||||
def edit(file_path)
|
||||
require_application_and_environment!
|
||||
encrypted = Rails.application.encrypted(file_path, key_path: options[:key])
|
||||
|
||||
ensure_editor_available(command: "bin/rails encrypted:edit") || (return)
|
||||
ensure_encryption_key_has_been_added(options[:key])
|
||||
ensure_encryption_key_has_been_added(options[:key]) if encrypted.key.nil?
|
||||
ensure_encrypted_file_has_been_added(file_path, options[:key])
|
||||
|
||||
catch_editing_exceptions do
|
||||
|
|
|
@ -43,6 +43,18 @@ class Rails::Command::CredentialsCommandTest < ActiveSupport::TestCase
|
|||
assert_match(/api_key: abc/, run_show_command)
|
||||
end
|
||||
|
||||
test "edit command does not add master key when `RAILS_MASTER_KEY` env specified" do
|
||||
Dir.chdir(app_path) do
|
||||
key = IO.binread("config/master.key").strip
|
||||
FileUtils.rm("config/master.key")
|
||||
|
||||
switch_env("RAILS_MASTER_KEY", key) do
|
||||
run_edit_command
|
||||
assert_not File.exist?("config/master.key")
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
test "show credentials" do
|
||||
assert_match(/access_key_id: 123/, run_show_command)
|
||||
end
|
||||
|
|
|
@ -33,6 +33,18 @@ class Rails::Command::EncryptedCommandTest < ActiveSupport::TestCase
|
|||
end
|
||||
end
|
||||
|
||||
test "edit command does not add master key when `RAILS_MASTER_KEY` env specified" do
|
||||
Dir.chdir(app_path) do
|
||||
key = IO.binread("config/master.key").strip
|
||||
FileUtils.rm("config/master.key")
|
||||
|
||||
switch_env("RAILS_MASTER_KEY", key) do
|
||||
run_edit_command("config/tokens.yml.enc")
|
||||
assert_not File.exist?("config/master.key")
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
test "edit encrypts file with custom key" do
|
||||
run_edit_command("config/tokens.yml.enc", key: "config/tokens.key")
|
||||
|
||||
|
|
Loading…
Reference in a new issue