testing
This commit is contained in:
@@ -74,51 +74,52 @@ class EveLoginController extends Controller
|
||||
|
||||
private function CreateOrUpdateUser($ssoUser)
|
||||
{
|
||||
|
||||
//Update user permissions, privileges, and add to database if not available.
|
||||
$user = app(\App\Services\UserPrivilegeService::class)->privilegesChanged($user, function($user) {
|
||||
//Get all the data we need from the ssoUser
|
||||
$characterId = strtr($ssoUser['sub'], ['CHARACTER:EVE:' => '']);
|
||||
$characterName = $ssoUser['name'];
|
||||
$characterOwnerHash = $ssoUser['owner'];
|
||||
$avatar = 'https://image.eveonline.com/Character/' . $characterId . '_128.jpg';
|
||||
$token = $ssoUser->token;
|
||||
$refreshToken = $ssoUser->refreshToken ?? null;
|
||||
$expiresIn = $ssoUser->expiresIn ?? null;
|
||||
$scopes = is_array($ssoUser['scp']) ? $ssoUser['scp'] : [$ssoUser['scp']];
|
||||
|
||||
$user = User::updateOrCreate(
|
||||
['character_id' => $characterId],
|
||||
[
|
||||
'avatar' => $avatar,
|
||||
'character_name' => $characterName,
|
||||
'character_owner_hash' => $characterOwnerHash,
|
||||
'token' => $token,
|
||||
'refresh_token' => $refreshToken,
|
||||
'expiresIn' => $expiresIn,
|
||||
]
|
||||
);
|
||||
$user = new User;
|
||||
$privilege = new UserPrivilegeService;
|
||||
|
||||
//Delete currently saved scopes, then add the scopes used to login with.
|
||||
EsiScope::where(['character_id' => $characterId])->delete();
|
||||
foreach($scopes as $scope) {
|
||||
$data = new EsiScope;
|
||||
$data->character_id = $characterId;
|
||||
$data->scope = $scope;
|
||||
$data->save();
|
||||
}
|
||||
//Get all the data we need from the ssoUser
|
||||
$characterId = strtr($ssoUser['sub'], ['CHARACTER:EVE:' => '']);
|
||||
$characterName = $ssoUser['name'];
|
||||
$characterOwnerHash = $ssoUser['owner'];
|
||||
$avatar = 'https://image.eveonline.com/Character/' . $characterId . '_128.jpg';
|
||||
$token = $ssoUser->token;
|
||||
$refreshToken = $ssoUser->refreshToken ?? null;
|
||||
$expiresIn = $ssoUser->expiresIn ?? null;
|
||||
$scopes = is_array($ssoUser['scp']) ? $ssoUser['scp'] : [$ssoUser['scp']];
|
||||
|
||||
$user = User::updateOrCreate(
|
||||
['character_id' => $characterId],
|
||||
[
|
||||
'avatar' => $avatar,
|
||||
'character_name' => $characterName,
|
||||
'character_owner_hash' => $characterOwnerHash,
|
||||
'token' => $token,
|
||||
'refresh_token' => $refreshToken,
|
||||
'expiresIn' => $expiresIn,
|
||||
]
|
||||
);
|
||||
|
||||
//Add Esi Token to the token database
|
||||
$esiToken = EsiToken::updateOrCreate(
|
||||
['character_id' => $characterId],
|
||||
[
|
||||
'access_token' => $token,
|
||||
'refresh_token' => $refreshToken,
|
||||
'inserted_at' => time(),
|
||||
'expires_in' => $expiresIn,
|
||||
]
|
||||
);
|
||||
});
|
||||
//Delete currently saved scopes, then add the scopes used to login with.
|
||||
EsiScope::where(['character_id' => $characterId])->delete();
|
||||
foreach($scopes as $scope) {
|
||||
$data = new EsiScope;
|
||||
$data->character_id = $characterId;
|
||||
$data->scope = $scope;
|
||||
$data->save();
|
||||
}
|
||||
|
||||
//Add Esi Token to the token database
|
||||
$esiToken = EsiToken::updateOrCreate(
|
||||
['character_id' => $characterId],
|
||||
[
|
||||
'access_token' => $token,
|
||||
'refresh_token' => $refreshToken,
|
||||
'inserted_at' => time(),
|
||||
'expires_in' => $expiresIn,
|
||||
]
|
||||
);
|
||||
|
||||
$privilege->privilegesChanged($user);
|
||||
|
||||
//Send the object back to the calling function
|
||||
return $user;
|
||||
|
||||
Reference in New Issue
Block a user