Total.js ждет события в локализации

Пытаясь дождаться асинхронного вызова в total.js для локализации. Однако, когда я пытаюсь заставить часть localization.js ждать ответа, программа продолжает работу и автоматически выбирает язык "en". Код ниже не заботится об асинхронном процессе, но я поделился им, чтобы показать, что я пытаюсь сделать. Есть идеи, как это сделать?

var COOKIE = '__language',
allowed = {en: true, dk: true};

F.onLocate = function (req, res) {
var self = this,
language = req.query.language || req.cookie(COOKIE);
var userIP = self.ip

// Set the language according to the querystring and store to the cookie
if (language) {
    if (!allowed[language])
        return 'en';
    res.cookie(COOKIE, language, '2 days');
    return language;
}

// addition if cookie is not set, first time Danish users will have 'dk' cookie set
else {
 // return from here works
   Util.waitUtils.request('https://ipfind.co?ip='+userIP +'&auth=myauthcodehere'
    , ['get'], function(err, data, status, headers) {


          var result = JSON.parse(data);

          if(result.country_code === 'DK')
            {
              res.redirect('/?language=dk');

             }
 });
}

res.cookie(COOKIE, 'en', '2 days');
return 'en';
};

1 ответ

Решение

Это невозможно. F.onLocale синхронно Решение заключается в использовании промежуточного программного обеспечения:

F.middleware('language', function(req, res, next) {

    // ...
    // ...

    RESTBuilder.make(function(builder) {
        builder.url('https://ipfind.com?ip={0}&myauthcodehere={1}'.format(req.ip, 'myauthcodehere'));
        builder.exec(function(err, response) {

            req.language = response.country_code;
            next();

            // or
            // res.redirect('?language=dk');
            // next = null;
        });
    });
});

Спасибо.

Другие вопросы по тегам