Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

filterable_model

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

filterable_model

  • 0.1.1
  • Rubygems
  • Socket score

Version published
Maintainers
1
Created
Source

FilterableModel

FilterableModel provides an organized and seamless way to filter your ActiveRecord objects using real and custom attributes.

Installation

Add this line to your application's Gemfile:

gem 'filterable_model', '~> 0.1.0'

And then execute:

$ bundle

Or install it yourself as:

$ gem install filterable_model

Usage

Include FilterableModel inside ApplicationRecord or directly inside your ActiveRecord model:

class User < ApplicationRecord
  include FilterableModel
end

Filtering by real attributes

To filter using the exact values of your ActiveRecord model attributes, override the filterable_attributes class method to return an array of whitelisted attributes:

class User < ApplicationRecord
  include FilterableModel

  concerning :Filtering do
    class_methods do

      def filterable_attributes
        %w[id gender is_subscribed]
      end

    end
  end

end

Filtering by custom attributes

Filtering using custom attributes works by calling the add_filter method and passing a block that accepts the filter-by value, and returns an ActiveRecord::Relation:

class User < ApplicationRecord
  include FilterableModel

  concerning :Filtering do
    included do

      add_filter :name do |name| # search by first name or username
        where("LOWER(users.first_name) LIKE :query OR LOWER(users.username) LIKE :query", query: "%#{name.downcase}%")
      end


      add_filter :just_active do |value| # filter by users with active sessions
        if value.to_s == 'true'
          includes(:session).where(session: { active: true })
        else
          current_scope # do not change the current relation
        end
      end

    end
  end
end

Filter your relation by calling filter on your model and passing the filtering hash:

@users = User.all

filtering_hash = {
  gender: 'male',
  is_subscribed: 'false',
  name: 'John',
  just_active: 'true'
}

@users = @users.filter(filtering_hash)

Passing an unknown filter will raise a FilterNotSupported error.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/umar221b/filterable_model.

License

The gem is available as open source under the terms of the MIT License.

FAQs

Package last updated on 14 Feb 2020

Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc