Социальный вход с Angular 5 и Lumen 5.6 - PullRequest
0 голосов
/ 28 июня 2018

Я пытаюсь реализовать социальный вход в систему с угловым 5 в качестве моего внешнего интерфейса и люменом 5,6 в качестве моего внутреннего интерфейса.

Я использую систему аутентификации JWT с Lumen. Итак, я запутался, как мне следует внедрить систему социального входа в систему в этой ситуации.

Благодаря моим исследованиям я пришел к этим библиотекам, которые могут выполнять эту работу, но я не уверен, как этот процесс обрабатывается от внешнего (углового) до внутреннего (люмен).

For Angular 5 -
angularx-social-login OR Satellizer
For Lumen -
laravel/socialite

Но поскольку я не нашел никакой документации по Satellizer, работающей с Angular 5, я решил использовать другую.

Я читал эту статью, но мне все еще неясен процесс от внешнего интерфейса до внутреннего. https://medium.com/@barryvdh/oauth-in-javascript-apps-with-angular-and-lumen-using-satellizer-and-laravel-socialite-bb05661c0d5c

Любая объяснительная помощь?

1 Ответ

0 голосов
/ 30 июня 2018

Таким образом, я использовал социальный вход в Angular 5 с помощью пакета

"angular5-social-login": "^1.0.9",

Итак, добавьте это в файл package.json.

Импорт в app.module.ts

import { SocialLoginModule, AuthServiceConfig, GoogleLoginProvider, FacebookLoginProvider } from 'angular5-social-login';

Настройка функции в app.module.ts

export function getAuthServiceConfigs() {
  const config = new AuthServiceConfig(
      [
        {
          id: FacebookLoginProvider.PROVIDER_ID,
          provider: new FacebookLoginProvider('') // Left as i dont use it
        },
        {
          id: GoogleLoginProvider.PROVIDER_ID,
          provider: new GoogleLoginProvider('YOUR-API-TOKEN.apps.googleusercontent.com')
        },
      ]
  );
  return config;
}

Добавьте его в свой импорт в app.module.ts

imports: [
    HttpClientModule,
    AppRoutingModule,
    ...
    SocialLoginModule, // One we need to add
  ],

Затем добавьте его своим провайдерам в app.module.ts

providers: [
    YourServices,
    ...
    ApiAuthService,
    {
        provide: AuthServiceConfig,
        useFactory: getAuthServiceConfigs
    },
    LoggedInGuard,
],

Как вы можете видеть, у меня есть LoggedInGuard и ApiAuthService это они с аутентификацией и проверкой вашего входа в систему.

Итак, пакет установлен и настроен ...

Теперь внутри api-auth.service.ts добавьте эту функцию

socialSignIn(userData) {
    const formData = new FormData();
      formData.append('email', userData.email);
      formData.append('name', userData.name);
      formData.append('provider', userData.provider);
      formData.append('id', userData.id);
      formData.append('idToken', userData.idToken);
      formData.append('token', userData.token);
      formData.append('image', userData.image);
    return this._http.post(
      environment.apiUrl + '/auth/social-signin/',
      formData,
      {
        headers: new Headers({
          'Authorization': 'Bearer ' + userData.idToken
        })
      }
    );
  }

Теперь в вашем компоненте входа добавьте это в HTML

<div (click)="socialSignIn('google')" class="c2a_btn large google">
    Log in with google 
</div>

В вашем компоненте .ts файла входа добавьте эту функцию

import { AuthService, FacebookLoginProvider, GoogleLoginProvider, LinkedinLoginProvider } from 'angular5-social-login';
import { ApiAuthService } from '../../../../services/api-auth.service';
import { TokenService } from '../../../../services/token.service';


public socialSignIn(socialPlatform: string) {
    this.loading = true;
    let socialPlatformProvider;
    if (socialPlatform === 'facebook') {
      socialPlatformProvider = FacebookLoginProvider.PROVIDER_ID;
    } else if (socialPlatform === 'google') {
      socialPlatformProvider = GoogleLoginProvider.PROVIDER_ID;
    } else if (socialPlatform === 'linkedin') {
      socialPlatformProvider = LinkedinLoginProvider.PROVIDER_ID;
    }

    this.socialAuthService.signIn(socialPlatformProvider).then(
      (userData) => {
        this._apiAuthService.socialSignIn(userData)
        .map( data => {
          return data.json();
        })
        .subscribe(
          token => {
            this._tokenService.setAccessToken(token.access_token);
          },
          error => {
            this.invalidLogin = true;
            this.loading = false;
          },
          () => {
            this.loading = false;
            this.closeSignIn.emit('out');
            // this._router.navigate(['/profile']);
          }
        );
      }
    );
  }

Теперь это только передняя часть для задней части. Я использую Laravel 5.6

Но я сделал такую ​​функцию

public function socialSignIn(Request $request, Response $response) {

        $date = date('Y-m-d h:i:s');
        $provider = $request->input('provider');

        if ($provider == 'google') {
            $id_token = $request->header('Authorization');
            $id_token = str_replace("Bearer ","",$id_token);

            $CLIENT_ID = Config::get('google.client_id');

            $email = $request->input('email');
            $names = $request->input('name');
            $name = explode(' ', $names);

            $client = new \Google_Client();
            $client->setDeveloperKey($CLIENT_ID);
            $payload = $client->verifyIdToken($id_token);
            if ($payload) {
                if (User::where('email', '=', $email)->exists()) {

                    $user = User::Where('email', '=', $email)->first();
                    if(!Auth::loginUsingId($user->id)){
                        return response()->json([
                            'failed'
                        ], 403);
                    }

                    $updateLastLoginDate = User::where('id', Auth::user()->id)-first();
                    $updateLastLoginDate->last_login_date = $date;
                    $updateLastLoginDate->save();

                    $activeAccount = Auth::user();
                    $activeAccount->active = '1';
                    $activeAccount->save();

                } else {

                    $recordUser = New User;
                    $recordUser->email = $request->input('email');
                    $recordUser->last_login_date = $date;
                    $recordUser->save();

                    $recordLinkedSocialAcounts = new LSA;
                    $recordLinkedSocialAcounts->user_id = $recordUser->id;
                    $recordLinkedSocialAcounts->provider_name = $provider;
                    $recordLinkedSocialAcounts->provider_id = $request->input('id');
                    $recordLinkedSocialAcounts->save();

                    $recordUserInformation = new UPI;
                    $recordUserInformation->user_id = $recordUser->id;
                    $recordUserInformation->first_name = $name[0];
                    $recordUserInformation->last_name = $name[1];
                    $recordUserInformation->last_login_date = $date;
                    $recordUserInformation->image = $request->input('image');
                    $recordUserInformation->save();

                    if(!Auth::loginUsingId($recordUser->id)){
                        return response()->json([
                            'failed'
                        ], 403);
                    }
                }

                return response()->json([
                    'access_token' => Auth::user()->createToken('access_token')->accessToken,
                    'role_id' => Auth::user()->role_id
                ], 200);
            } else {
                return response()->json([
                    'failed'
                ], 403);
            }
        }
    }

Скорее всего, я скоро сделаю видео об этом. Любые вопросы просто задавайте

...