Внедрение социальной аутентификации II
Напомним, что этот проект строится на следующем стартовом проекте Glitch или клонируется из GitHub . Последняя часть настройки вашей аутентификации GitHub - это создание самой стратегии. Для этого вам нужно будет добавить зависимость «паспорт-github» к вашему проекту и потребовать его как GithubStrategy, например, const GitHubStrategy = require('passport-github').Strategy;
, Чтобы настроить стратегию GitHub, вы должны указать паспорт, чтобы использовать экземпляр GithubStrategy , который принимает 2 аргумента: объект (содержащий clientID , clientSecret и callbackURL ) и функцию, которая будет вызываться, когда пользователь будет успешно аутентифицирован, что мы определим если пользователь является новым и какие поля сначала сохраняются в объекте базы данных пользователя. Это распространено во многих стратегиях, но для некоторых из них может потребоваться дополнительная информация, как указано в github этой конкретной стратегии README; например, Google требует также область видимости, которая определяет, какую информацию запрашивает ваш запрос, и просит пользователя одобрить такой доступ. Текущая стратегия, которую мы реализуем, имеет свое использование, изложенное здесь , но мы все это проверим здесь, на freeCodeCamp! Вот как ваша новая стратегия должна смотреть на этот момент:
passport.use (новый GitHubStrategy ({ clientID: process.env.GITHUB_CLIENT_ID, clientSecret: process.env.GITHUB_CLIENT_SECRET, callbackURL: / * ВСТАВЬТЕ URL-адрес CALLBACK, ВХОДЯЩИЙ В ГИТУМ ЗДЕСЬ * / }, function (accessToken, refreshToken, profile, cb) { console.log (профиль); // Логика базы данных здесь с обратным вызовом, содержащим наш пользовательский объект } ));Ваша аутентификация еще не будет выполнена, и на самом деле вывести ошибку, без логики базы данных и обратного вызова, но она должна зайти на консоль вашего профиля GitHub, если вы попробуете! Представьте свою страницу, когда вы думаете, что у вас все в порядке.