Skip to content

Latest commit

 

History

History
69 lines (52 loc) · 1.93 KB

README.md

File metadata and controls

69 lines (52 loc) · 1.93 KB

DRE

A Device Registration Engine for Rails.

Adds a Device model for your Rails app, as well as a set of routes to register and deregister devices by supplying a token.

Installation

Add the gem into your project:

gem 'dre'
bundle install

Then run the installation:

rails g dre:install
rake db:migrate

Usage

Add the acts_as_device_owner method into your user model:

class User < ActiveRecord::Base
  acts_as_device_owner
end

Mount the engine in your routes.rb file:

Rails.application.routes.draw do
  mount_dre
end

This will add three routes into your application:

Route Description
GET /devices Get all of the devices for the current user
PUT /devices/:token Register a new device if it doesn't exist
DELETE /devices/:token Deregister the device belonging to the supplied token

The routes for Dre can be customised to point to a custom controller:

Rails.application.routes.draw do
  mount_dre do
    controllers devices: 'custom_devices'
  end
end

And this will point the routes to the custom_devices controller, as opposed to the dre/devices controller baked into the engine.

Configuration

Dre.setup do |config|
  # Dre will call this within DevicesController to ensure the user is authenticated.
  config.authentication_method = :authenticate_user!

  # Dre will call this within DevicesController to return the current logged in user.
  config.current_user_method = :current_user
end

The default configuration integrates with Devise, but if you have other methods of authentication and retrieving the currently authenticated user, you can specify them here and the DevicesController will use those in the before filter.