mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2024-09-21 00:41:34 +02:00
e4f46c2a4e
* Default database connection - set defaults for engine and strict * Working on tests for refactored model * Fixes for tests, use polymorphic relationships for Invitations * skin the password reset pages
73 lines
1.7 KiB
PHP
73 lines
1.7 KiB
PHP
<?php
|
|
|
|
namespace App\Libraries;
|
|
|
|
use Laravel\Socialite\Facades\Socialite;
|
|
|
|
/**
|
|
* Class OAuth
|
|
* @package App\Libraries
|
|
*/
|
|
class OAuth
|
|
{
|
|
|
|
/**
|
|
* Socialite Providers
|
|
*/
|
|
const SOCIAL_GOOGLE = 1;
|
|
const SOCIAL_FACEBOOK = 2;
|
|
const SOCIAL_GITHUB = 3;
|
|
const SOCIAL_LINKEDIN = 4;
|
|
const SOCIAL_TWITTER = 5;
|
|
const SOCIAL_BITBUCKET = 6;
|
|
|
|
/**
|
|
* @param Socialite $user
|
|
*/
|
|
|
|
public static function handleAuth($user)
|
|
{
|
|
if(MultiDB::checkUserEmailExists($user->getEmail())) //if email is in the system this is an existing user -> check they are arriving on the correct provider
|
|
{
|
|
|
|
}
|
|
}
|
|
|
|
public static function providerToString($social_provider)
|
|
{
|
|
switch ($social_provider)
|
|
{
|
|
case SOCIAL_GOOGLE:
|
|
return 'google';
|
|
case SOCIAL_FACEBOOK:
|
|
return 'facebook';
|
|
case SOCIAL_GITHUB:
|
|
return 'github';
|
|
case SOCIAL_LINKEDIN:
|
|
return 'linkedin';
|
|
case SOCIAL_TWITTER:
|
|
return 'twitter';
|
|
case SOCIAL_BITBUCKET:
|
|
return 'bitbucket';
|
|
}
|
|
}
|
|
|
|
public static function providerToInt($social_provider)
|
|
{
|
|
switch ($social_provider)
|
|
{
|
|
case 'google':
|
|
return SOCIAL_GOOGLE;
|
|
case 'facebook':
|
|
return SOCIAL_FACEBOOK;
|
|
case 'github':
|
|
return SOCIAL_GITHUB;
|
|
case 'linkedin':
|
|
return SOCIAL_LINKEDIN;
|
|
case 'twitter':
|
|
return SOCIAL_TWITTER;
|
|
case 'bitbucket':
|
|
return SOCIAL_BITBUCKET;
|
|
}
|
|
}
|
|
} |