承接 ka4ivan/laravel-notification-channel-whatsapp 相关项目开发

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

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

ka4ivan/laravel-notification-channel-whatsapp

最新稳定版本:1.3.0

Composer 安装命令:

composer require ka4ivan/laravel-notification-channel-whatsapp

包简介

Whatsapp Notifications Channel for Laravel

README 文档

README

License Build Status Latest Stable Version Total Downloads

This package makes it easy to send notifications using the Whatsapp Messenger with Laravel.

Contents

Installation

You can install the package via composer:

composer require ka4ivan/laravel-notification-channel-whatsapp

Setting up your Whatsapp Bot

This document describes the steps you must take to become a Tech Provider Whatsapp

Set config

Next we need to add tokens to our Laravel configurations. Create a new Whatsapp section inside config/services.php and place the page token there:

// config/services.php
'whatsapp' => [
    'access_token' => env('WHATSAPP_ACCESS_TOKEN', ''),
    'number_id' => env('WHATSAPP_NUMBER_ID', ''),
    'api_version' => env('WHATSAPP_API_VERSION', '22.0'),
],

Usage

You can now use the Whatsapp channel in your via() method, inside the InvoicePaid class. The to($recipientId) Whatsapp ID (Phone Number) method defines the Whatsapp user, you want to send the notification to.

use NotificationChannels\Whatsapp\WhatsappChannel;
use NotificationChannels\Whatsapp\WhatsappMessage;

use Illuminate\Notifications\Notification;

class ChannelConnected extends Notification
{
    public function via($notifiable)
    {
        return [WhatsappChannel::class];
    }

    public function toWhatsapp($notifiable)
    {
        $apiVersion = config('services.whatsapp.api_version');
        $accessToken = config('services.whatsapp.access_token');
        $numberId = config('services.whatsapp.number_id');

        return WhatsappMessage::create()
            ->to($notifiable->whatsapp_id)  // Optional
            ->setApiVersion($apiVersion)    // Optional
            ->setAccessToken($accessToken)  // Optional
            ->setNumberId($numberId)        // Optional
            ->previewUrl(false)             // Optional
            ->text('Congratulations, the communication channel is connected');
    }
}

The notification will be sent from your Whatsapp page, whose page token you have configured earlier. Here's a screenshot preview of the notification inside the chat window.

image

Message Examples

Basic Text Message
return WhatsappMessage::create('You have just paid your monthly fee! Thanks');

Routing a message

You can either send the notification by providing with the page-scoped user id of the recipient to the to($recipientId) Whatsapp ID (Phone Number) method like shown in the above example or add a routeNotificationForWhatsapp() method in your notifiable model:

/**
 * Route notifications for the Whatsapp channel.
 *
 * @return int
 */
public function routeNotificationForWhatsapp()
{
    return $this->whatsapp_id;
}

Types of messages

Audio Message

  • to($recipientId): (string) User (recipient) Whatsapp ID (Phone Number).
  • mediaId(''): (string) Whatsapp media ID (Only if using uploaded media)
  • link(''): (string) Media link (Only if using hosted media (not recommended))
WhatsappAudioMessage::create()
    ->link('audio url');

Call-To-Action (CTA URL) Message

  • to($recipientId): (string) User (recipient) Whatsapp ID (Phone Number).
  • body(''): (string) Message body text.
  • header(null): (Header) Message header object. (ButtonCtaUrlImageHeader/ButtonCtaUrlTitleHeader)
  • footer(''): (string) Message footer text.
  • button(): (ButtonCtaUrl) Message button object.
WhatsappCtaUrlMessage::create()
    ->header(ButtonCtaUrlTitleHeader::create()->title('header text'))
    ->body('body text')
    ->footer('footer text')
    ->button(ButtonCtaUrl::create()->displayText('button text')->url('button url'));

Document Message

  • to($recipientId): (string) User (recipient) Whatsapp ID (Phone Number).
  • caption(''): (string) Notification caption.
  • filename(''): (string) Document filename, with extension. The WhatsApp client will use an appropriate file type icon based on the extension.
  • mediaId(''): (string) Whatsapp media ID (Only if using uploaded media)
  • link(''): (string) Whatsapp media link (Only if using hosted media (not recommended))
