17
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

LINE DC Advent Calendar 2021 (クリスマスプレゼント付き)Advent Calendar 2021

Day 22

LINEで手軽にIoT! opnizを使ってLINE BotからM5ATOM Liteをコントロールしてみる

Last updated at Posted at 2021-12-21

はじめに

先日LINEアドベントカレンダーにて「LINEで手軽にIoT! opniz × LINE Notifyを試してみる」という記事を投稿させて頂きました。
この記事ではLINE Notifyを用いて「M5ATOM -> LINE」という方向のアクセスを行いました。

本記事ではLINE Messaging APIを用いて「M5ATOM <-> LINE」と双方向のアクセスを試してみます。

なお本記事では上記の記事同様マイコンデバイスにはM5ATOM Liteを使用します(M5ATOM Matrixでも大丈夫です)。
M5ATOMへのopniz Arduino Library書き込み方法は本記事では省略しますので、必要な場合は「こちら」をご覧ください。

LINE -> M5ATOM の動作

LINEからM5ATOMへアクセスするケースでは、LINEに入力した色にあわせM5ATOMのLEDを変化させてみます。
あわせてBotからの応答メッセージもLINEに返してみます。

こんな感じです。
image

M5ATOM -> LINE の動作

M5ATOMからLINEへアクセスするケースです。
前回の記事同様にM5ATOMのボタンを押したらLINEにメッセージとスタンプを送るようにします。

前回の記事ではLINE Notifyにて実装していましたが、今回はこの部分もMessaging APIで実装します。

こんな感じです。
image

実装

処理のイメージは以下のようになります。
image
image

手順としては、

という流れで進めます。

LINE DevelopersコンソールにてLINE Botを作成

この部分は既にさまざまな記事にて解説されています。
私が最初にBotを作ったときも、久しぶりにBotを作るときもまず参照する「1時間でLINE BOTを作るハンズオン (資料+レポート) in Node学園祭2017 #nodefest」という記事がおすすめです。

この記事の「1. Botアカウントを作成する」から「Botと友達になろう」までを実施するとLINE Botを作成できます。
画面のキャプチャや項目名称が現環境と少し差異がありますが、雰囲気でなんとかなると思います。

opniz Node.js SDK & LINE Bot SDKプログラムの作成

作成したLINE Botの中身の動きの実装を行います。
少しコードが長いのでいくつかポイントを抜粋して説明します。

まずconfigに格納する「<CHANNEL_SECRET>」「<CHANNEL_ACCESS_TOKEN>」をLINE DevelopersコンソールのBot情報から取得し差し替えます。
先ほどの記事の「Channel Secretとアクセストークンの確認」を参考にしてみてください。

index.js(config部抜粋)
const line = require("@line/bot-sdk")
const express = require("express")
const { Opniz } = require("opniz")

const config = {
	channelSecret: "<CHANNEL_SECRET>",            // ここを差し替える
	channelAccessToken: "<CHANNEL_ACCESS_TOKEN>", // ここを差し替える
}

次にLINEからのメッセージをうけ、M5ATOMのLEDを制御する部分です。
メッセージ(色名)をもとにカラーコードを取得し、await opniz.dis.drawpix(0, colorCode)というメソッドでカラーコードを指定しM5ATOMのLEDを制御します。
最後にLINEへの応答メッセージを生成しレスポンスを返します。

ここではopniz(M5ATOM)のコードはawait opniz.dis.drawpix(0, colorCode)のみです。
このようにシンプルにM5ATOMを制御することができます。

index.js(LINEメッセージをもとにM5ATOMのLEDの色変更部)
// LINE Botでのメッセージハンドリング
const client = new line.Client(config)
const handleEvent = async (event) => {
	if (event.type !== "message" || event.message.type !== "text") return null
	
	const message = event.message.text.trim() // メッセージ(色名)取得
	const colorCode = colorTable[message] // 色名をカラーコードに変換
	
	colorCode && await opniz.dis.drawpix(0, colorCode) // M5ATOm LiteのLED色変更
	
	const replyMessage = colorCode ? // 応答メッセージを生成
		`LEDを${message}にします!` :
		"「赤、 青、 緑、 白、 オフ」のいずれかを指定してください!"
	
	return client.replyMessage(event.replyToken, {
		type: "text",
		text: replyMessage
	})
}

最後にM5ATOMのボタンを押したらLINEへメッセージ送信する部分です。
まずpushMessageというLINE Botに対してブロードキャストでメッセージ送信する関数を定義しています。
そしてこの関数をopniz.onbutton = pushMessageにてonbuttonメソッドにバインドしています。

前回の記事でも同様の処理をしていますが、LINE Notifyを使用していたのでLINE NotifyのエンドポイントへHTTP POSTをしていました。
今回はLINE Bot SDKを使用しているので、SDKで用意されているclient.broadcast()メソッドで簡単に実装できました。

index.js(M5ATOMのボタンを押したらLINEへメッセージ送信)
// LINE Botからメッセージ送信
const pushMessage = async () => {
	await client.broadcast([
		{
			type: "text",
			text: "opnizのボタンが押されたやで!",
		},
		{
			type: "sticker",
			packageId: "11537",
			stickerId: "52002735",
		},
	])
}



