PHPackages                             adamwathan/eloquent-oauth - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Authentication &amp; Authorization](/categories/authentication)
4. /
5. adamwathan/eloquent-oauth

AbandonedLibrary[Authentication &amp; Authorization](/categories/authentication)

adamwathan/eloquent-oauth
=========================

Stupid simple OAuth authentication with Laravel and Eloquent

v8.1.0(10y ago)36759.4k44[8 issues](https://github.com/adamwathan/eloquent-oauth/issues)3MITPHPPHP &gt;=5.5.0CI failing

Since Dec 20Pushed 6y ago23 watchersCompare

[ Source](https://github.com/adamwathan/eloquent-oauth)[ Packagist](https://packagist.org/packages/adamwathan/eloquent-oauth)[ RSS](/packages/adamwathan-eloquent-oauth/feed)WikiDiscussions master Synced 1mo ago

READMEChangelog (10)Dependencies (15)Versions (22)Used By (3)

> **Important: This package is not actively maintained.** For bug fixes and new features, please fork.

Eloquent OAuth
==============

[](#eloquent-oauth)

[![This Project Has Been Deprecated.](https://camo.githubusercontent.com/3ae650fc7228648d06b62681ce7c397abe96e1677840b72cc69c336a0de863c6/687474703a2f2f7777772e7265706f7374617475732e6f72672f6261646765732f302e312e302f6162616e646f6e65642e737667)](http://www.repostatus.org/#abandoned)[![Code Climate](https://camo.githubusercontent.com/e941c25f94e8bad1bf7fa685f0b7b8bf0f34e1a3eb0008f0aa3e6c88d34db987/68747470733a2f2f636f6465636c696d6174652e636f6d2f6769746875622f6164616d77617468616e2f656c6f7175656e742d6f617574682f6261646765732f6770612e737667)](https://codeclimate.com/github/adamwathan/eloquent-oauth)[![Scrutinizer Code Quality](https://camo.githubusercontent.com/14c8466d97a1039eede5533d640c07aabb84640b3ab1df86d62426d65775c9c2/68747470733a2f2f7363727574696e697a65722d63692e636f6d2f672f6164616d77617468616e2f656c6f7175656e742d6f617574682f6261646765732f7175616c6974792d73636f72652e706e673f623d6d6173746572)](https://scrutinizer-ci.com/g/adamwathan/eloquent-oauth/?branch=master)[![Build Status](https://camo.githubusercontent.com/5fd421e9bdcde2ad501881b754d9b4c8c2da52617740067d43532dc96227f142/68747470733a2f2f6170692e7472617669732d63692e6f72672f6164616d77617468616e2f656c6f7175656e742d6f617574682e737667)](https://travis-ci.org/adamwathan/eloquent-oauth)

> - Use the [Laravel 4 wrapper](https://github.com/adamwathan/eloquent-oauth-l4) for easy integration with Laravel 4.
> - Use the [Laravel 5 wrapper](https://github.com/adamwathan/eloquent-oauth-l5) for easy integration with Laravel 5.

Eloquent OAuth is a package for Laravel designed to make authentication against various OAuth providers *ridiculously* brain-dead simple. Specify your client IDs and secrets in a config file, run a migration and after that it's just two method calls and you have OAuth integration.

#### Video Walkthrough

[](#video-walkthrough)

[![Screenshot](https://cloud.githubusercontent.com/assets/4323180/6274884/ac824c48-b848-11e4-8e4d-531e15f76bc0.png)](https://vimeo.com/120085196)

#### Basic example

[](#basic-example)

```
// Redirect to Facebook for authorization
Route::get('facebook/authorize', function() {
    return OAuth::authorize('facebook');
});

// Facebook redirects here after authorization
Route::get('facebook/login', function() {

    // Automatically log in existing users
    // or create a new user if necessary.
    OAuth::login('facebook');

    // Current user is now available via Auth facade
    $user = Auth::user();

    return Redirect::intended();
});
```

#### Supported Providers

[](#supported-providers)

- Facebook
- GitHub
- Google
- LinkedIn
- Instagram
- SoundCloud

> Feel free to open an issue if you would like support for a particular provider, or even better, submit a pull request.

Installation
------------

[](#installation)

Check the appropriate wrapper package for installation instructions for your version of Laravel.

- [Laravel 4 wrapper](https://github.com/adamwathan/eloquent-oauth-l4)
- [Laravel 5 wrapper](https://github.com/adamwathan/eloquent-oauth-l5)

Usage
-----

[](#usage)

Authentication against an OAuth provider is a multi-step process, but I have tried to simplify it as much as possible.

### Authorizing with the provider

[](#authorizing-with-the-provider)

First you will need to define the authorization route. This is the route that your "Login" button will point to, and this route redirects the user to the provider's domain to authorize your app. After authorization, the provider will redirect the user back to your second route, which handles the rest of the authentication process.

To authorize the user, simply return the `OAuth::authorize()` method directly from the route.

```
Route::get('facebook/authorize', function() {
    return OAuth::authorize('facebook');
});
```

### Authenticating within your app

[](#authenticating-within-your-app)

Next you need to define a route for authenticating against your app with the details returned by the provider.

For basic cases, you can simply call `OAuth::login()` with the provider name you are authenticating with. If the user rejected your application, this method will throw an `ApplicationRejectedException` which you can catch and handle as necessary.

The `login` method will create a new user if necessary, or update an existing user if they have already used your application before.

Once the `login` method succeeds, the user will be authenticated and available via `Auth::user()` just like if they had logged in through your application normally.

```
use SocialNorm\Exceptions\ApplicationRejectedException;
use SocialNorm\Exceptions\InvalidAuthorizationCodeException;

Route::get('facebook/login', function() {
    try {
        OAuth::login('facebook');
    } catch (ApplicationRejectedException $e) {
        // User rejected application
    } catch (InvalidAuthorizationCodeException $e) {
        // Authorization was attempted with invalid
        // code,likely forgery attempt
    }

    // Current user is now available via Auth facade
    $user = Auth::user();

    return Redirect::intended();
});
```

If you need to do anything with the newly created user, you can pass an optional closure as the second argument to the `login` method. This closure will receive the `$user` instance and a `SocialNorm\User`object that contains basic information from the OAuth provider, including:

- `id`
- `nickname`
- `full_name`
- `avatar`
- `email`
- `access_token`

```
OAuth::login('facebook', function($user, $details) {
    $user->nickname = $details->nickname;
    $user->name = $details->full_name;
    $user->profile_image = $details->avatar;
    $user->save();
});
```

> Note: The Instagram and Soundcloud APIs do not allow you to retrieve the user's email address, so unfortunately that field will always be `null` for those provider.

### Advanced: Storing additional data

[](#advanced-storing-additional-data)

Remember: One of the goals of the Eloquent OAuth package is to normalize the data received across all supported providers, so that you can count on those specific data items (explained above) being available in the `$details` object.

But, each provider offers its own sets of additional data. If you need to access or store additional data beyond the basics of what Eloquent OAuth's default `ProviderUserDetails` object supplies, you need to do two things:

1. Request it from the provider, by extending its scope:

    Say for example we want to collect the user's gender when they login using Facebook.

    In the `config/eloquent-oauth.php` file, set the `[scope]` in the `facebook` provider section to include the `public_profile` scope, like this:

    ```
       'scope' => ['email', 'public_profile'],
    ```

> For available scopes with each provider, consult that provider's API documentation.

> NOTE: By increasing the scope you will be asking the user to grant access to additional information. They will be informed of the scopes you're requesting. If you ask for too much unnecessary data, they may refuse. So exercise restraint when requesting additional scopes.

2. Now where you do your `OAuth::login`, store the to your `$user` object by accessing the `$details->raw()['KEY']` data:

```
       OAuth::login('facebook', function($user, $details) (
           $user->gender = $details->raw()['gender']; // Or whatever the key is
           $user->save();
       });
```

> TIP: You can see what the available keys are by testing with `dd($details->raw());` inside that same closure.

###  Health Score

44

—

FairBetter than 92% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity47

Moderate usage in the ecosystem

Community29

Small or concentrated contributor base

Maturity67

Established project with proven stability

 Bus Factor1

Top contributor holds 94% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~35 days

Recently: every ~41 days

Total

20

Last Release

3851d ago

Major Versions

v4.0 → v5.0.02015-03-18

v4.0.3 → v5.0.22015-04-07

v5.0.3 → v6.0.02015-05-13

v6.1.0 → v7.0.02015-06-10

v7.0.0 → v8.0.02015-09-13

PHP version history (3 changes)v0.1PHP &gt;=5.3.0

v0.7.0PHP &gt;=5.4.0

v8.0.0PHP &gt;=5.5.0

### Community

Maintainers

![](https://www.gravatar.com/avatar/e3fb69ca14ca0266d852fc2678a6e00db1b3dbf209db9ecfdee3fa9ac913feed?d=identicon)[adamwathan](/maintainers/adamwathan)

---

Top Contributors

[![adamwathan](https://avatars.githubusercontent.com/u/4323180?v=4)](https://github.com/adamwathan "adamwathan (188 commits)")[![drbyte](https://avatars.githubusercontent.com/u/404472?v=4)](https://github.com/drbyte "drbyte (3 commits)")[![knvpk](https://avatars.githubusercontent.com/u/6078669?v=4)](https://github.com/knvpk "knvpk (3 commits)")[![syphernl](https://avatars.githubusercontent.com/u/639906?v=4)](https://github.com/syphernl "syphernl (2 commits)")[![colindecarlo](https://avatars.githubusercontent.com/u/682860?v=4)](https://github.com/colindecarlo "colindecarlo (2 commits)")[![cmgmyr](https://avatars.githubusercontent.com/u/4693481?v=4)](https://github.com/cmgmyr "cmgmyr (1 commits)")[![schmitzc](https://avatars.githubusercontent.com/u/10464?v=4)](https://github.com/schmitzc "schmitzc (1 commits)")

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/adamwathan-eloquent-oauth/health.svg)

```
[![Health](https://phpackages.com/badges/adamwathan-eloquent-oauth/health.svg)](https://phpackages.com/packages/adamwathan-eloquent-oauth)
```

###  Alternatives

[laravel/pulse

Laravel Pulse is a real-time application performance monitoring tool and dashboard for your Laravel application.

1.7k12.1M99](/packages/laravel-pulse)[roots/acorn

Framework for Roots WordPress projects built with Laravel components.

9682.1M97](/packages/roots-acorn)[php-open-source-saver/jwt-auth

JSON Web Token Authentication for Laravel and Lumen

8359.8M53](/packages/php-open-source-saver-jwt-auth)[laragear/two-factor

On-premises 2FA Authentication for out-of-the-box.

339785.3k8](/packages/laragear-two-factor)[alajusticia/laravel-logins

Session management in Laravel apps, user notifications on new access, support for multiple separate remember tokens, IP geolocation, User-Agent parser

2011.0k](/packages/alajusticia-laravel-logins)[aedart/athenaeum

Athenaeum is a mono repository; a collection of various PHP packages

255.2k](/packages/aedart-athenaeum)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
