README.md in omniauth-identity-3.0.2 vs README.md in omniauth-identity-3.0.3
- old
+ new
@@ -1,7 +1,9 @@
# OmniAuth Identity
+[data:image/s3,"s3://crabby-images/0b352/0b352719b4df4a649a50631312b405012f7339ff" alt="Version"](https://rubygems.org/gems/omniauth-identity)
+[data:image/s3,"s3://crabby-images/d13a8/d13a8e068f1ec40f4032f20aed6e39cb11252e50" alt="Depfu"](https://depfu.com/github/omniauth/omniauth-identity?project_id=22381)
[data:image/s3,"s3://crabby-images/e0079/e00794ca68932909fdbaf2e078da652e7514c4fa" alt="Build Status"](https://actions-badge.atrox.dev/omniauth/omniauth-identity/goto)
[data:image/s3,"s3://crabby-images/bfc13/bfc13d786341fb4f54a4659cfc1d506a3cd9d2c1" alt="Maintainability"](https://codeclimate.com/github/omniauth/omniauth-identity/maintainability)
[data:image/s3,"s3://crabby-images/7b7b2/7b7b262a388d1a76c383e5a0e1927d7aa44d7704" alt="Test Coverage"](https://codeclimate.com/github/omniauth/omniauth-identity/test_coverage)
[data:image/s3,"s3://crabby-images/8fe25/8fe252f76dc2a000f81c31eb23c03acd6799638b" alt="License: MIT"](https://opensource.org/licenses/MIT)
[data:image/s3,"s3://crabby-images/e0c5a/e0c5af3cb7ea5bb54342500318f3de829f17b109" alt="Open Source Helpers"](https://www.codetriage.com/omniauth/omniauth-identity)
@@ -15,11 +17,11 @@
## Compatibility
This gem is compatible with, as of Feb 2021, version 3:
-* Latest released version of omniauth, v2.0.2
+* Latest released version of omniauth, v2.0.2
* Ruby 2.4, 2.5, 2.6, 2.7, 3.0, ruby-head
## Installation
To acquire the latest release from RubyGems add the following to your `Gemfile`:
@@ -54,10 +56,17 @@
Next, you need to create a model (called `Identity` by default, or specified
with `:model` argument above) that will be able to persist the information
provided by the user. Luckily for you, there are pre-built models for popular
ORMs that make this dead simple.
+Once you've got an `Identity` persistence model and the strategy up and
+running, you can point users to `/auth/identity` and it will request
+that they log in or give them the opportunity to sign up for an account.
+Once they have authenticated with their identity, OmniAuth will call
+through to `/auth/identity/callback` with the same kinds of information
+it would had the user authenticated through an external provider.
+
**Note:** OmniAuth Identity is different from many other user authentication
systems in that it is *not* built to store authentication information in your primary
`User` model. Instead, the `Identity` model should be **associated** with your
`User` model giving you maximum flexibility to include other authentication
strategies such as Facebook, Twitter, etc.
@@ -90,37 +99,10 @@
field :name, type: String
field :password_digest, type: String
end
```
-### MongoMapper
-
-Unfortunately MongoMapper is **not supported** in `omniauth-identity` from >= v2.0 as a result of it
-not being maintained for several years.
-
-It wasn't possible to include Mongoid *and* MongoMapper due to incompatible gem version
-requirements. Therefore precedence was given to Mongoid as it is significantly more
-popular and actively maintained.
-
-### DataMapper
-
-Include the `OmniAuth::Identity::Models::DataMapper` mixin and specify
-fields that you will need.
-
-```ruby
-class Identity
- include DataMapper::Resource
- include OmniAuth::Identity::Models::DataMapper
-
- property :id, Serial
- property :email, String
- property :password_digest, Text
-
- attr_accessor :password_confirmation
-end
-```
-
### CouchPotato
Include the `OmniAuth::Identity::Models::CouchPotatoModule` mixin and specify fields that you will need.
```ruby
@@ -137,16 +119,27 @@
view :by_email, key: :email
end
```
-Once you've got an `Identity` persistence model and the strategy up and
-running, you can point users to `/auth/identity` and it will request
-that they log in or give them the opportunity to sign up for an account.
-Once they have authenticated with their identity, OmniAuth will call
-through to `/auth/identity/callback` with the same kinds of information
-it would had the user authenticated through an external provider.
-Simple!
+### NoBrainer
+
+[NoBrainer](http://nobrainer.io/) is an ORM for [RethinkDB](https://rethinkdb.com/).
+
+Include the `OmniAuth::Identity::Models::NoBrainer` mixin and specify fields that you will need.
+
+```ruby
+class Identity
+ include NoBrainer::Document
+ include OmniAuth::Identity::Models::NoBrainer
+
+ auth_key :email
+end
+```
+
+### Ruby Object Mapper
+
+Would love to add a mixin for the [Ruby Object Mapper (ROM)](https://rom-rb.org/) if anyone wants to work on it!
## Custom Auth Model
To use a class other than the default, specify the <tt>:model</tt> option to a
different class.