positus/positus-api-php-client 问题修复 & 功能扩展

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

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

positus/positus-api-php-client

最新稳定版本:0.1.0

Composer 安装命令:

composer require positus/positus-api-php-client

包简介

Client library for Positus APIs

README 文档

README

  • PHP 7.3+

Installing

Use Composer to install it:

composer require positus/positus-api-php-client

If you use Laravel, we provide a wrapper.

Instantiating

use Positus\Client;

$client = new Client();

Authentication

If you don't have an authentication token, click here to generate one.

$client = new Client();

$client->setToken('you-api-token');

Sending Messages

The first step to be able to send messages is to specify the ID number of origin:

$number = $client->number('your-number-id');

Then send the message and wait for a response.

If you want to test a Sandbox you can pass a second argument when calling the number method as true:

$number = $client->number('sandbox-number-id', true);

If you want to send a message using data on your own, you can use:

$response = $number->sendData([
    'to' => '+5511999999999',
    'type' => 'text',
    'text' => [
        'body' => 'Hi!'
    ]
]);

To check all the data that can be sent in each type of message, check the WhatsApp Business documentation.

If you prefer, we provide ready methods for each type of message.

Text

$response = $number->sendText('+5511999999999', 'Your message');

Template

$response = $number->sendTemplate('+5511999999999', 'namespace', 'name', 'languageCode', [
    "type" => "body",
    "parameters" => [
        [
            "type" => "text",
            "text" => "Param 1"
        ],
        ...
    ]
]);

Please check the documentation related to templates in the WhatsApp Business documentation.

Contacts

$response = $number->sendContacts('+5511999999999', [
    [
        'name' => [
            "formatted_name" => "John Doe"
        ],
        'phones' => [
            'phone' => '+5511888888888',
            'type' => 'CELL'
        ]
    ]
]);

Please check the documentation related to contacts in the WhatsApp Business documentation.

Location

$response = $number->sendLocation('+5511999999999', '-23.553885', '-46.662819', 'Robbu - Atendimento digital inteligente', 'Av. Angélica, 2530 - Bela Vista, São Paulo - SP, 01228-200');

Image

$response = $number->sendImage('+5511999999999', 'https://example.com/image.jpg', 'Random Image');

Document

$response = $number->sendDocument('+5511999999999', 'https://example.com/document.pdf', 'Random Document');

Video

$response = $number->sendVideo('+5511999999999', 'https://example.com/video.mp4', 'Random Video');

Audio

$response = $number->sendAudio('+5511999999999', 'https://example.com/audio.mp3');

Receiving media

To download a media, use the following method:

$response = $number->getMedia('media-id');

Responses

After any call you can check if everything went well and receive the data using the following methods:

if ($response->success()) {
    echo 'Message with Id ' . $response->json()->messages[0]->id . ' sent successfully';
}

If everything goes correctly you will receive an answer like this:

{
    "messages": [
        {
            "id": "gBEGVUOWQWWQAgnFOaNl67sTDIE"
        }
    ],
    "message": "The message was successfully sent"
}

If something goes wrong, you will receive a message detailing the errors:

{
    "errors": [
        {
            "code": 1008,
            "title": "Required parameter is missing",
            "details": "Parameter 'body' is mandatory for type 'text'"
        }
    ],
    "message": "Unfortunately we were not able to send your message"
}

Please check all possible errors that the api may return in the WhatsApp Business documentation.

Feel free to create a pull request or open a support ticket in Positus Studio if you have or find any problems.

You can check if it failed:

if ($response->error()) {
    echo 'Something went wrong';
}

If you only need the status code:

$response->status();

You can get the answer from api as a string:

$response->body();

Or if you prefer as JSON:

$response->json();

Or if you prefer as object:

$response->object();

You can get a header:

$response->header('Content-Type');

Or you can get all headers:

$response->headers();

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2020-07-16