25
13

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 1 year has passed since last update.

🌟LINE DC🌟 LINE Developer CommunityAdvent Calendar 2022

Day 3

ChatGPTでLINE Botを実装してみる

Last updated at Posted at 2022-12-02

はじめに

本記事は12/1より界隈に激震を走らせている「ChatGPT」に質問しまくりLINE Botを作成してみた記録です。

「LINE Botのコードかいて」

image.png

しっかりコメントも添えられたコードだけではなく、コードの解説に加えnpm installまで案内してくれてます。

教えてくれたとおりコードはまんまコピペしてnpm installを実行します。
生成してくれたコードは↓の感じです。

const express = require('express');
const line = require('@line/bot-sdk');

// LINE Messaging APIのチャンネルアクセストークンとシークレット
const config = {
  channelAccessToken: 'YOUR_CHANNEL_ACCESS_TOKEN',
  channelSecret: 'YOUR_CHANNEL_SECRET'
};

// LINE Botのインスタンスを作成
const bot = new line.Client(config);

// Webhookからのリクエストを処理する
const handleWebhook = (req, res) => {
  // リクエストボディを解析
  const events = req.body.events;
  events.forEach((event) => {
    // メッセージが送信された場合
    if (event.type === 'message') {
      // メッセージを返信
      bot.replyMessage(event.replyToken, {
        type: 'text',
        text: 'こんにちは!'
      });
    }
  });

  // 200 OKを返す
  res.status(200).send('OK');
};

// Webサーバーを立てる
const app = express();
app.post('/webhook', line.middleware(config), handleWebhook);
app.listen(3000);

「LINE Botのpackage.jsonはどんな感じ?」

image.png

npm initしてなかったのでpackage.jsonはどんな感じを想定しているのか質問してみました。
npm startのscriptを用意してくれてました。
bot-sdkの最新バージョンは7系なのでちょっと古かったです。

「LINE Botのトークンの取得方法は?」

image.png

生成してくれたコードではchannelAccessTokenchannelSecretを自身で発行したものに差し替えないといけないっぽいので、トークンの取得方法について聞いてみました。
LINE Developersを案内してくれたのはナイスですが、そこから先は投げやり気味というかちょっと惜しい感じです。

「LINE Botをローカル環境で試す方法は?」

image.png

LINE Botのエンドポイントコードを作ってくれましたが、ローカル環境で試すにはどうすればいいのか聞いてみました。
回答ではおなじみngrokの使い方を教えてくれましたので指示にそってngrokをインストール、実行します。

「このLINE BotをLINEから試すにはどうすればいい?」

image.png

ローカルでエンドポイントもたてられたので次は実際にLINEからアクセスしてみたいのでやり方を聞いてみました。
なんでもかんでも聞きすぎてそろそろAIもめんどくさくなってきたのか「ドキュメント読め」とのことでした(内容が具体的すぎてこうせざるをえないのでしょう)。
丁寧にドキュメントサイトへリンクもしてくれてます。

LINE BotをホストするWebサーバーを用意します。はローカルでngrokを動かせばいいんだよね?」

image.png

ひとつ前の回答で「LINE BotをホストするWebサーバーを用意します。」とありましたが、今までの会話の流れですとngrokでローカル環境を用意してるのでそれでいいんだよね?という質問をしてみました。
回答としては「そうだよ。とりあえずドキュメント読め」という感じですが、ポリシー違反の可能性があるとの警告が出ました。
ChatGPTのポリシーみてみましたが特に問題なさそうなのでその旨フィードバックしておきました。

とりあえずLINE Developers Consoleでの操作はドキュメントを読んだことにして諸々設定し(Webhook URL登録、あいさつ、応答メッセージのオフ)、実際にLINEからアクセスして問題なく動作すること確認しました。
AIすごい…

「LINE Botでオウム返しできるようにしたい」

image.png

最初に生成してくれたコードは「こんにちは!」を固定で返すBotでした。
今度はこれをオウム返しBotに修正してもらいました。

replyMessageにてtext: event.message.textに書き換わっており、ちゃんとオウム返しできるコードに修正してくれました。

なおコードが途中で切れてしまっていますが、何度かリトライすると途中切れタイミングが変わったりしているのでAIが疲れてしまったのかもしれません(ページを開き直すとまた最後までちゃんと返してくれるようになります)。

「コード途中で切れてない?」

image.png

もう十分すぎる働きをしてくれていますが、心を鬼にして指摘してみした。
結果、今度はしっかりコードをすべて生成してくれました。

これまでのやりとりでかなり人間味を感じていたため、冒頭で謝られてしまうと胸が痛みます。

生成されたオウム返しBotのコードは以下になります。

const express = require('express');
const line = require('@line/bot-sdk');

// LINE Messaging APIのチャンネルアクセストークンとシークレット
const config = {
  channelAccessToken: 'YOUR_CHANNEL_ACCESS_TOKEN',
  channelSecret: 'YOUR_CHANNEL_SECRET'
};

// LINE Botのインスタンスを作成
const bot = new line.Client(config);

// Webhookからのリクエストを処理する
const handleWebhook = (req, res) => {
  // リクエストボディを解析
  const events = req.body.events;
  events.forEach((event) => {
    // メッセージが送信された場合
    if (event.type === 'message') {
      // メッセージを返信
      bot.replyMessage(event.replyToken, {
        type: 'text',
        text: event.message.text // 友達が送信したメッセージをそのまま返信する
      });
    }
  });

  // 200 OKを返す
  res.status(200).send('OK');
};

// Webサーバーを立てる
const app = express();
app.post('/webhook', line.middleware(config), handleWebhook);
app.listen(3000);

「大変恐縮ですが解説が途中で切れていたため、再度お願いできますでしょうか?」

image.png

ほんともう十分なんですけど、解説が途中で切れていてどんなこと言おうとしてたのか気になったので最後に質問してみました。
コードが一例であることや、LINE Botのバリエーション、LINE Developers Consoleの説明など、締めとしてばっちりな文章を回答してくれました。
入門記事とかなら一本まるごと書けてしまいそうですね…

おわりに

ちゃんと動くソースコードを生成してくれるだけでなく、適切なコメント、コードの解説、補足情報もありと至れり尽くせりで、これは激震モノだなあと納得のクオリティでした。
そして途中から「ドキュメント読め」と投げやりになってきたり、コードが途中で力尽きるようになったりとやたら人間味のある感じがちょっとこわかったぐらいです。

本記事内容外でもいろいろ試してみたところ、たまにバグを含むコードを生成することがあったりしますが「ここバグってない?」と聞くとちゃんと修正されたコードを生成してくれたりもします。

現時点ではシンプルなものでないとコードまるごと全部生成は難しそうですが、それでも部分的に詳細なコードを生成してもらってそれをベースに修正していって、という使い方はいけそうです。
意図した良いコードを生成してもらうにはStable Diffusion同様にプロンプト力が必要になってきますね。

25
13
1

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
25
13

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?