iboldurev / dialogflow
Dialogflow php sdk
0.3.0
2017-10-27 19:44 UTC
Requires
- php: >=5.5.0
- guzzlehttp/guzzle: ^6.2
This package is auto-updated.
Last update: 2024-09-10 21:08:45 UTC
README
这是一个Dialogflow的非官方php SDK,仍在开发中...
Dialogflow: Build brand-unique, natural language interactions for bots, applications and devices.
安装
通过composer
$ composer require iboldurev/dialogflow
使用方法
使用低级Client
require_once __DIR__.'/vendor/autoload.php'; use DialogFlow\Client; try { $client = new Client('access_token'); $query = $client->get('query', [ 'query' => 'Hello', ]); $response = json_decode((string) $query->getBody(), true); } catch (\Exception $error) { echo $error->getMessage(); }
使用方法
使用低级Query
require_once __DIR__.'/vendor/autoload.php'; use DialogFlow\Client; use DialogFlow\Model\Query; use DialogFlow\Method\QueryApi; try { $client = new Client('access_token'); $queryApi = new QueryApi($client); $meaning = $queryApi->extractMeaning('Hello', [ 'sessionId' => '1234567890', 'lang' => 'en', ]); $response = new Query($meaning); } catch (\Exception $error) { echo $error->getMessage(); }
使用方法
使用低级异步API
require_once __DIR__.'/vendor/autoload.php'; use DialogFlow\Client; use DialogFlow\Model\Query; use DialogFlow\Method\QueryApi; use GuzzleHttp\HandlerStack; use React\EventLoop\Factory; use WyriHaximus\React\GuzzlePsr7\HttpClientAdapter; $loop = Factory::create(); $reactGuzzle = new \GuzzleHttp\Client([ 'base_uri' => Client::API_BASE_URI . Client::DEFAULT_API_ENDPOINT, 'timeout' => Client::DEFAULT_TIMEOUT, 'connect_timeout' => Client::DEFAULT_TIMEOUT, 'handler' => HandlerStack::create(new HttpClientAdapter($loop)) ]); $client = new Client('bc0a6d712bba4b3c8063a9c7ff0fa4ea', new DialogFlow\HttpClient\GuzzleHttpClient($reactGuzzle)); $queryApi = new QueryApi($client); $queryApi->extractMeaningAsync('Hello', [ 'sessionId' => '123456789', 'lang' => 'en' ])->then( function ($meaning) { $response = new Query($meaning); }, function ($error) { echo $error; } ); $loop->run();
对话
Dialog
类提供了一种简单的方式使用query
API并自动执行链式步骤
首先,您需要创建一个ActionMapping
类来自定义动作的行为。
namespace Custom; class MyActionMapping extends ActionMapping { /** * @inheritdoc */ public function action($sessionId, $action, $parameters, $contexts) { return call_user_func_array(array($this, $action), array($sessionId, $parameters, $contexts)); } /** * @inheritdoc */ public function speech($sessionId, $speech, $contexts) { echo $speech; } /** * @inheritdoc */ public function error($sessionId, $error) { echo $error; } }
然后在Dialog
类中使用它。
require_once __DIR__.'/vendor/autoload.php'; use DialogFlow\Client; use DialogFlow\Method\QueryApi; use DialogFlow\Dialog; use Custom\MyActionMapping; try { $client = new Client('access_token'); $queryApi = new QueryApi($client); $actionMapping = new MyActionMapping(); $dialog = new Dialog($queryApi, $actionMapping); // Start dialog .. $dialog->create('1234567890', 'Привет', 'ru'); } catch (\Exception $error) { echo $error->getMessage(); }