承接 fcritic/amojo-api-client 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

fcritic/amojo-api-client

最新稳定版本:v1.4.0

Composer 安装命令:

composer require fcritic/amojo-api-client

包简介

PHP client for the amoCRM chat API service

README 文档

README

amoJo PHP Client

amoJo PHP Client

🚀 PHP клиент для интеграции с сервисом API чатов amoCRM

Версия Загрузки Версия PHP License

Содержание

✨ Возможности

  • Полное покрытие API чатов amoCRM
  • Строгая типизация данных через DTO
  • Гибкая система Middleware
  • Предсказуемые данные в WebHooks
  • Поддержка сегментов .ru и .com
  • Подробная обработка ошибок
  • Инструменты разработчика
    • Строгая типизация (strict_types)
    • PSR-12 совместимый код
    • Полная документация PHPDoc
    • Поддержка Guzzle и PSR-18

📦 Установка

Установка через Composer:

composer require fcritic/amojo-api-client

Требования:

  • PHP 7.4+

🚀 Быстрый старт

Управление каналами

1. Подключение канала
use AmoJo\Client\AmoJoClient;
use AmoJo\Models\Channel;

$channel = new Channel(uuid: 'channel-uuid', secretKey: 'secret-key');
$client = new AmoJoClient(
    channel: $channel,
    additionalMiddleware: [],
    segment: 'ru'
);

$response = $client->connect(
    accountUuid: 'f36b8c48-ed97-4866-8aba-d55d429da86d',
    title: 'Мой канал',
    hookVersion: 'v2'
);

echo 'Scope ID: ' . $response->getScopeId();
2. Отключение канала
$client->disconnect(accountUuid: 'f36b8c48-ed97-4866-8aba-d55d429da86d');

Работа с чатами

1. Создание чата
use AmoJo\Models\Conversation;
use AmoJo\Models\Users\Sender;

$conversation = (new Conversation())->setId('chat-123');
$contact = (new Sender())
    ->setId('user-123')
    ->setName('Иван Иванов')
    ->setAvatar('https://picsum.photos/300/300')
    ->setProfile((new UserProfile())->setPhone('+1464874556719'));

$response = $client->createChat(
    accountUuid: 'f36b8c48-ed97-4866-8aba-d55d429da86d',
    conversation: $conversation,
    contact: $contact
);

echo 'ID чата в API чатов: ' . $response->getConversationRefId();

Работа с сообщениями

1. Входящие текстовое сообщение
use AmoJo\Models\Payload;
use AmoJo\Models\Messages\TextMessage;

$message = (new TextMessage())->setUuid('MSG_100')->setText('Hello');

$response = $client->sendMessage(
    accountUuid: 'f36b8c48-ed97-4866-8aba-d55d429da86d',
    payload: (new Payload())
        ->setConversation($conversation)
        ->setSender($contact)
        ->setMessage($message),
    externalId: 'Источник'
);

echo 'ID чата в API чатов: ' . $response->getReceiverRefId();
2. Исходящие текстовое сообщение
use AmoJo\Models\Users\Receiver;

// amojo_id пользователя amoCRM
$sender = (new Sender())->setRefId('113de373-a2d3-4eb7-a67c-04660332df07');
$message = (new TextMessage())->setUuid('MSG_101')->setText('Hello');

$response = $client->sendMessage(
    accountUuid: 'f36b8c48-ed97-4866-8aba-d55d429da86d',
    payload: (new Payload())
        ->setConversation($conversation)
        ->setSender($sender)
        ->setReceiver($contact)
        ->setMessage($message),
    externalId: 'Источник'
);
3. Редактирование сообщения
$message = (new TextMessage())->setUuid('MSG_101')->setText('Hello, Richard');

$response = $client->editMessage(
    accountUuid: 'f36b8c48-ed97-4866-8aba-d55d429da86d',
    (new Payload())
        ->setConversation($conversation)
        ->setMessage($message)
);
4. Ответ на сообщения
use AmoJo\Models\Messages\ReplyTo;

$message = (new TextMessage())->setUuid('MSG_102')->setText('I want to place an order');

