README.md in sequel-devise-0.0.7 vs README.md in sequel-devise-0.0.8
- old
+ new
@@ -24,17 +24,52 @@
end
If you're interested in more instructions on using Sequel with Rails,
I've written [some instructions](http://rosenfeld.herokuapp.com/en/articles/2012-04-18-getting-started-with-sequel-in-rails) in my web site.
+## Important Note
+
+Unfortunately Devise does not rely on the `orm_adapter` specs as
+[it was supposed to](https://github.com/plataformatec/devise/blob/master/devise.gemspec#L22).
+
+It will assume the model support other methods besides those defined by `orm_adapter` and that they
+behave like the equivalent in ActiveRecord supporting the same arguments.
+
+In some cases, it will call some method which is not defined by `Sequel::Model`, so we implement
+them in this gem, but there are some cases which are trickier. For example, Devise will call the
+`save` method in the model and expect it to return false if the validation fails. This is not the
+default behavior of Sequel::Model, so you'll have to change this behavior for your User classes
+that are intended to be used by Devise. There are a few solutions depending on your use case:
+
+### You expect your Sequel Models to not raise on save failure by default
+
+Just disable the raise behavior by default:
+
+ Sequel::Model.raise_on_save_failure = false
+
+### You are okay with changing the raise behavior only for your user classes
+
+ class User < Sequel::Model
+ self.raise_on_save_failure = false
+ plugin :devise
+ devise :database_authenticatable
+ end
+
+### You don't want to touch your user model just to accomodate Devise
+
+You are free to simply create another user class that is meant to be used by Devise while the
+remaining of your application just use your regular user class:
+
+ class DeviseUser < User
+ self.raise_on_save_failure = false
+ plugin :devise
+ devise :database_authenticatable
+ end
+
## Contributing
1. Fork it
2. Create your feature branch (`git checkout -b my-new-feature`)
3. Commit your changes (`git commit -am 'Added some feature'`)
4. Push to the branch (`git push origin my-new-feature`)
5. Create new Pull Request
-
-
-
-[![Bitdeli Badge](https://d2weczhvl823v0.cloudfront.net/rosenfeld/sequel-devise/trend.png)](https://bitdeli.com/free "Bitdeli Badge")