jolti/freshchat_sdk 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

jolti/freshchat_sdk

Composer 安装命令:

composer require jolti/freshchat_sdk

包简介

A PHP SDK to use Freschat Chatbot API Service

README 文档

README

Create a PHP SDK to interact with Freshchat API

Documentation

The project is based on the documentation described in https://developers.freshchat.com/api

Installation

first install composer dependencies

composer install 

secondly copy .env.example file to .env and change the property API_TOKEN with you Freshchat api token

Example usage

let assume you want to send a message when a user send a message to your Bot, the WebhookController is an example of a controller to handle freshchat message notification (webhooks) 1.First we have to get the message from the incoming request sent by freshchat server , the class MessageResponseFactory can be used to build a message instance from a request

$messageResponseFactory = new MessageResponseFactory($request->getContent());
/**
* message webhook sent by Freshchat server
* @var Message
*/
$messageResponse = $messageResponseFactory->getMessage();

the variable messageResponse contains all the message properties.

2.Create new Conversation and set the id to the id of the messageResponse Conversation so our message will be send just to the user that contact us.

$conversation = new Conversation();
$conversation->setId($messageResponse->getConversationId());
  1. Create a new Message , each message has an actor (agent) Id described in Freshchat documentation , in this example we will get our agents and set the first agent as the agent of our message
    getting first agent :
$agents = new Agent();
$agentsFromApi = $agents->getAgents();

$agentFactory = new AgentFactory();

/**
* @var array<Agent>
*/
 $agents = $agentFactory->build($agentsFromApi);

$defaultActorId = $agents[0]->getId();

creating new Message and setting the Agent

$message = new Message();
$message->setActorId($defaultActorId);
  1. Adding Message parts ,message parts has diffrent types text, images ,buttons.in this specific example we will add two parts a text and a image
$imageType = new ImageType();
$imageType->setResource($image_url);

$textType = new TextType();
$textType->setResource("Hi sir ,welcome to the World Cup");

$message->addMultipleParts([$imageType, $textType]);

5.Send the message , before sending the message you can check first if the incoming message is a UserMessage , we don't want to send a message if another agent send message (in this case)

if ($messageResponse->isUserMessage()) {
  $conversation->sendMessage($message);
}

New Features

  • Add integration testing for sending a message , getting agents
  • Add other supported Freshchat message Types buttons
  • Add api call to get all messages of a conversation (can be used to handle chatbot workflow)

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 2
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-01-22

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固