0.0
No release in over 3 years
Low commit activity in last 3 years
Specify features for your subscription plans and check that the user has access to those
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

~> 6.0.0
 Project Readme

PayFeatures

PayFeatures is a gem to add plan features to your subscription plan. Let's say a user is subscribed to the Simple plan, which allows for 2 team_members. You can easily set up features and checks to use in your app and to display on your pricing page.

Installation

Add this line to your application's Gemfile:

gem 'pay_features'

And then execute:

$ bundle

Or install it yourself as:

$ gem install pay_features

Migrations

Install migrations by running

rails pay_features:install:migrations

That will add two new tables as well as add previous_plan_id to your existing plans table.

Usage

Per default we rely on an existing plans table to be present. This is only needed if you want the feature inheritance between plans.

In your existing plan model, add the following:

class Plan < ActiveModel
  include PayFeatures::Plan
end

You can then set up features and your plans like this:

first_plan = Plan.create(name: "First plan")
second_plan = Plan.create(name: "Second plan", previous_plan: first_plan)

first_plan.features.create(identifier: "users", amount: 2)
first_plan.features.create(identifier: "can_create_teams", description: "Can create teams")
second_plan.features.create(identifier: "users", amount: 10)
second_plan.features.create(identifier: "api_access", description: "Use the API")

You can perform simple checks like this:

first_plan.has_feature?(:users)
# => true

first_plan.amount_for(:users)
# => 2

# Features are inherited when previous_plan is set
second_plan.has_feature?(:can_create_teams)
# => true

first_plan.has_feature?(:api_access)
# => false

second_plan.has_feature?(:api_access)
# => true

If you want to display the features on your pricing page, you can access plan.display_features which will give you an array similar to this:

{
  identifier: "users",
  description: "2 users",
  amount: 2,
}

If a feature exists on the previous plan, and you add it to the plan after similar to this:

first_plan = Plan.create(name: "First plan")
second_plan = Plan.create(name: "Second plan", previous_plan: first_plan)

first_plan.features.create(identifier: "users", amount: 2, description: "2 users")
second_plan.features.create(identifier: "users", amount: 10, description: "10 users")
second_plan.features.create(identifier: "api_access", description: "API Access")

If you call second_plan.display_features you'll see the users feature marked as a new feature. This is so you can highlight differences in your pricing table.

[
  {
    identifier: "users",
    description: "10 users",
    amount: 10,
    new_feature: true,
  },
  {
    identifier: "api_access",
    description: "API Access",
    amount: nil,
    new_feature: true,
  },
]

Contributing

Open up Issue/PR if you encounter any problems or have ideas.

License

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