RailsKeyRotator
Warning THIS IS BETA SOFTWARE
Major version zero (0.y.z) is for initial development. Anything MAY change at any time. The public API SHOULD NOT be considered stable. See: https://semver.org/#spec-item-4
Installation
Install the gem and add to the application's Gemfile by executing:
$ bundle add rails_key_rotator
If bundler is not being used to manage dependencies, install the gem by executing:
$ gem install rails_key_rotator
NOTE If you're using
dotenv-rails
make sure it is loaded beforerails_key_rotator
e.g:gem "dotenv-rails" gem "rails_key_rotator"
Usage
Warning DON'T FORGET TO HANDOUT THE NEW KEY TO YOUR COLLEAGUES!
-
Run the rake taks
$ RAILS_ENV=production bundle exec rake key_rotator:rotate Starting process: -> Copy config/credentials/production.key -> config/credentials/production.key.bak-2023-10-15-084335 -> Copy config/credentials/production.yml.enc -> config/credentials/production.yml.enc.bak-2023-10-15-084335 -> Writing the key "774ef137809953c633f03233d3ec5d35" to config/credentials/production.key -> Writing the re-encrypted credentials to config/credentials/production.yml.enc Finished! The next steps are: - Deploy `RAILS_MASTER_KEY_NEW=774ef137809953c633f03233d3ec5d35` to your infrastructure - Share the new key w/ your colleagues - Commit changes in config/credentials/production.yml.enc - Update `RAILS_MASTER_KEY`and remove `RAILS_MASTER_KEY_NEW` from your infrastructure
This will backup current key / credentials, create a new key and saves encrypts the credentails w/ this new key for the current
RAILS_ENV
-
Deploying this variable as an env
RAILS_MASTER_KEY_NEW
-
Commit and deploy new encrypted file.
-
After a while when everything is back in sync replace
RAILS_MASTER_KEY
w/ the new key and deleteRAILS_MASTER_KEY_NEW
Process
When we've defined RAILS_MASTER_KEY_NEW
it means we are rotating the encryption key for our credentials. What we want to do then is:
-
Check if we can decrypt the current credentials file with the new key
-
If we can, we will change
RAILS_MASTER_KEY
to equalRAILS_MASTER_KEY_NEW
-
If not, we will fallback to the old key, thus leave
RAILS_MASTER_KEY
alone
Development
This project uses docker and dip, a.k.a. the Docker Interaction Program.
To use it:
gem install dip
dip provision
dip guard # run specs
To install this gem onto your local machine, run bundle exec rake install
. To release a new version, update the version number in version.rb
, and then run dip bundle exec rake release
, which will create a git tag for the version, push git commits and the created tag, and push the .gem
file to rubygems.org.
Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/LeipeLeon/rails_key_rotator. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the code of conduct.
License
The gem is available as open source under the terms of the MIT License.
Code of Conduct
Everyone interacting in the RailsKeyRotator project's codebases, issue trackers, chat rooms and mailing lists is expected to follow the code of conduct.
Thanks to:
- The fine folks of kerkdienstgemist.nl allowed me to extract the basics from their sourcecode.
- The original inspirator after some googling: https://www.reddit.com/r/rails/comments/x4sujc/deploying_a_rotated_credentials_key_without/