具有输出上下文的Dialogflow响应使PHP / Symfony服务器崩溃

时间:2019-07-15 14:41:05

标签: symfony dialogflow

TL; DR

当Dialogflow发送带有输出上下文的响应时,我的PHP / Symfony服务器崩溃,但是当响应没有任何输出上下文时,我的PHP / Symfony服务器正常工作。 为什么会这样,如何防止服务器崩溃?

某些上下文

我正在研究一个同事的一个老项目,几个月前他离开了公司。 该项目使用Dialogflow和PHP / Symfony服务器创建聊天机器人。 早在1月份,该项目就运行良好,但是当我上周尝试对其进行测试时,我发现我们的服务器已被无可避免地从主机上删除了。 我重新上传并重新安装了服务器代码,但是我不能100%确定备份代码与托管代码完全相同。

正确的行为

  1. 我将“嘿” 发送到服务器
  2. 服务器将消息传输到Dialogflow
  3. Dialogflow确定意图是“欢迎”
  4. Dialogflow将“ Salutations” 发送回服务器
  5. 我得到响应“ Salutations”

错误行为

  1. 我将“帮助” 发送到服务器
  2. 服务器将消息传输到Dialogflow
  3. Dialogflow确定意图是“帮助”
  4. Dialogflow将“ [一些长文本]” 发送回服务器
  5. 服务器崩溃并返回一般错误500

如果我发送“等等等等”这样的请求,则默认回退意图也一样。

差异

Welcome意向不提供输出上下文,也不会重置上下文。 帮助意图确实提供了输出上下文。 后备意图不提供输出上下文,但会重置上下文。

我已验证,如果我为输出上下文提供了“欢迎”意图,则服务器将崩溃,并且如果我从“帮助”意图中删除了输出上下文,则一切正常。

问题

该项目正在做什么?为什么输出上下文使服务器崩溃?我该如何解决?

我当然不能仅仅从意图中删除输出上下文。

代码

MiniBatchKMeans

“欢迎”对话框流输出

<?php

namespace AppBundle\Controller;

use Ramsey\Uuid\Uuid;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\HttpFoundation\JsonResponse;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
use Google\Cloud\Dialogflow\V2\SessionsClient;
use Google\Cloud\Dialogflow\V2\TextInput;
use Google\Cloud\Dialogflow\V2\QueryInput;

class DefaultController extends Controller
{
    /**
     * @Route("/messenger", name="homepage")
     *
     */
    public function indexAction(Request $request)
    {
        return $this->render('@App/messenger.twig', array());
    }

    /**
     * @param Request $request
     *
     * @Route("/messenger/call/{intent}", options={"expose"=true}, name="call_assistant")
     * @throws \Google\ApiCore\ValidationException
     * @throws \Google\ApiCore\ApiException
     * @throws \Exception
     */
    public function callAssistantAction(Request $request, $intent) {
        $sessionDialogFlow = $this->get('session')->get('dialogFlow_session');
        if ($sessionDialogFlow === null) {
            $sessionDialogFlow = Uuid::uuid4()->toString();
            $this->get('session')->set('dialogFlow_session', $sessionDialogFlow);
        }

        $sessionClient = new SessionsClient(array(
            'credentials' => realpath($this->getParameter('kernel.root_dir'). "/../web/authentDialogFlow.json")
        ));

        $session = $sessionClient->sessionName("<my session name>", $sessionDialogFlow);
        $textInput = new TextInput();
        $textInput->setText($intent);
        $textInput->setLanguageCode('fr-FR');

        $queryInput = new QueryInput();
        $queryInput->setText($textInput);

        $response = $sessionClient->detectIntent($session, $queryInput); // <- this line is where the crash happens
        $queryResult = $response->getQueryResult();
        $fulfillmentText = $queryResult->getFulfillmentText();

        return new JsonResponse(array("response" => $fulfillmentText));
    }
}

“帮助”对话框流输出

{
  "queryText": "hey",
  "action": "input.welcome",
  "parameters": {},
  "fulfillmentText": "Salutations !",
  "fulfillmentMessages": [
    {
      "text": {
        "text": [
          "Salutations !"
        ]
      },
      "lang": "fr"
    }
  ],
  "intent": {
    "id": "<id>",
    "displayName": "Default Welcome Intent",
    "priority": 500000,
    "events": [
      "WELCOME"
    ],
    "action": "input.welcome",
    "messages": [
      {
        "text": {
          "text": [
            "Hi! How are you doing?",
            "Hello! How can I help you?",
            "Good day! What can I do for you today?",
            "Greetings! How can I assist?"
          ]
        },
        "lang": "en"
      },
      {
        "text": {
          "text": [
            "Salut !",
            "Bonjour !",
            "Salutations !",
            "Bienvenue !"
          ]
        },
        "lang": "fr"
      }
    ]
  },
  "intentDetectionConfidence": 1,
  "languageCode": "fr",
  "slotfillingMetadata": {
    "allRequiredParamsPresent": true
  },
  "id": "<id>",
  "sessionId": "<id>",
  "timestamp": "2019-07-15T07:41:28.778Z",
  "source": "agent",
  "webhookStatus": {
    "webhookEnabledForAgent": true
  },
  "agentEnvironmentId": {
    "agentId": "<id>",
    "cloudProjectId": "<id>"
  }
}

随时询问其他信息。

1 个答案:

答案 0 :(得分:1)

经过几天的苦闷,原来我的服务器缺少bcmath所需的PHP扩展google/protobuf。我在php.ini中启用了它,一切正常。

您可以找到有关Github问题的更多信息:https://github.com/googleapis/google-cloud-php/issues/2120