const opniz = new Opniz.M5Atom({ port: 3000 }) // opnizインスタンス生成
opniz.onbutton = pushMessage // M5ATOMのボタンが押されたらメッセージ送信

ソースコード全文

╭╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╮
   ╏    ソースコードを表示(ここをクリックすると展開されます)   ╏
   ╰╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╍╯
index.js
const line = require("@line/bot-sdk")
const express = require("express")
const { Opniz } = require("opniz")

const config = {
	channelSecret: "<CHANNEL_SECRET>",            // ここを差し替える
	channelAccessToken: "<CHANNEL_ACCESS_TOKEN>", // ここを差し替える
}

const colorTable = {
	"": "#00ff00",
	"": "#0000ff",
	"": "#ff0000",
	"": "#ffffff",
	"オフ": "#000000",
}



// LINE Botでのメッセージハンドリング
const client = new line.Client(config)
const handleEvent = async (event) => {
	if (event.type !== "message" || event.message.type !== "text") return null
	
	const message = event.message.text.trim() // メッセージ(色名)取得
	const colorCode = colorTable[message] // 色名をカラーコードに変換
	
	colorCode && await opniz.dis.drawpix(0, colorCode) // M5ATOm LiteのLED色変更
	
	const replyMessage = colorCode ? // 応答メッセージを生成
		`LEDを${message}にします!` :
		"「赤、 青、 緑、 白、 オフ」のいずれかを指定してください!"
	
	return client.replyMessage(event.replyToken, {
		type: "text",
		text: replyMessage
	})
}



// LINE Botからメッセージ送信
const pushMessage = async () => {
	await client.broadcast([
		{
			type: "text",
			text: "opnizのボタンが押されたやで!",
		},
		{
			type: "sticker",
			packageId: "11537",
			stickerId: "52002735",
		},
	])
}



const opniz = new Opniz.M5Atom({ port: 3000 }) // opnizインスタンス生成
opniz.onbutton = pushMessage // M5ATOMのボタンが押されたらメッセージ送信

const connect = async () => {
	while (!(await opniz.connect())) console.log("connect...") // opniz接続
	console.log("connected!")
}
connect()



// Botサーバ起動
const requestHandler = async (req, res) => res.json(await handleEvent(req.body.events[0]))
const app = express()
app.post("/", line.middleware(config), requestHandler)
app.listen(3001)

プログラムの実行

それでは実行してみましょう。

まずは関連npmパッケージをインストールします。

パッケージインストール
npm install opniz @line/bot-sdk express
npm install -D ngrok

次に上記のコマンドでインストールしたngrokというトンネリングアプリを使ってPCの3001番ポートをHTTPトンネリングします。
ForwardingというレコードにHTTPS URLが表示されますので、これを再びLINE DevelopersコンソールよりWebhook URLに登録します。

ngrokの実行
$ npx ngrok http 3001

ngrok by @inconshreveable(Ctrl+C to quit)
Session Status                online
Session Expired               Restart ngrok or upgrade: ngrok.com/upgrade
Version                       2.3.40
Region                        United States (us)
Web Interface                 http://127.0.0.1:4040
Forwarding                    http://xxxx-xxxx-xxxx-xxxx-xxxx-xxxx-xxxx-xxxx-xxxx.ngrok.io -> http://localhost:3001
Forwarding                    https://xxxx-xxxx-xxxx-xxxx-xxxx-xxxx-xxxx-xxxx-xxxx.ngrok.io -> http://localhost:3001

Connections                   ttl     opn     rt1     rt5     p50     p90     
                              1       0       0.00    0.00    17.13   17.13   

[LINE Developersコンソール Webhook設定]
image

そしてプログラム実行します。
connected!と表示されればM5ATOM Liteと正常に接続できている状態です。

$ node index.js
connected!

LINEからM5ATOMのLEDを制御

まずは「LINE -> M5ATOM」のアクセスをためしてみます。

LINE Botへ「赤、青、緑、白、オフ」のいずれかのメッセージを送ってみます。
するとM5ATOMのLEDが指定した色に変化し、LEDの色を変更した旨のメッセージが返ってきます。
image

M5ATOMのボタンを押してLINEへメッセージ送信

つづいて「M5ATOM -> LINE」のアクセスをためしてみます。

前回記事と同様、M5ATOM Liteのボタンを押したらLINEへメッセージとスタンプが送られます。
image

おわりに

LINE Messaging APIを通してLINEとM5ATOMで双方向の制御を実現できました。
ここまでできてしまえば、もうなんでもできるんじゃないでしょうか。

ひとつLINE Messaging API使用の注意点があります。
LINEのメッセージは「応答メッセージ」と「プッシュメッセージ」に分けられます
「応答メッセージは」無制限で利用可能ですが「プッシュメッセージは」フリープランだと月あたり1000回までという制限があります。

「M5ATOM -> LINE」の方向のアクセスでは制限がある「プッシュメッセージ」を用いていますのでこのあたり注意が必要です。

なお前回記事で用いたLINE Notifyも同様に制限は設けられていますが、1時間あたり1000回までとあってないような制限です。
プッシュを多用したいケースではLINE Messaging APIではなくLINE Notifyの使用を検討してみるとよいでしょう。

17
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
17
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?