Download the PHP package skn036/laravel-google-client without Composer
On this page you can find all versions of the php package skn036/laravel-google-client. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download skn036/laravel-google-client
More information about skn036/laravel-google-client
Files in skn036/laravel-google-client
Package laravel-google-client
Short Description Wrapper for Google API Client Library for Laravel
License MIT
Homepage https://github.com/skn036/laravel-google-client
Informations about the package laravel-google-client
Wrapper Around Google Client For Laravel
This package only handles the authentication layer, securely saving, retrieving and revoking tokens around google api client. So it could be a good choice as authentication layer while using any api service from google.
For some common api services from google please check:
Gmail Api: skn036/laravel-gmail-api
Calendar Api: skn036/laravel-google-calendar (coming soon)
For extending your own api service please follow the guidelines below.
Installation
First install the package via composer.
Then publish the config file. It will publishes google.php file in the config directory.
Configuration
Please look into config/google.php for detailed information about the configuration. First you need to enable the required api services and generate credentials in your google developers account. Please see here from detailed instructions. Available .env variables for configuration are:
Authentication Modes:
There are three authentication modes:
- Single account in whole application ( set
credentials_per_user
tofalse
in config file ). - Single account per user ( set
credentials_per_user
totrue
&multiple_accounts_per_user
tofalse
in config file ). - Multiple accounts per user ( set
credentials_per_user
totrue
&multiple_accounts_per_user
totrue
in config file ).
Note: You need to set the scopes on .env file which google services you intended to use.
Getting Started
google-dashboard.blade.php:
SPA Authentication
If you are using SPA frontend like React
or Vue
and entirely handle the Oauth redirect in the frontend, you should call the getAuthUrl method to get the google Oauth url.
After successful login from google, it should add code
route query param on redirect uri set on the google console. You need to pass this code the authenticate
method or if you pass the code as route query, it will automatically capture on authentication request;
Single Account Per User Mode:
By default, authenticated user is passed to GoogleClient
instance using laravel's auth()->id()
. If you want to pass a user manually to client instance:
Multiple Account Per User Mode:
When using multiple accounts, first account synced will be set as default account. If you want to change the default account, first get the available accounts:
It will give a array of synced accounts like:
Then you call setDefaultAccount
method to change the default account.
Normally it will use the default account to interact with the services. If you want to use other account rather than the default, you should pass the email of the intended account as the second argument of the client constructor.
Extending This Package To Google Api Services
First you should make a api service class extending the GoogleClient class. Then bind it to the api services to interact with the api.
For example we will extend to the Gmail api
service:
On the GmailMessage.php
:
Now you can get the gmail messages by
Tree Shaking Unused Google Services
There are more than 200 api services shipped together on google api. For tree shaking the unnecessary services, please follow instructions on google api client.
Testing
Changelog
Please see CHANGELOG for more information on what has changed recently.
License
The MIT License (MIT). Please see License File for more information.