$response = $client->sendMessage(
    accountUuid: 'f36b8c48-ed97-4866-8aba-d55d429da86d',
    payload: (new Payload())
        ->setConversation($conversation)
        ->setSender($contact)
        ->setMessage($message)
        ->setReplyTo((new ReplyTo())->setReplyUuid('MSG_101'))
);

Дополнительные функции

1. История чата
$response = $client->getHistoryChat(
    accountUuid: 'f36b8c48-ed97-4866-8aba-d55d429da86d',
    conversationRefId: $conversation->getRefId()
);

foreach ($response->getMessages() as $message) {
    echo 'Текст сообщения: ' . $message->getMessage()->getText();
}
2. Обновление статуса доставки
use AmoJo\Enum\DeliveryStatus;
use AmoJo\Enum\ErrorCode;
use AmoJo\Models\Deliver;

$client->deliverStatus(
    accountUuid: 'f36b8c48-ed97-4866-8aba-d55d429da86d',
    messageUuid: $message->getRefUuid(),
    deliver: (new Deliver(DeliveryStatus::ERROR))
        ->setErrorCode(ErrorCode::WITH_DESCRIPTION)
        ->setMessageError('User deleted')
);
3. Отправка или снятие реакции
$client->react(
    accountUuid: 'f36b8c48-ed97-4866-8aba-d55d429da86d',
    conversation: $conversation,
    sender: $contact,
    message: $message,
    emoji: '👍'
);
4. Информации о печатание
$client->typing(
    accountUuid: 'f36b8c48-ed97-4866-8aba-d55d429da86d',
    conversation: $conversation,
    sender: $contact,
);

🔌 Кастомные middleware

Пример middleware для логирования запросов:
use AmoJo\Middleware\MiddlewareInterface;
use Psr\Http\Message\RequestInterface;
use Psr\Log\LoggerInterface;
use Closure;

final class LoggingMiddleware implements MiddlewareInterface
{
    public function __invoke(callable $handler): Closure
    {
        return function (RequestInterface $request, array $options) use ($handler) {
            error_log('Request: ' . $request->getMethod() . ' ' . $request->getUri());
            return $handler($request, $options);
        };
    }
}
Подключение middleware:
$client = new AmoJoClient(
    channel: $channel,
    additionalMiddleware: [LoggingMiddleware::class]
);

📢 Обработка ошибок

Клиент выбрасывает исключения при ошибках:

  • AmoJoException - Базовое исключение
  • EmptyMessageErrorException - Не передано сообщение об ошибки при 905 коде ошибке deliverStatus()
  • InvalidRequestWebHookException - не валидном вебхуке об исходящим сообщении
  • InvalidResponseException - Некорректный ответ сервера
  • NotFountException - некорректный URL запроса
  • RequiredParametersMissingException - Отсутствуют обязательные параметры
  • SenderException - Не был передан ID внутреннего пользователя при исходящим сообщение
  • UnsupportedMessageTypeException - Передано неподдерживаемый типа сообщения

Пример обработки:

try {
    // Вызов API метода
} catch (RequiredParametersMissingException $e) {
    echo "Ошибка: " . $e->getMessage();
} catch (AmoJoException $e) {
    var_dump([
        'type'    => $e->getType(),
        'message' => $e->getMessage(),
        'code'    => $e->getCode(),
        'context' => $e->getContext(),
        'file'    => $e->getFile(),
    ]);
}

🔐 Работа с WebHooks

1. Валидация WebHooks
use AmoJo\Webhook\ValidatorHook;

if (!ValidatorHook::isValid(request: $request, secretKey: '465c28d756f...')) {
    // Обработка не валидного вебхука
}
2. Строгая типизация данных полученных из WebHooks amoCRM
use AmoJo\Webhook\AmoJoHookFactory;

$event = (new AmoJoHookFactory())->fromArray($requestBody);
        
var_dump($event->toArray());

📝 Документация

Официальная документация API чатов amoCRM:

📄 Лицензия

Проект распространяется под лицензией MIT - подробности в файле LICENSE

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-02-13