WhatsAppAdapter
in package
implements
Adapter, AdapterHasMessagingWindow, HandlesBatchedWebhooks, HandlesReactions, HandlesSlashCommands, HandlesStatuses, HasAuthorInfo
Table of Contents
Interfaces
- Adapter
- AdapterHasMessagingWindow
- HandlesBatchedWebhooks
- HandlesReactions
- HandlesSlashCommands
- HandlesStatuses
- HasAuthorInfo
Properties
- $accessToken : string
- $apiUrl : string
- $botUserId : string|null
- $fileUploadConverter : FileUploadConverter
- $formatConverter : WhatsAppFormatConverter
- $httpClient : ClientInterface
- $phoneNumberId : string
- $psrFactory : Psr17Factory|null
- $state : StateAdapter|null
- $webhookVerifier : WhatsAppWebhookVerifier|null
Methods
- __construct() : mixed
- addReaction() : void
- channelIdFromThreadId() : string
- createResponse() : ResponseInterface|null
- decodeThreadId() : mixed
- deleteMessage() : void
- disconnect() : void
- editMessage() : SentMessage
- encodeThreadId() : string
- fetchChannelInfo() : ChannelInfo|null
- fetchMessages() : FetchResult
- fetchThread() : ThreadInfo
- getAuthorInfo() : Author
- getBotUserId() : string|null
- getFormatConverter() : FormatConverter|null
- getMessagingWindowSeconds() : int|null
- getName() : string
- getTrackingKey() : string
- Return a stable tracking key for the conversation from a thread ID.
- getUser() : UserInfo|null
- initialize() : void
- openDM() : string|null
- parseBatchedWebhook() : array<string|int, WebhookEvent>
- Parse ALL events from a potentially-batched webhook payload.
- parseReaction() : Author, emoji: string, rawEmoji: string, added: bool, threadId: string, messageId: string, userId: string, raw: mixed, originId: ?string}|null
- parseSlashCommand() : Author, command: string, text: string, userId: string, isBot: bool, isMe: bool, channelId: string, triggerId: ?string, raw: mixed}|null
- parseStatus() : array{type: "delivered"|"read"|"failed", messageIds: string[], threadId: string, userId: string, raw: mixed, timestamp: ?int, originId: ?string}|null
- parseWebhook() : Message
- postMessage() : SentMessage
- removeReaction() : void
- startTyping() : void
- stream() : SentMessage|null
- verifyWebhook() : ResponseInterface|null
- addRecipientParam() : array<string|int, mixed>
- apiCall() : array<string|int, mixed>
- buildMessageParams() : array<string|int, mixed>
- createAuthor() : Author
- extractAttachments() : array<string|int, Attachment>
- parseInboundMessage() : Message
Properties
$accessToken read-only
protected
string
$accessToken
$apiUrl read-only
protected
string
$apiUrl
= 'https://graph.facebook.com/v21.0'
$botUserId
protected
string|null
$botUserId
= null
$fileUploadConverter
protected
FileUploadConverter
$fileUploadConverter
$formatConverter
protected
WhatsAppFormatConverter
$formatConverter
$httpClient read-only
protected
ClientInterface
$httpClient
$phoneNumberId read-only
protected
string
$phoneNumberId
$psrFactory read-only
protected
Psr17Factory|null
$psrFactory
= null
$state
protected
StateAdapter|null
$state
= null
$webhookVerifier
protected
WhatsAppWebhookVerifier|null
$webhookVerifier
= null
Methods
__construct()
public
__construct(string $accessToken, ClientInterface $httpClient, string $phoneNumberId[, string|null $appSecret = null ][, string|null $verifyToken = null ][, string $apiUrl = 'https://graph.facebook.com/v21.0' ][, Psr17Factory|null $psrFactory = null ][, FileUploadConverter|null $fileUploadConverter = null ]) : mixed
Parameters
- $accessToken : string
- $httpClient : ClientInterface
- $phoneNumberId : string
- $appSecret : string|null = null
- $verifyToken : string|null = null
- $apiUrl : string = 'https://graph.facebook.com/v21.0'
- $psrFactory : Psr17Factory|null = null
- $fileUploadConverter : FileUploadConverter|null = null
addReaction()
public
addReaction(string $threadId, string $messageId, string $emoji) : void
Parameters
- $threadId : string
- $messageId : string
- $emoji : string
channelIdFromThreadId()
public
channelIdFromThreadId(string $threadId) : string
Parameters
- $threadId : string
Return values
stringcreateResponse()
public
createResponse() : ResponseInterface|null
Return values
ResponseInterface|nulldecodeThreadId()
public
decodeThreadId(string $threadId) : mixed
Parameters
- $threadId : string
deleteMessage()
public
deleteMessage(string $threadId, string $messageId) : void
Parameters
- $threadId : string
- $messageId : string
disconnect()
public
disconnect() : void
editMessage()
public
editMessage(string $threadId, string $messageId, PostableMessage $message) : SentMessage
Parameters
- $threadId : string
- $messageId : string
- $message : PostableMessage
Return values
SentMessageencodeThreadId()
public
encodeThreadId(mixed $platformData) : string
Parameters
- $platformData : mixed
Return values
stringfetchChannelInfo()
public
fetchChannelInfo(string $channelId) : ChannelInfo|null
Parameters
- $channelId : string
Return values
ChannelInfo|nullfetchMessages()
public
fetchMessages(string $threadId[, FetchOptions|null $options = null ]) : FetchResult
Parameters
- $threadId : string
- $options : FetchOptions|null = null
Return values
FetchResultfetchThread()
public
fetchThread(string $threadId) : ThreadInfo
Parameters
- $threadId : string
Return values
ThreadInfogetAuthorInfo()
public
getAuthorInfo(Author $author) : Author
Parameters
- $author : Author
Return values
AuthorgetBotUserId()
public
getBotUserId() : string|null
Return values
string|nullgetFormatConverter()
public
getFormatConverter() : FormatConverter|null
Return values
FormatConverter|nullgetMessagingWindowSeconds()
public
getMessagingWindowSeconds() : int|null
Return values
int|nullgetName()
public
getName() : string
Return values
stringgetTrackingKey()
Return a stable tracking key for the conversation from a thread ID.
public
getTrackingKey(string $threadId) : string
Used as the storage key for the last-seen timestamp.
Parameters
- $threadId : string
Return values
stringgetUser()
public
getUser(string $userId) : UserInfo|null
Parameters
- $userId : string
Return values
UserInfo|nullinitialize()
public
initialize(Chat $chat) : void
Parameters
- $chat : Chat
openDM()
public
openDM(string $userId) : string|null
Parameters
- $userId : string
Return values
string|nullparseBatchedWebhook()
Parse ALL events from a potentially-batched webhook payload.
public
parseBatchedWebhook(ServerRequestInterface $request) : array<string|int, WebhookEvent>
Unlike the individual parseXxx() methods which return on the first match, this method iterates every entry/event and returns all of them for the Chat to dispatch individually.
Parameters
- $request : ServerRequestInterface
Return values
array<string|int, WebhookEvent>parseReaction()
public
parseReaction(ServerRequestInterface $request) : Author, emoji: string, rawEmoji: string, added: bool, threadId: string, messageId: string, userId: string, raw: mixed, originId: ?string}|null
Parameters
- $request : ServerRequestInterface
Return values
Author, emoji: string, rawEmoji: string, added: bool, threadId: string, messageId: string, userId: string, raw: mixed, originId: ?string}|nullparseSlashCommand()
public
parseSlashCommand(ServerRequestInterface $request) : Author, command: string, text: string, userId: string, isBot: bool, isMe: bool, channelId: string, triggerId: ?string, raw: mixed}|null
Parameters
- $request : ServerRequestInterface
Return values
Author, command: string, text: string, userId: string, isBot: bool, isMe: bool, channelId: string, triggerId: ?string, raw: mixed}|nullparseStatus()
public
parseStatus(ServerRequestInterface $request) : array{type: "delivered"|"read"|"failed", messageIds: string[], threadId: string, userId: string, raw: mixed, timestamp: ?int, originId: ?string}|null
Parameters
- $request : ServerRequestInterface
Return values
array{type: "delivered"|"read"|"failed", messageIds: string[], threadId: string, userId: string, raw: mixed, timestamp: ?int, originId: ?string}|nullparseWebhook()
public
parseWebhook(ServerRequestInterface $request) : Message
Parameters
- $request : ServerRequestInterface
Return values
MessagepostMessage()
public
postMessage(string $threadId, PostableMessage $message) : SentMessage
Parameters
- $threadId : string
- $message : PostableMessage
Return values
SentMessageremoveReaction()
public
removeReaction(string $threadId, string $messageId, string $emoji) : void
Parameters
- $threadId : string
- $messageId : string
- $emoji : string
startTyping()
public
startTyping(string $threadId) : void
Parameters
- $threadId : string
stream()
public
stream(string $threadId, iterable<string|int, mixed> $textStream[, array<string|int, mixed> $options = [] ]) : SentMessage|null
Parameters
- $threadId : string
- $textStream : iterable<string|int, mixed>
- $options : array<string|int, mixed> = []
Return values
SentMessage|nullverifyWebhook()
public
verifyWebhook(ServerRequestInterface $request) : ResponseInterface|null
Parameters
- $request : ServerRequestInterface
Return values
ResponseInterface|nulladdRecipientParam()
protected
addRecipientParam(array<string|int, mixed> $params, string $userWaId) : array<string|int, mixed>
Parameters
- $params : array<string|int, mixed>
- $userWaId : string
Return values
array<string|int, mixed>apiCall()
protected
apiCall(string $endpoint, array<string|int, mixed> $params) : array<string|int, mixed>
Parameters
- $endpoint : string
- $params : array<string|int, mixed>
Return values
array<string|int, mixed>buildMessageParams()
protected
buildMessageParams(PostableMessage $message) : array<string|int, mixed>
Parameters
- $message : PostableMessage
Return values
array<string|int, mixed>createAuthor()
protected
createAuthor(string $userId, array<string, mixed>|null $contact) : Author
Parameters
- $userId : string
- $contact : array<string, mixed>|null
Return values
AuthorextractAttachments()
protected
extractAttachments(array<string|int, mixed> $msg) : array<string|int, Attachment>
Parameters
- $msg : array<string|int, mixed>
Return values
array<string|int, Attachment>parseInboundMessage()
protected
parseInboundMessage(array<string|int, mixed> $msg, array<string|int, mixed>|null $contact, string $phoneNumberId, string $rawBody[, string|null $originId = null ]) : Message
Parameters
- $msg : array<string|int, mixed>
- $contact : array<string|int, mixed>|null
- $phoneNumberId : string
- $rawBody : string
- $originId : string|null = null