0

ここでは本当に単純なものが欠けている必要がありますが、ここに行きます。

私はちょうど今、Alexa の開発を学び始めたところですが、Alexa のプログラミングを本当に簡単にするように見える alexa-app モジュールを見つけました - 私が遭遇しているこのネットワークの問題を除いて。

ここでは、AirportInfo というチームが提供するサンプル アプリについて説明します。問題領域のコードは次のとおりです。

var faaHelper = new FAADataHelper();
faaHelper.requestAirportStatus(airportCode).then(function(airportStatus) {
    var goodMessage = faaHelper.formatAirportStatus(airportStatus);
    console.log(goodMessage);
    res.say(goodMessage).send();
}).catch(function(err) {
    console.log(err.statusCode);
    var prompt = 'I didn\'t have data for an airport code of ' + airportCode;
    console.log(prompt);
    res.say(prompt).reprompt(reprompt).shouldEndSession(false).send();
});
return false;

次に、これらの関数を呼び出します。

FAADataHelper.prototype.requestAirportStatus = function(airportCode) {
    return this.getAirportStatus(airportCode).then(
        function(response) {
            console.log('success - received airport info for ' + airportCode);
            return response.body;
        }
    );
};
FAADataHelper.prototype.getAirportStatus = function(airportCode) {
    var options = {
        method: 'GET',
        uri: ENDPOINT + airportCode,
        resolveWithFullResponse: true,
        json: true
    };
    return rp(options);
};

これは私には良さそうに見えますが、コードを実行すると、応答がデバイスに送り返されるタイミングを制御するメインの alexa-app の「リクエスト」が予想よりも早く返されます。return rp(options)選択した空港の予想される気象情報を含む完全な応答ペイロードの代わりに、呼び出しが行われた直後に応答が返されます。.then()最初のコードサンプルのブロックで実行されるコードは、スキルが空の応答に相当するものをAlexaに送り返した後に実行されます。これにより、Alexa がスキルのエラーに関する不可解なメッセージを発するため、実際に Alexa がクラッシュします。

ここに私のserver.jsコードがあります:

var AlexaAppServer = require("../index.js");
AlexaAppServer.start({
    server_root: './',
    port: 8080,
    debug: true,
    // Use preRequest to load user data on each request and add it to the request json.
    // In reality, this data would come from a db or files, etc.
    preRequest: function(json, req, res) {
        console.log("preRequest fired");
        json.userDetails = { "name": "Bob Smith" };
    },
    // Add a dummy attribute to the response
    postRequest: function(json, req, res) {
        // look for this output in the log below
        console.log("postRequest fired");
        json.dummy = "text";
    }
});

そして、これが私が説明しているこの状態を示すデバッグログです:

preRequest fired
REQUEST { method: 'GET',
  uri: 'http://services.faa.gov/airport/status/dfw',
  resolveWithFullResponse: true,
  json: true,
  simple: false,
  callback: [Function: RP$callback],
  transform: undefined,
  transform2xxOnly: false }
postRequest fired
REQUEST make request http://services.faa.gov/airport/status/dfw
REQUEST onRequestResponse http://services.faa.gov/airport/status/dfw 200 { date: 'Fri, 24 Mar 2017 05:09:41 GMT',
  server: 'Apache',

  ...

  'access-control-allow-origin': '*',
  'access-control-allow-methods': 'GET, HEAD, OPTIONS',
  'version-requested': 'Any',
  connection: 'close',
  'transfer-encoding': 'chunked',
  'content-type': 'application/json;charset=UTF-8' }
REQUEST reading response's body

...

REQUEST end event http://services.faa.gov/airport/status/dfw
REQUEST has body http://services.faa.gov/airport/status/dfw 517
REQUEST emitting complete http://services.faa.gov/airport/status/dfw
success - received airport info for dfw

preRequest FiredpostRequest Firedを基準にして表示される場所に注意してくださいsuccess - received airport info for dfw。私が間違っていることはありますか?ノード環境で何かが誤って構成されているか、または依存関係のバージョンが不適切である可能性がありますか? Nodeコマンドプロンプトからデバッガー(VS Code)で失敗し、Lambdaからも同じように失敗するため、疑わしいです。

完全なソース コードへのリンク: https://github.com/bignerdranch/alexa-airportinfo

4

1 に答える 1