リアクション・メッセージを送る
このコードでは、Messages API を使って WhatsApp リアクションメッセージを送信する方法を説明します。WhatsApp reaction メッセージタイプでは、受信したメッセージに絵文字で反応することができます。
と同様に to そして from Numbersでは、このメッセージタイプには2つの重要な情報が必要です:
- について
message_uuid反応するメッセージのこれは受信したインバウンド・メッセージのボディに存在する。 - について
emojiをリアクションとして使用します。これは例えば😀のような絵文字そのものでもかまいません。
重要: メッセージ未送信の場合、WhatsAppは初回メッセージ送信時にテンプレートを要求します。詳しくは WhatsAppトピックの理解.
例
各コード・スニペットで使用されているすべての変数の説明を以下に示します:
| キー | 説明 |
|---|---|
JWT | Used to authenticate your request. See Authentication for more information, including how to generate a JWT. |
VONAGE_APPLICATION_ID | The Vonage Application ID. |
VONAGE_PRIVATE_KEY_PATH | Private key path. |
MESSAGES_API_URL | There are two versions of the API, each with their own endpoints. For production the previous Messages API endpoint was |
WHATSAPP_NUMBER | The WhatsApp number that has been allocated to you by Vonage. For sandbox testing the number is 14157386102. |
TO_NUMBER | Replace with the number you are sending to. E.g. |
MESSAGE_UUID | The UUID of the specific message. |
EMOJI | The emoji to send in the message. |
注: 先頭の + または 00 電話番号を入力する場合は、447700900000のように国番号から入力してください。
Prerequisites
If you do not have an application you can create one. Make sure you also configure your webhooks.
Write the code
Add the following to send-reaction.sh:
curl -X POST "${MESSAGES_API_URL}" \
-H "Authorization: Bearer "$JWT\
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-d $'{
"to": "'${MESSAGES_TO_NUMBER}'",
"from": "'${WHATSAPP_SENDER_ID}'",
"channel": "whatsapp",
"message_type": "reaction",
"reaction": {
"action": "react",
"emoji": "'${MESSAGES_EMOJI}'"
},
"context": {
"message_uuid": "'${MESSAGES_MESSAGE_ID}'"
}
}'Run your code
Save this file to your machine and run it:
Prerequisites
If you do not have an application you can create one. Make sure you also configure your webhooks.
Add the following to build.gradle:
implementation 'com.vonage:server-sdk-kotlin:2.1.1'Create a class named SendWhatsappReaction and add the following code to the main method:
val client = Vonage {
applicationId(VONAGE_APPLICATION_ID)
privateKeyPath(VONAGE_PRIVATE_KEY_PATH)
}Write the code
Add the following to the main method of the SendWhatsappReaction class:
val messageId = client.messages.send(
whatsappReaction {
to(MESSAGES_TO_NUMBER)
from(WHATSAPP_SENDER_ID)
contextMessageId(MESSAGES_MESSAGE_ID)
reaction(MESSAGES_EMOJI)
}
)Run your code
We can use the アプリケーション plugin for Gradle to simplify the running of our application. Update your build.gradle with the following:
apply plugin: 'application'
mainClassName = project.hasProperty('main') ? project.getProperty('main') : ''Run the following gradle command to execute your application, replacing com.vonage.quickstart.kt.messages.whatsapp with the package containing SendWhatsappReaction:
Prerequisites
If you do not have an application you can create one. Make sure you also configure your webhooks.
Add the following to build.gradle:
implementation 'com.vonage:server-sdk:9.3.1'Create a class named SendWhatsappReaction and add the following code to the main method:
VonageClient client = VonageClient.builder()
.applicationId(VONAGE_APPLICATION_ID)
.privateKeyPath(VONAGE_PRIVATE_KEY_PATH)
.build();Write the code
Add the following to the main method of the SendWhatsappReaction class:
var response = client.getMessagesClient().sendMessage(
WhatsappReactionRequest.builder()
.from(WHATSAPP_SENDER_ID).to(MESSAGES_TO_NUMBER)
.contextMessageId(MESSAGES_MESSAGE_ID)
.reaction(MESSAGES_EMOJI).build()
);
System.out.println("Message sent successfully. ID: "+response.getMessageUuid());Run your code
We can use the アプリケーション plugin for Gradle to simplify the running of our application. Update your build.gradle with the following:
apply plugin: 'application'
mainClassName = project.hasProperty('main') ? project.getProperty('main') : ''Run the following gradle command to execute your application, replacing com.vonage.quickstart.messages.whatsapp with the package containing SendWhatsappReaction:
Prerequisites
If you do not have an application you can create one. Make sure you also configure your webhooks.
composer require vonage/clientCreate a file named send-reaction.php and add the following code:
$keypair = new \Vonage\Client\Credentials\Keypair(
file_get_contents(VONAGE_APPLICATION_PRIVATE_KEY_PATH),
VONAGE_APPLICATION_ID
);
$client = new \Vonage\Client($keypair);Write the code
Add the following to send-reaction.php:
$custom = [
"message_type" => "reaction",
"reaction" => [
"action" => "react",
"emoji" => EMOJI
],
"context" => [
"message_uuid" => MESSAGE_UUID
],
"to" => TO_NUMBER,
"from" => WHATSAPP_NUMBER,
"channel" => "whatsapp"
];
$whatsApp = new \Vonage\Messages\Channel\WhatsApp\WhatsAppCustom(
TO_NUMBER,
FROM_NUMBER,
$custom
);
$client->messages()->send($whatsApp);Run your code
Save this file to your machine and run it:
試してみる
コードを実行すると、WhatsAppのリアクションメッセージが相手先の番号に送信されます。