Class: ActiveRecord::Generators::DeviseGenerator

Inherits:
Base
  • Object
show all
Includes:
Devise::Generators::OrmHelpers
Defined in:
lib/generators/active_record/devise_generator.rb

Instance Method Summary collapse

Methods included from Devise::Generators::OrmHelpers

#migration_exists?, #migration_path, #model_contents, #model_exists?, #model_path

Instance Method Details

#copy_devise_migrationObject



12
13
14
15
16
17
18
# File 'lib/generators/active_record/devise_generator.rb', line 12

def copy_devise_migration
  if (behavior == :invoke && model_exists?) || (behavior == :revoke && migration_exists?(table_name))
    migration_template "migration_existing.rb", "db/migrate/add_devise_to_#{table_name}"
  else
    migration_template "migration.rb", "db/migrate/devise_create_#{table_name}"
  end
end

#generate_modelObject



20
21
22
# File 'lib/generators/active_record/devise_generator.rb', line 20

def generate_model
  invoke "active_record:model", [name], :migration => false unless model_exists? && behavior == :invoke
end

#inject_devise_contentObject



24
25
26
27
28
29
# File 'lib/generators/active_record/devise_generator.rb', line 24

def inject_devise_content
  inject_into_class(model_path, class_name, model_contents + <<CONTENT) if model_exists?
  # Setup accessible (or protected) attributes for your model
  attr_accessible :email, :password, :password_confirmation, :remember_me
CONTENT
end

#migration_dataObject



31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
# File 'lib/generators/active_record/devise_generator.rb', line 31

def migration_data
<<RUBY
## 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

## Encryptable
# t.string :password_salt

## 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
RUBY
end