agent.add () не работает, хотя console.log () - PullRequest
2 голосов
/ 17 апреля 2020

Я пытаюсь реализовать бота, используя Telegram, Dialogflow и Firebase. У меня возникли проблемы с этой функцией:

function findDoc(agent){
    const userId = request.body.originalDetectIntentRequest.payload.data.from.id.toString();
    const first_name = request.body.originalDetectIntentRequest.payload.data.from.first_name;
    console.log(`Telegram user ID: ${userId}, first_name: ${first_name}`);//THIS SHOWS
    agent.add(`voy a ver si existe el documento`);//THIS SHOWS
    agent.setContext({name: "firstTimer", lifespan:10});
    return db.collection('users').doc(''+userId).get()
      .then((doc) => {
        if (!doc.exists) {
          console.log(`New user created in database `);//THIS SHOWS
          agent.add(`New user created in database`);//THIS DOESN'T SHOW
          var data={
            'id':userId, 
            'name':first_name, 
            'contadorP': 0,
            'doneQuestions': [],
          };
          return db.runTransaction((dataDB)=>{
            dataDB.set(db.collection('users').doc(''+userId), data,{merge:true});
            return Promise.resolve();
          }).catch((err) => {
                console.error(`Error creating file: `+err);
            });
        } else {
          console.log('Found Telegram profile: ', JSON.stringify(doc.data()));//THIS SHOWS
          const data = doc.data();
          agent.add(`User ${data.id} has the name of ${data.nombre}`);//THIS DOESN'T SHOW
        }
      })
      .catch((err) => {
        console.error(err);
      });
  }

Я уверен, что функция работает нормально, потому что console.log () в консоли Firebase работает нормально, поскольку они показывают, что они должны; и я тоже не получаю ошибок ...

Вот мои зависимости от моего пакета. json:

"dependencies": {
    "actions-on-google": "^2.5.0",
    "firebase-admin": "^8.2.0",
    "firebase-functions": "^2.0.2",
    "dialogflow": "^0.6.0",
    "dialogflow-fulfillment": "^0.6.1"
  }

Вот как я работаю с намерениями:

  intentMap.set('Default Welcome Intent', welcome);

, и эта функция вызывает функцию findDo c ():

function welcome(agent){
    console.log(`Estoy en la funcion de welcome`);
    agent.add(`Welcome`);
    findDoc(agent);
  }

. Отобразятся как console.log (), так и agent.add () функции welcome. , Из того, что я прочитал в Интернете, зависимости в порядке и должны работать. Так что я не знаю, что еще попробовать, так как я (я думаю) правильно сделал каждое найденное предложение. Пожалуйста, помогите ...

1 Ответ

1 голос
/ 26 апреля 2020

Проблема в том, что, хотя findDoc(agent) обрабатывает вещи асинхронно и возвращает Обещание, вы не используете это обещание как часть вашего обработчика welcome(). Библиотека выполнения диалогового потока требует, чтобы вы возвращали Promise из вашего обработчика, если вы выполняете какую-либо асинхронную операцию.

Это выглядит как для работы, поскольку Promise завершается , поэтому звонки на console.log() работают как положено. Но поскольку вы не возвращаете это обещание диспетчеру, он отправляет обратно только все от agent.add() до точки асинхронных операций c.

В вашем случае решение простое. Поскольку findDoc() возвращает Обещание, все, что вам нужно сделать, это welcome() вернуть это обещание. Примерно так должно работать:

function welcome(agent){
  console.log(`Estoy en la funcion de welcome`);
  agent.add(`Welcome`);
  return findDoc(agent);
}
...