Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/stas/active_record-pgcrypto
PostgreSQL PGCrypto support for ActiveRecord
https://github.com/stas/active_record-pgcrypto
activerecord encryption pgcrypto postgresql rails ruby
Last synced: about 1 month ago
JSON representation
PostgreSQL PGCrypto support for ActiveRecord
- Host: GitHub
- URL: https://github.com/stas/active_record-pgcrypto
- Owner: stas
- License: mit
- Created: 2019-06-06T12:43:38.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-10-08T21:24:01.000Z (over 1 year ago)
- Last Synced: 2024-11-28T18:11:03.121Z (about 1 month ago)
- Topics: activerecord, encryption, pgcrypto, postgresql, rails, ruby
- Language: Ruby
- Homepage:
- Size: 50.8 KB
- Stars: 22
- Watchers: 4
- Forks: 7
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# PGCrypto for ActiveRecord 🆊
[PostgreSQL PGCrypto](https://www.postgresql.org/docs/current/pgcrypto.html)
support for ActiveRecord models.![Don't roll your own crypto](https://imgs.xkcd.com/comics/cryptography.png)
## About
The goal of this project is to provide a simple and efficient encryption
support for your application records.Main goals:
* No _magic_ please
* No DSLs please
* Less code, less maintenance
* Good docs and test coverage
* Keep it up-to-date (or at least tell people this is no longer maintained)The available features include:
* PostgreSQL `pgcrypto` native symmetric encryption using the
[attribute serialization](https://api.rubyonrails.org/classes/ActiveRecord/AttributeMethods/Serialization/ClassMethods.html#method-i-serialize) API and Arel API.
* Logger support for sensitive data query obfuscation.### A bit of history...
The project was born after trying out `crypt_keeper` and having to deal with
the broken support for PostgreSQL where the stored data would be invalid for
native SQL functions.I would like to thank Justin for his work, but I decided to move away from the
original work for arguably subjective reasons and the critical importance of
this functionality in my projects.## Installation
Add this line to your application's Gemfile:
```ruby
gem 'active_record-pgcrypto'
```And then execute:
```ruby
$ bundle
```Or install it yourself as:
```ruby
$ gem install active_record-pgcrypto
```## Usage
To start using it with ActiveRecord/Rails, add this to an initializer and
configure your keys:
```ruby
# config/initializers/pgcrypto.rb
require 'active_record/pgcrypto'
# Replace the default environment variable name with your own value/key.
ActiveRecord::PGCrypto::SymmetricCoder.pgcrypto_key = ENV['PGCRYPTO_SYM_KEY']
```Now enable the coder for your model attributes:
```ruby
class MyModel < ActiveRecord::Base
serialize(:email, ActiveRecord::PGCrypto::SymmetricCoder)
end
```NOTE: In order for the encrypted data to be store the column must be of type `binary`.
The coder provides a simple API to help you provide search support by
leveraging the Arel API:```ruby
class MyModel < ActiveRecord::Base
serialize(:email, ActiveRecord::PGCrypto::SymmetricCoder)def self.decrypted_email
ActiveRecord::PGCrypto::SymmetricCoder
.decrypted_arel_text(arel_table[:email])
end
end
```Now you can use add it to your `ActiveRecord::Base#where` queries:
```ruby
MyModel.where(MyModel.decrypted_email.matches('keyword%'))
```## Development
Build the Docker image first:
```
docker build -f Dockerfile -t active_record-pgcrypto/ci ./`
```Now you can run the tests:
```
docker run -v `pwd`:/gem -it active_record-pgcrypto/ci
```## Contributing
Bug reports and pull requests are welcome on GitHub at
https://github.com/stas/active_record-pgcrypto. This project is intended to be
a safe, welcoming space for collaboration, and contributors are expected to
adhere to the [Contributor Covenant](http://contributor-covenant.org) code of
conduct.## License
The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).
## Code of Conduct
Everyone interacting with this project codebase, issue
tracker, chat rooms and mailing list is expected to follow the [code of
conduct](https://github.com/[USERNAME]/active_record-pgcrypto/blob/master/CODE_OF_CONDUCT.md).