I\'ve looked at ActiveRecord::DangerousAttributeError and other similar threads on SO, but they don\'t address the same issue.
I\'m following the omniauth tutorial:
I just ran into this following the same RailsCast.
The tutorial says to run:
rails g nifty:scaffold authentication user_id:integer \
provider:string uid:string index create destroy
But not having the nifty scaffold stuff on my machine, I just ran
rails g scaffold authentication user_id:integer \
provider:string uid:string index create destroy
Which behaves differently. Instead of creating stub 'index', 'create', and 'destroy' controller methods, it created fields in the database.
Remove them and it works fine, as mentioned previously.
Try: current_user.authentications.create!
EDIT
So basically your problem was that you had columns in your table named the same as methods of the Modal class.
You can't have a column named create or destroy in your database.
Most likely it was a typo on your model/controller generation.
Activerecord is warning you that some of your database attribute names (create etc.) clash with the names of instance methods provided by activerecord/ruby.
Since rails would otherwise create instance methods of those names to access attributes, such a clash used to cause really weird things to happen. Thus active record raises an exception to warn you that this is happening
So just to finish the question off you will need to create a migration using this command:
rails g migration remove_silly_authentication_fields_which_should_not_be_there
Which looks something like this:
class DropSillyControllerAttributes < ActiveRecord::Migration
def change
remove_column :authentications, :index
remove_column :authentications, :create
remove_column :authentications, :destroy
end
end
And run it using the usual:
rake db:migration
Or alternatively you should be able to run:
rake db:rollback
To roll back the changes just made to the database and:
rails d scaffold authentication
To remove all the files, then run:
rails g scaffold authentication user_id:integer provider:string uid:string
And do the other stuff manually
I did exactly the same thing myself by the way.