OAuth Ausnahme in Facebook Messenger chatbot mit api.ai und Heroku (node.js)

stimmen
1

Ich habe meinen Code und den Fehler geteilt , die unten aufgetaucht. Grundsätzlich folgte ich das Tutorial http://www.girliemac.com/blog/2017/01/06/facebook-apiai-bot-nodejs/ und ein anderes. Mein chatbot arbeitet für smalltalk , aber nicht für das Wetter api Zeug. Ich versuche , die chatbot geben mir Antworten über das Wetter in verschiedenen Städten zu machen. Ich habe das Tutorial genau befolgt.

  Error:  { message: '(#100) No matching user found',
  type: 'OAuthException',
   code: 100,
  error_subcode: 2018001,
   fbtrace_id: 'DeubaTWU6Gg' }
 Error:  { message: '(#100) No matching user found',
   type: 'OAuthException',
   code: 100,
   error_subcode: 2018001,
   fbtrace_id: 'FSiMes3IwHv' }

// Code aus index.js nur für das Wetter api Zeug

 app.post('/ai', (req, res) => {
  //console.log('*** Webhook for api.ai query ***');
  //console.log(req.body.result);

  if (req.body.result.action === 'weather') {
 //  console.log('*** weather ***');
    let city = req.body.result.parameters['geo-city'];
    let restUrl = 'http://api.openweathermap.org/data/2.5/weather?APPID='+process.env.WEATHER_API_KEY+'&q='+city;

    request.get(restUrl, (err, response, body) => {
      if (!err && response.statusCode == 200) {
        let json = JSON.parse(body);
       // console.log(json);
        let tempF = ~~(json.main.temp * 9/5 - 459.67);
        let tempC = ~~(json.main.temp - 273.15);
        let msg = 'The current condition in ' + json.name + ' is ' + json.weather[0].description + ' and the temperature is ' + tempF + ' ℉ (' +tempC+ ' ℃).'
        return res.json({
          speech: msg,
          displayText: msg,
          source: 'weather'
        });
      } else {
        let errorMessage = 'I failed to look up the city name.';
        return res.status(400).json({
          status: {
            code: 400,
            errorType: errorMessage
          }
        });
      }
    })
  }

});

Wie kann ich diesen Fehler beheben?

Veröffentlicht am 23/09/2017 um 05:00
quelle vom benutzer
In anderen Sprachen...                            


1 antworten

stimmen
1

Der Fehler ist , weil die Seite-scoped ID Sie mit der Nachricht senden , in recipient.idnicht gültig ist. Angenommen , Sie haben die einrichten sendMessage()corrently Funktion aus dem Tutorial, wahrscheinlich das Problem ist , dass die Facebook - Konto , das Sie den Chat mit dem Bot verwenden die richtige Rolle nicht haben.

Wenn der Bot nicht öffentlich ist (dh nicht vorgelegt und genehmigt worden ist) das Facebook-Konto Sie Nachrichten verwenden, um den Bot zu senden muss der Administrator angegeben werden, Entwickler oder Tester Rolle in Ihrer App-Einstellungen.

Beantwortet am 26/09/2017 um 04:25
quelle vom benutzer

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more