ActiveRecord Accessible Json
Using this gem, ActiveRecord JSON typed attribute is deserialized into HashWithIndifferentAccess if possible.
Example
# Both author and tags are JSON typed columns.
Post.create(author: { 'name': 'yamat47', 'age': 27 }, tags: %w[Rails TDD])
post = Post.last
post.author.class #=> ActiveSupport::HashWithIndifferentAccess
post.author['name'] #=> 'yamat47'
post.author['name'] == post.author[:name] #=> true
post.author = { name: 'Andy', age: 30 }
post.author.class #=> ActiveSupport::HashWithIndifferentAccess
post.author['name'] #=> 'Andy'
post.author['name'] == post.author[:name] #=> true
# If attribute's value is not changeable into HashWithIndifferentAccess,
# this gem does nothing.
post.tags.class #=> Array
Version Compatibility
Rails 6.0 | Rails 6.1 | Rails 7.0 | Rails head | |
---|---|---|---|---|
Ruby 2.7 | ✅ | ✅ | ✅ | ✅ |
Ruby 3.0 | ✅ | ✅ | ✅ | ✅ |
Ruby 3.1 | ❌ | ❌ | ✅ | ✅ |
Ruby 3.2 | ❌ | ❌ | ✅ | ✅ |
Ruby head | ❌ | ❌ | ✅ | ✅ |
Version compatibility is checked everyday on CI.
Installation
Add this line to your Rails application's Gemfile:
gem 'activerecord_accessible_json'
And then execute:
$ bundle
Or install it yourself as:
$ gem install activerecord_accessible_json
Release
- Check if CI is passed on
main
. - Decide next versioning and update version.rb.
-
bundle install
. - Commit these changes with happy message (like "Release v0.2.0 🎉").
-
bundle exec rake build
. -
bundle exec rake release
. - Create new release.
License
The gem is available as open source under the terms of the MIT License.