12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 |
- <?php
- namespace App\Http\Controllers\Auth;
- use App\Http\Controllers\Controller;
- use App\Models\DiscordUser;
- use App\Models\User;
- use Illuminate\Support\Facades\Auth;
- use Illuminate\Support\Facades\Http;
- use Laravel\Socialite\Facades\Socialite;
- class SocialiteController extends Controller
- {
- public function redirect()
- {
- $scopes = ! empty(config('SETTINGS::DISCORD:BOT_TOKEN')) && ! empty(config('SETTINGS::DISCORD:GUILD_ID')) ? ['guilds.join'] : [];
- return Socialite::driver('discord')
- ->scopes($scopes)
- ->redirect();
- }
- public function callback()
- {
- if (Auth::guest()) {
- return abort(500);
- }
- /** @var User $user */
- $user = Auth::user();
- $discord = Socialite::driver('discord')->user();
- $botToken = config('SETTINGS::DISCORD:BOT_TOKEN');
- $guildId = config('SETTINGS::DISCORD:GUILD_ID');
- $roleId = config('SETTINGS::DISCORD:ROLE_ID');
- //save / update discord_users
- //check if discord account is already linked to an cpgg account
- if (is_null($user->discordUser)) {
- $discordLinked = DiscordUser::where('id', '=', $discord->id)->first();
- if ($discordLinked !== null) {
- return redirect()->route('profile.index')->with(
- 'error',
- 'Discord account already linked!'
- );
- }
- //create discord user in db
- DiscordUser::create(array_merge($discord->user, ['user_id' => Auth::user()->id]));
- //update user
- Auth::user()->increment('credits', config('SETTINGS::USER:CREDITS_REWARD_AFTER_VERIFY_DISCORD'));
- Auth::user()->increment('server_limit', config('SETTINGS::USER:SERVER_LIMIT_REWARD_AFTER_VERIFY_DISCORD'));
- Auth::user()->update(['discord_verified_at' => now()]);
- } else {
- $user->discordUser->update($discord->user);
- }
- //force user into discord server
- //TODO Add event on failure, to notify ppl involved
- if (! empty($guildId) && ! empty($botToken)) {
- $response = Http::withHeaders(
- [
- 'Authorization' => 'Bot '.$botToken,
- 'Content-Type' => 'application/json',
- ]
- )->put(
- "https://discord.com/api/guilds/{$guildId}/members/{$discord->id}",
- ['access_token' => $discord->token]
- );
- //give user a role in the discord server
- if (! empty($roleId)) {
- $response = Http::withHeaders(
- [
- 'Authorization' => 'Bot '.$botToken,
- 'Content-Type' => 'application/json',
- ]
- )->put(
- "https://discord.com/api/guilds/{$guildId}/members/{$discord->id}/roles/{$roleId}",
- ['access_token' => $discord->token]
- );
- }
- }
- return redirect()->route('profile.index')->with(
- 'success',
- 'Discord account linked!'
- );
- }
- }
|