Получить данные из Passport-azure-ad перед настройкой БД - PullRequest
0 голосов
/ 13 декабря 2018
var server;
var db;    

passport.use(new OIDCStrategy({
        identityMetadata: config.creds.identityMetadata,
        clientID: config.creds.clientID,
        responseType: config.creds.responseType,
        responseMode: config.creds.responseMode,
        redirectUrl: config.creds.redirectUrl,
        allowHttpForRedirectUrl: config.creds.allowHttpForRedirectUrl,
        clientSecret: config.creds.clientSecret,
        validateIssuer: config.creds.validateIssuer,
        isB2C: config.creds.isB2C,
        issuer: config.creds.issuer,
        passReqToCallback: config.creds.passReqToCallback,
        scope: config.creds.scope,
        loggingLevel: config.creds.loggingLevel,    
        nonceLifetime: config.creds.nonceLifetime,
        nonceMaxAmount: config.creds.nonceMaxAmount,
        useCookieInsteadOfSession: config.creds.useCookieInsteadOfSession,
        cookieEncryptionKeys: config.creds.cookieEncryptionKeys,
        clockSkew: config.creds.clockSkew,
      },
        function (iss, sub, profile, accessToken, refreshToken, done) { 

            const request = require('request');

            const options = {
                url: 'https://graph.microsoft.com/v1.0/me?$select=displayName,extension_db,extension_server',
                headers: {
                    'Authorization': "Bearer " + accessToken,
                    'Content-Type': 'application/json'
                }
            };

            function callback(error, response, body) {
                if (!error && response.statusCode == 200) {
                    console.log('error:', error); // Print the error if one occurred
                    console.log('statusCode:', response && response.statusCode); // Print the response status code if a response was received
                    console.log('body:', body); 
                    var data = JSON.parse(response.body);
                    server = data.extension_server;
                    db = data.extension_db;
                } else {
                    console.log(response.statusCode);
                }
            }
            request(options, callback);

        if (!profile.oid) {
          return done(new Error("No oid found"), null);
        }
        // asynchronous verification, for effect...
        process.nextTick(function () {
          findByOid(profile.oid, function(err, user) {
            if (err) {
              return done(err);
              }
            if (!user) {
              // "Auto-registration"
                users.push(profile);
              return done(null, profile);
              }

            return done(null, user);
          });
        });
      }
    ));


//config database
var sql = require("mssql");

var config = {
    user: '****',
    password: '*****',
    server: server,
    database: db
};

Я хочу настроить базу данных на основе полей, которые я получаю из запроса на получение.У меня возникает проблема с passport.use после того, как конфиг уже установлен и весь мой другой код, включая маршруты, выполнены.Как я могу сделать так, чтобы passport.use происходил первым после входа в систему?

...