Security News
Research
Data Theft Repackaged: A Case Study in Malicious Wrapper Packages on npm
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
carl-activerecord-jsonb-associations
Advanced tools
Use PostgreSQL JSONB fields to store association information of your models.
This gem was created as a solution to this task from EvilMartians.
Requirements:
Add to Gemfile
gem 'carl-activerecord-jsonb-associations', require 'activerecord-jsonb-associations'
You can store all foreign keys of your model in one JSONB column, without having to create multiple columns:
class Profile < ActiveRecord::Base
# Setting additional :store option on :belongs_to association
# enables saving of foreign ids in :extra JSONB column
belongs_to :user, store: :extra
end
class SocialProfile < ActiveRecord::Base
belongs_to :user, store: :extra
end
class User < ActiveRecord::Base
# Parent model association needs to specify :foreign_store
# for associations with JSONB storage
has_one :profile, foreign_store: :extra
has_many :social_profiles, foreign_store: :extra
end
Foreign keys for association on one model have to be unique, even if they use different store column.
You can also use add_references
in your migration to add JSONB column and index for it (if index: true
option is set):
add_reference :profiles, :users, store: :extra, index: true
You can also use JSONB columns on 2 sides of a HABTM association. This way you won't have to create a join table.
class Label < ActiveRecord::Base
# extra['user_ids'] will store associated user ids
has_and_belongs_to_many :users, store: :extra
end
class User < ActiveRecord::Base
# extra['label_ids'] will store associated label ids
has_and_belongs_to_many :labels, store: :extra
end
Compared to regular associations, fetching models associated via JSONB column has no drops in performance.
Getting the count of connected records is ~35% faster with associations via JSONB (tested on associations with up to 10 000 connections).
Adding new connections is slightly faster with JSONB, for scopes up to 500 records connected to another record (total count of records in the table does not matter that much. If you have more then ~500 records connected to one record on average, and you want to add new records to the scope, JSONB associations will be slower then traditional:
On the other hand, unassociating models from a big amount of associated models if faster with JSONB HABTM as the associations count grows:
Add this line to your application's Gemfile:
gem 'activerecord-jsonb-associations'
And then execute:
$ bundle install
To setup development environment, just run:
$ bin/setup
To run specs:
$ bundle exec rspec
To run benchmarks (that will take a while):
$ bundle exec rake benchmarks:habtm
The gem is available as open source under the terms of the MIT License.
FAQs
Unknown package
We found that carl-activerecord-jsonb-associations demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Research
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
Research
Security News
Attackers used a malicious npm package typosquatting a popular ESLint plugin to steal sensitive data, execute commands, and exploit developer systems.
Security News
The Ultralytics' PyPI Package was compromised four times in one weekend through GitHub Actions cache poisoning and failure to rotate previously compromised API tokens.