davidniki02 / api-ai-php
API.ai php sdk
0.2.5
2016-08-20 08:27 UTC
Requires
- php: >=5.5.0
- guzzlehttp/guzzle: ^6.2
This package is not auto-updated.
Last update: 2025-06-28 00:08:25 UTC
README
This is fork of the unofficial php sdk for Api.ai - iboldurev/api-ai-php
In this fork, we have added the ability to create, update and delete intents. Specifically, it now has a better support for POST queries as well as PUT and DELETE verbs.
Api.ai: Build brand-unique, natural language interactions for bots, applications and devices.
Install:
Via composer:
$ composer require davidniki02/api-ai-php
Usage:
Using the low level Client
:
require_once __DIR__.'/vendor/autoload.php'; use ApiAi\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(); }
Creating a sample intent with a context:
private function createIntent($context, $issue, $response){ try { $client = new \ApiAi\Client('<developer token>'); $query = $client->post('intents', [ "name" => "issue name", "auto" => true, "templates" => [ $issue ], "contexts" => [ $context ], "userSays" => [ [ "data" => [ ["text" => $issue] ], "isTemplate" => false, "count" => 0 ], ], "responses" => [ ["speech" => $response] ] ]); $r = json_decode((string) $query->getBody(), true); if ($r['status']['code'] != "200") return false; return $r; } catch (\Exception $error) { return false; } }
Usage:
Using the low level Query
:
require_once __DIR__.'/vendor/autoload.php'; use ApiAi\Client; use ApiAi\Model\Query; use ApiAi\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(); }
Dialog
The Dialog
class provides an easy way to use the query
api and execute automatically the chaining steps :
First, you need to create an ActionMapping
class to customize the actions behavior.
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; } }
And using it in the Dialog
class.
require_once __DIR__.'/vendor/autoload.php'; use ApiAi\Client; use ApiAi\Method\QueryApi; use ApiAi\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(); }
Some examples are describe in the davidniki02/api-ai-php-example repository.