WhatsappDocumentMessage::create()
    ->caption('file caption')
    ->filename('file name')
    ->link('file url');

Image Message

  • to($recipientId): (string) User (recipient) Whatsapp ID (Phone Number).
  • caption(''): (string) Notification caption.
  • mediaId(''): (string) Whatsapp media ID (Only if using uploaded media)
  • link(''): (string) Whatsapp media link (Only if using hosted media (not recommended))
WhatsappImageMessage::create()
    ->caption('image caption')
    ->link('image url');

Location Message

  • to($recipientId): (string) User (recipient) Whatsapp ID (Phone Number).
  • latitude(''): (string) The geographic latitude of the location (e.g., '50.4501').
  • longitude(''): (string) The geographic longitude of the location (e.g., '30.5234').
  • name(''): (string) The name or label of the location (e.g., 'Independence Square').
  • address(''): (string) The full address (optional), displayed under the name (e.g., 'Khreshchatyk St, Kyiv, Ukraine').
WhatsappLocationMessage::create('latitude', 'longitude')
    ->address('address text')
    ->name('name text');

Location Request Message

  • to($recipientId): (string) User (recipient) Whatsapp ID (Phone Number).
  • body(''): (string) Message body text.
WhatsappLocationRequestMessage::create('Location, pls');

Text Message

  • to($recipientId): (string) User (recipient) Whatsapp ID (Phone Number).
  • text(''): (string) Notification message.
  • previewUrl(true): (boolean) Link Preview.
  • setApiVersion($apiVersion): (string) Set Default Graph API Version.
  • setAccessToken($accessToken): (string) Set the access token used for authenticating API requests.
  • setNumberId($numberId): (string) Set the Whatsapp number ID for API requests.
WhatsappMessage::create('Your order has been confirmed!');

Reaction

  • to($recipientId): (string) User (recipient) Whatsapp ID (Phone Number).
  • emoji(''): (string) Emoji reaction. Unicode escape sequence example: \uD83D\uDE00. Emoji example: 😀
  • messageId(''): (string) Whatsapp Message ID
WhatsappReaction::create()
    ->emoji('😊')
    ->messageId('Whatsapp message ID');

Reply Buttons Message

  • to($recipientId): (string) User (recipient) Whatsapp ID (Phone Number).
  • body(''): (string) Message body text.
  • header(null): (Header) Message header object. (ButtonCtaUrlImageHeader/ButtonCtaUrlTitleHeader)
  • footer(''): (string) Message footer text.
  • buttons([]): (array) Message buttons array [ButtonReply, ButtonReply, ButtonReply].
WhatsappButtonReplyMessage::create()
    ->header(ButtonReplyTitleHeader::create()->title('header text'))
    ->body('body text')
    ->footer('footer text')
    ->buttons([
        ButtonReply::create()->id('button id 1')->title('button title 1'),
        ButtonReply::create()->id('button id 2')->title('button title 2'),
        ButtonReply::create()->id('button id 3')->title('button title 3'),
    ]);

Video Message

  • to($recipientId): (string) User (recipient) Whatsapp ID (Phone Number).
  • caption(''): (string) Notification caption.
  • mediaId(''): (string) Whatsapp media ID (Only if using uploaded media)
  • link(''): (string) Whatsapp media link (Only if using hosted media (not recommended))
WhatsappVideoMessage::create()
    ->caption('video caption')
    ->link('video url');

Sending multiple messages

If you need to send multiple files (regardless of the message type)

/**
 * @param $notifiable
 * @return \NotificationChannels\Whatsapp\Message|array
 * @throws \NotificationChannels\Whatsapp\Exceptions\CouldNotCreateMessage
 */
public function toWhatsApp($notifiable)
{
    $text = 'text';

    $files = $this->getFiles();

    if (!empty($files)) {
        $messages = [];

        $first = true;
        foreach ($files as $url => $name) {
            $message = WhatsappDocumentMessage::create()
                ->link($url)
                ->filename(Str::substr($name, -32));

            if ($first) {
                $message->caption($text);
                $first = false;
            }

            $messages[] = $message;
        }

        return $messages;
    }

    return WhatsappMessage::create()->text($text);
}

Contributing

Please see CONTRIBUTING for details.

License

The MIT License (MIT). Please see License File for more information.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-05-16