PHPackages                             motomedialab/laravel-google-signin - 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. motomedialab/laravel-google-signin

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

motomedialab/laravel-google-signin
==================================

Simple implementation for Google oAuth sign-in utilising Laravel Passport

v1.1.1(1y ago)61591MITPHPPHP ^8.1

Since Sep 5Pushed 1y ago1 watchersCompare

[ Source](https://github.com/motomedialab/laravel-google-signin)[ Packagist](https://packagist.org/packages/motomedialab/laravel-google-signin)[ RSS](/packages/motomedialab-laravel-google-signin/feed)WikiDiscussions main Synced 1mo ago

READMEChangelog (6)Dependencies (5)Versions (8)Used By (0)

Effortless Google Sign-In for Laravel
=====================================

[](#effortless-google-sign-in-for-laravel)

[![GitHub Actions](https://github.com/motomedialab/laravel-google-signin/actions/workflows/tests.yaml/badge.svg)](https://github.com/motomedialab/laravel-google-signin/actions/workflows/tests.yaml/badge.svg)

Seamlessly integrate Google OAuth2 Single Sign-On into your Laravel application with this streamlined package. Born out of the need to efficiently implement Google OAuth2 authentication across multiple projects, this package leverages Laravel's [Socialite](https://laravel.com/docs/11.x/socialite) under the hood, adhering to best practices while simplifying the setup process. It bundles the necessary components, controllers, and routes for an effortless implementation.

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

[](#installation)

Install via Composer:

```
composer require motomedialab/laravel-google-signin
```

The package will auto-register. Next, add your Google Client ID and Secret to your `.env` file (see below for instructions if you haven't set these up yet).

```
GOOGLE_OAUTH_CLIENT_ID=your-client-id
GOOGLE_OAUTH_CLIENT_SECRET=your-client-secret

```

Using the "Sign in with Google" button
--------------------------------------

[](#using-the-sign-in-with-google-button)

[![Sign in with Google](previews/button.png)](previews/button.png)

This package includes a ready-to-use "Sign in with Google" button. You can include it in your views as a blade component:

```

```

For further styling, publish the button view to your project:

```
php artisan vendor:publish --tag=views-google-signin
```

That's it! You've successfully added Google SSO to your Laravel project. If you haven't already, you'll need to obtain your Google Client ID and Secret from the Google Developer Console.

---

Getting your Google Client ID and Secret
----------------------------------------

[](#getting-your-google-client-id-and-secret)

1. Visit the [Google Developer Console](https://console.developers.google.com/)
2. Create a new project or select an existing one
3. Navigate to the "Credentials" tab
4. Click the "Create Credentials" button and choose "OAuth client ID".
5. Select "Web application" as the application type
6. Add the URL to your callback route to the "Authorized redirect URIs" list
    1. you can find this by running `php artisan route:list --name=google-signin.store`
7. Click "Create" to generate your Client ID and Secret
8. Copy the generated ID and secret to your `.env` file as per [Configuration](#installation)

### Further customisation

[](#further-customisation)

To tailor the package's behavior further, such as modifying the login process, publish the configuration file and override the default settings:

```
php artisan vendor:publish --tag=config-google-signin

```

### So what does it actually do?

[](#so-what-does-it-actually-do)

From a technical standpoint this package adds a `google_id` column to your users table. When a user attempts to log in with Google, we'll check if a user with the same Google ID already exists - if it does, we'll log them in.

If it doesn't, and there's a user with a matching email address, we'll link the Google ID to that user and log them in.

If both checks fail, we'll return a 403 forbidden response. **It's important to note that a user must have a corresponding Google email address already registered on your platform to be able to gain access.**

We store the Google ID to prevent future 'email hijacking' attacks, where a user could change their email address to one that's already in use/was in use by another user.

### Contributing

[](#contributing)

Please see [CONTRIBUTING](CONTRIBUTING.md) for details.

### Security

[](#security)

If you discover any security-related issues, please email  instead of using the issue tracker.

### License

[](#license)

This package is licensed under the MIT License. See the [LICENSE](LICENSE.md) file for more information.

### Need help with your next project?

[](#need-help-with-your-next-project)

This plugin is maintained and developed by [MotoMediaLab](https://www.motomedialab.com), a full-service agency based in the UK. Contact us for assistance with your next project!

###  Health Score

32

—

LowBetter than 72% of packages

Maintenance35

Infrequent updates — may be unmaintained

Popularity19

Limited adoption so far

Community8

Small or concentrated contributor base

Maturity53

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% 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 ~2 days

Total

7

Last Release

603d ago

PHP version history (2 changes)v1.0.0PHP ^7.4|^8.1

v1.1.0PHP ^8.1

### Community

Maintainers

![](https://www.gravatar.com/avatar/805ae1048fb81d8f02871f57cc0a34699089da17f7021210e554ffdba4df918a?d=identicon)[chrispage1](/maintainers/chrispage1)

---

Top Contributors

[![chrispage1](https://avatars.githubusercontent.com/u/2487374?v=4)](https://github.com/chrispage1 "chrispage1 (15 commits)")

---

Tags

laravelgoogleSSOsocialitemotomedialab

###  Code Quality

TestsPest

Static AnalysisPHPStan

Code StyleLaravel Pint

### Embed Badge

![Health badge](/badges/motomedialab-laravel-google-signin/health.svg)

```
[![Health](https://phpackages.com/badges/motomedialab-laravel-google-signin/health.svg)](https://phpackages.com/packages/motomedialab-laravel-google-signin)
```

###  Alternatives

[socialiteproviders/manager

Easily add new or override built-in providers in Laravel Socialite.

42442.0M544](/packages/socialiteproviders-manager)[andrewdwallo/filament-companies

A comprehensive Laravel authentication and authorization system designed for Filament, focusing on multi-tenant company management.

34450.0k2](/packages/andrewdwallo-filament-companies)[schedula/laravel-passport-socialite

The missing laravel passport feature for social authentication

4922.6k](/packages/schedula-laravel-passport-socialite)[revolution/socialite-mastodon

Socialite for Mastodon

13203.2k1](/packages/revolution-socialite-mastodon)[truckersmp/steam-socialite

Laravel Socialite provider for Steam OpenID.

1516.7k](/packages/truckersmp-steam-socialite)

PHPackages © 2026

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