0.0
No commit activity in last 3 years
No release in over 3 years
If you have a model (User, Account, etc..) and you only want invited people to be allowed creating those resource. Good example is while in beta, invite only account creation.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

>= 3.2
 Project Readme

Invite Only

Build Status

This gem was inspired by acts_as_tenant. I really liked the fail-safe and out-of-the-way manner of acts_as_tenant! Hence, this is a very low level abstraction layer to help deal with invites to your applications and integrates (near) seamless with Rails.

In addition, invite_only:

  • auto validates on create for any model that you want invite only for.
  • sets up a helper method to allow you to create invite codes.

Installation

invite_only is tested for Rails 3.2 and up.

To use it, add it to your Gemfile:

gem 'invite_only'
bundle install

Run the generator to create the migration

rails g inviter

Getting started

There are three steps to get your app going with invite_only:

  1. enable_invite_only on your controller.
  2. call invite_only on the model you want protected.
  3. add virtual attribute :invite_code

Calling enable_invite_only on your controller

Add the enable_invite_only to a controller to get the helper method you need to generate a code.

  class ApplicationController < ActionController::Base
    enable_invite_only
  end

Now you will have a helper method called 'create_invite_code_for(identifier)'. The identifier is the string you use to uniquely identify the model. For example a User.email or User.username. Any string you want to id with. For example..

  code = create_invite_code_for('foo@bar.com')

Calling invite_only on your model

  class User < ActiveRecord::Base
    invite_only(:email)
  end

'invite_only(identifier=:email)' used in the model. Here identifier is the column the model uses as the identifier. invite_only defaults to :email, but in case you want to use for example :username or anything you like you can. This is used during the validation as the attribute to use for look up.

Adding virtual attribute :invite_only

  class User < ActiveRecord::Base
    invite_only(:email)
    attr_accessor :invite_code
  end

Thats it! Now whenever you try to save an invite_only model, it will not work unless you have the correct :invite_code. How you pass the value to the model is up to you. Simply just add the text field for the code in the form_for the model you are interested in.

To disable all this, simple remove the 'invite_only' call from the model.

Configuration options

You can control the different types of validation messages you can display. The attributes you have to create readers for are the following below.

attr_writer :code_blank_message,
            :code_invalid_message,
            :code_identifier_invalid_message,
            :code_already_used_message

The default validation error messages you get out of the box are.

attribute name Default
:code_blank_message "is missing."
:code_invalid_message "does not work with that #{identifier.to_s}."
:code_identifier_invalid_message "is not valid."
:code_already_used_message "has already been used."

An example of setting your own error message is below

  class User < ActiveRecord::Base
    invite_only(:email)

    protected
    def code_blank_message
      'code is blank'
    end
  end

To Do

  • Add support for mongodb

Bug reports & suggested improvements

If you have found a bug or want to suggest an improvement, please use our issue tracked at:

github.com/mez/invite_only/issues

If you want to contribute, fork the project, code your improvements and make a pull request on Github. When doing so, please don't forget to add tests. If your contribution is fixing a bug it would be perfect if you could also submit a failing test, illustrating the issue.

License

Copyright (c) 2014 Mez Gebre, released under the MIT license