Skip to content

Instantly share code, notes, and snippets.

@zhuochun
Created July 25, 2013 17:42
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save zhuochun/6082056 to your computer and use it in GitHub Desktop.
Save zhuochun/6082056 to your computer and use it in GitHub Desktop.
class DeviseCreateUsers < ActiveRecord::Migration
def change
create_table :users do |t|
t.timestamps
## Database authenticatable
t.string :email, :null => false, :default => ""
t.string :encrypted_password, :null => false, :default => ""
## Recoverable
t.string :reset_password_token
t.datetime :reset_password_sent_at
## Rememberable
t.datetime :remember_created_at
## Trackable
t.integer :sign_in_count, :default => 0
t.datetime :current_sign_in_at
t.datetime :last_sign_in_at
t.string :current_sign_in_ip
t.string :last_sign_in_ip
## Confirmable
# t.string :confirmation_token
# t.datetime :confirmed_at
# t.datetime :confirmation_sent_at
# t.string :unconfirmed_email # Only if using reconfirmable
## Lockable
# t.integer :failed_attempts, :default => 0 # Only if lock strategy is :failed_attempts
# t.string :unlock_token # Only if unlock strategy is :email or :both
# t.datetime :locked_at
## Token authenticatable
t.string :authentication_token
end
add_index :users, :email, :unique => true
add_index :users, :reset_password_token, :unique => true
# add_index :users, :confirmation_token, :unique => true
# add_index :users, :unlock_token, :unique => true
add_index :users, :authentication_token, :unique => true
end
end
devise_for :users, controllers: { sessions: "sessions" }
class SessionsController < Devise::SessionsController
respond_to :json, :html
def destroy
current_user.authentication_token = nil
super
end
protected
def verified_request?
request.content_type == "application/json" || super
end
end
#login
curl -v -H "Accept: application/json" -H "Content-type: application/json" -X POST -d ' {"user":{"email":"<email>","password":"<passwd>"}}' http://localhost:3000/users/sign_in.json
#request a resource
curl -v -H "Accept: application/json" -H "Content-type: application/json" http://localhost:3000/api/v1/firms.json?auth_token=<token>
#logout
curl -v -H "Accept: application/json" -H "Content-type: application/json" -X DELETE http://localhost:3000/users/sign_out.json?auth_token=<token>
class User < ActiveRecord::Base
before_save :ensure_authentication_token
devise :database_authenticatable, :registerable,
:recoverable, :rememberable, :trackable, :validatable,
:token_authenticatable
end
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment