Ce code fonctionne très bien:Encapsulation API.ai appel en une fonction javascript externe ne fonctionne pas
var apiai = require('apiai');
var app = apiai(<token>);
var request = app.textRequest('jacket', {
'sessionId': 123456
});
request.on('response', function(response) {
console.log(response);
console.log(response.result.fulfillment.speech);
console.log(response.result.metadata.intentName);
});
request.on('error', function(error) {
console.log(error);
});
request.end();
Et il produit la sortie de la console suivante:
{ id: '2865abde-ac8f-4ac3-816e-483c68f709d0',
timestamp: '2016-11-08T22:38:56.461Z',
result:
{ source: 'agent',
resolvedQuery: 'jacket',
action: '',
actionIncomplete: false,
parameters: {},
contexts: [ [Object] ],
metadata:
{ intentId: '357af94f-00b3-4016-a661-732419ddafd6',
webhookUsed: 'false',
intentName: 'clothing' },
fulfillment: { speech: 'clothing2', messages: [Object] },
score: 0.6 },
status: { code: 200, errorType: 'success' },
sessionId: '123456' }
clothing2
clothing
Cependant, lorsque je tente de briser cette part dans un appel de fonction, les choses ne fonctionnent pas si bien:
fichier: main.js
var apiai = require('apiai');
var app3 = apiai(<token>);
exports.getresponse = function(inputstring){
var request = app3.textRequest(inputstring, {'sessionId': 123456});
request.on('response', function(response) {
return(response);
});
request.on('error', function(error) {
return(error);
});
request.end();
};
fichier: moda.js
var express = require("express");
var app = express();
var joe = require('./main.js');
console.log(joe.getresponse('jacket'));
app.listen(3000);
Quand je lance moda.js (moda.js de nœud), je ne reçois que
undefined
comme la sortie de la console.
Qu'est-ce que je fais mal ici?
Merci beaucoup!
Vous avez publiquement exposé votre jeton api.ai dans ce post. Vous DEVEZ régénérer ce jeton immédiatement. https: //docs.api.ai/docs/authentication – Alan