class ActiveRecord::Generators::DeviseGenerator

def copy_devise_migration

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

def generate_model

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

def inject_devise_content

def inject_devise_content
  content = model_contents + <<CONTENT
tup accessible (or protected) attributes for your model
_accessible :email, :password, :password_confirmation, :remember_me
T
  class_path = if namespaced?
    class_name.to_s.split("::")
  else
    [class_name]
  end
  indent_depth = class_path.size - 1
  content = content.split("\n").map { |line| "  " * indent_depth + line } .join("\n") << "\n"
  inject_into_class(model_path, class_path.last, content) if model_exists?
end

def migration_data

def migration_data

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