Skip to content

fezzlk/Simple-Alert-LINE-Bot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

458 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Simple-Alert-LINE-Bot

LINE友達追加

友だち追加

Features

TBD

開発環境準備

  • python3 のインストール
  • pip3 のインストール
    • pip を最新バージョンにアップデート python3 -m pip install --upgrade pip
  • ngrok のインストール

テスト(Firestore Emulator)

  1. Emulator 起動
    • scripts/start_firestore_emulator.sh(Docker があれば docker-compose を使用)
  2. Emulator を使ってテスト実行
    • scripts/test_with_emulator.sh

FIRESTORE_PROJECT_IDFIRESTORE_EMULATOR_HOST は環境変数で上書きできます。

初回起動および LINE Bot との紐付けまでの手順

  1. 仮想環境の作成(必須ではないが推奨) $ python3 -m venv {仮想環境名} $ source /{仮想環境名}/bin/activate
  2. 依存パッケージのインストール $ pip3 install -r requirements.txt
  3. LINE Devlopers にてプロバイダ及び messaging API のチャンネルを作っておく
  4. .env ファイルにチャンネルトークンとチャンネルシークレットを入力し、コメントアウトを外す
  5. $ flask run // localhost:5000 に立ち上がる
  6. ngrok コマンドにて 5000 ポートをデプロイ
    • $ ngrok http 5000
  7. デプロイ先の URL の末尾に /callback を追加し、LINE bot チャンネルの Webhook URL に設定

2 回目以降の起動

  1. $ flask run
  2. $ ngrok http 5000
  3. 発行された URL の末尾に /callback を追加し、  LINE bot チャンネルの Webhook URL に設定

処理の流れ

起動

  1. $ flask run を実行すると、server.py に書かれた処理が実行される。
  2. その中で src/__init__.py の app を取得し、app.run() が呼び出されることでサーバーが起動する。

LINE アプリでのメッセージ受信時

  1. bot 宛にメッセージが送信されると、 /callback (LINE bot チャンネルの WebhookURL に基づいたエンドポイント) に POST リクエストが送信される。
  2. そのリクエストをサーバーが受け取り、src/views.py の callback() が実行される。
  3. handler.handle(body, signature) によりイベントをハンドリングする。
  4. ハンドリングしたイベントに対応した、handler.add() によりハンドラーに登録されている関数が実行される

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages