3
5

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.

AppSheetでLINE予約投稿システムを作ろう

Posted at

1. AppSheetの設定

1-1. スプレッドシートの新規作成

AppSheetで使うスプレッドシートを新規作成しておきます。下記URLにアクセスしてください。

1-2. カラム設定

A1セルに ステータス、B1セルに 投稿日時 、C1セルに メッセージ、D1セルに 画像、E1セルに URL、F1セルに 待ち時間 とそれぞれ入力してください。スプレッドシートの名前はお好きな名前を設定してください。今回は「予約投稿アプリ」としました。

1-3. プロジェクト作成

下記URLにアクセスして、[無料トライアル]ボタンをクリックします。

一番左にある Start with your own data をクリックします。

お好きなプロジェクト名①とカテゴリ②を設定して、[Choose your data]ボタン③をクリックします。

1-2で作成したスプレッドシートを選択します。

Customize your app をクリックします。

1-4. データ項目編集

AppSheetのプロジェクト管理画面が表示されます。左側メニューのData①→Columns②→シート1③をクリックします。

ステータスデータを編集します。鉛筆ボタンをクリックします。

ステータスのボタンを設定します。「今すぐ投稿」と「予約投稿」のボタンを設定しています。設定したら右上の[Done]ボタン⑤をクリックします。

項目
①Type Enum
②Add 2回クリック
③Values 今すぐ投稿、予約投稿項目を追加
④Input mode Buttons

続いて投稿日時データを編集します。投稿日時にある鉛筆ボタンをクリックします。

設定は下記の通りです。

項目
①Type DateTime
②Require? チェックを入れる
③Initial Value クリックする

初期値に現在時刻を取得する処理を追加します。NOW()行にある[Insert]ボタンをクリックして[Save]ボタンをクリックします。

設定が終われば右上の[Done]ボタンをクリックします。

続いて画像データを編集します。画像にある鉛筆ボタンをクリックします。

Typeは Image を選択します。

続いて待ち時間データを編集します。待ち時間にある鉛筆ボタンをクリックします。

Typeは Duration を選択します。

_RowNumberにあるKEY?部分だけにチェックを入れてください。ステータス部分のチェックは外しておきます。
設定が終われば右上の[SAVE]ボタン②をクリックします。

1-5. セキュリティ設定

デフォルトのままだと画像を投稿してもセキュリティがかかっていて、誰でも見ることができません。
LINEに投稿する画像は誰でも見ることができるようにしないといけないので、AppSheetの設定を行います。

左側メニューのSecurity①→Optionsタブ②→Require Image and File URL Signing③をオフにする

1-6. 動作確認

ここまで設定したら一度シミュレーターで確認してみましょう。画面右側のシミュレーターから[+]ボタン①をクリックして、投稿ステータスを設定②します。投稿日時、メッセージ、画像を選択したら右下の[Save]ボタン③をクリックします。すると設定した項目④が自動的に追加されます。

追加した情報はスプレッドシートにも自動的に反映されます。

2. LINEの設定

2-1. 新規チャネルを作成する

LINE DeveloperページへアクセスしてLINEログインしてください。

まだプロバイダー設定してない方は「新規プロバイダー作成」をクリックします。

プロバイダー名はお好きなものを入力して、「作成」ボタンをクリックします。

Messaging API をクリックします。

各種項目を埋めていきます。会社・事業者の所在国・地域は「日本」を選択します。

各種項目を埋めていきます。

項目
①チャネル名 【デモ】予約投稿
②チャネル説明 【デモ】予約投稿
③大業種 個人
④小業種 個人(その他)
⑤メールアドレス あなたのメールアドレスを入力してください

2つのチェックを入れて、[作成]ボタンをクリックします。

[OK]ボタンをクリックします。

[同意する]ボタンをクリックします。

2-2. ボットと友だちなる

作成したボットと友だちになっておきます。「Messaging API設定」タブにあるQRコードをLINEアプリから読み取って友だちになっておいてください。

2-3. アクセストークンを発行する

下の方にスクロールして、チャネルアクセストークンカテゴリにある「発行」ボタンをクリックします。

後ほど使いますので、発行されたチャネルアクセストークをメモしておきましょう。

3. AppSheet Automationの設定

3-1. Botを設定する

AppSheetに何かしらの変化があれば、何かを行うという 自動化 の処理を設定します。
今回は、スタータスの値に応じて、「今すぐ投稿」するのか、「予約投稿」で指定時間経過するまで待つのかを自動化していきます。

Automation①からBots②タブの「+New Bot」③をクリックします。

Bot名は LINE予約投稿 ①と入力して、「Configure event」②ボタンをクリックします。

「Create a custom event」をクリックします。

下記設定を行います。設定が終われば「Add a step」③ボタンをクリックします。

項目
Event Name① 新規追加
Event Type② Adds Onlyを選択

「Create a custom step」をクリックします。

「データ更新」とプロセス名①を変更して、Run a taskのプルダウンメニューから「Run a data action」を選択します。

set row values①を選択し、「Add」ボタン②を2回クリック、URL待ち時間を選択③します。
URL側をクリックして編集④します。

下記を入力してください。途中にある アプリ名はご利用環境によって異なります。設定
できれば「Save」をクリック②します。

concatenate(“https://www.appsheet.com/Template/gettablefileurl?”, 
“appname=”, encodeurl(“アプリ名”), 
“&tablename=”, encodeurl(“シート1”), 
“&filename=”, encodeurl([画像]))

アプリ名はURLに明記されています。

待ち時間を設定します。配信日時から現在時刻を引き算して算出します。この秒数待機してくれるようになります。

待ち時間を処理しますので、下記コード①を適応して、「Save」ボタン②をクリックします。

[投稿日時] - NOW()

「Add a step」ボタンをクリックします。

「Create a custom step」をクリックします。

プロセス名を「ステータス判定」①に変更し、プルダウンメニュー②から「Branch on a condition」③をクリックします。

ステータス判定するための式を設定します。

式は下記の通りです。

[ステータス] = “今すぐ投稿”

NO側の「+」をクリックします。これで、ステータスが「予約投稿」の場合にNOへ遷移します。

「Create a Custom step」をクリックします。

「Wait」をプルダウンメニューから選択します。

下記設定を行います。

項目
Wait for① A period of time
Period② [待ち時間]

「Add a step」をクリックします。

プロセス名を「LINE投稿」①に変更し、「Call a webhook」②を選択します。
URLは https://api.line.me/v2/bot/message/broadcastを③設定し、HTTP Verbは Postを④選択します。

下にスクロールするとBody項目①があるので、下記を入力します。HTTP Headersは Authorization: "Bearer 2-3で取得したアクセストークン"を②設定します。設定できれば「Save」③をクリックします。

{
  "messages": [
    {
      "type":"text",
      "text":"<<メッセージ>>"
    },
    {
      "type": "image",
      "originalContentUrl": "<<URL>>",
      "previewImageUrl": "<<URL>>"
    }
  ]
}

3-2. 動作確認

ここまで設定ができていれば、「今すぐ投稿」や「予約投稿」を試してみてください。
今すぐ投稿だと瞬時にLINEは投稿されます。「予約投稿」は指定時間になればLINEへ投稿されます。

予約投稿は最低5分先、最高30日先まで指定することができます。それ以外の範囲だとエラーになるので注意してください。

3-3. まとめ

ノーコードでLINEの予約投稿を実現することができました。LINEの公式アカウントにある管理画面からでも予約投稿することは可能なのですが、不特定多数のユーザーが同一の公式アカウントに投稿するケースや、LINE公式アカウントのログイン情報共有したくない場合にこちらのアプリが使えるのではないでしょうか?

AppSheet Automationは色々機能があるので、是非試してみてください。

システム化のご検討やご相談は弊社までお問い合わせください。

3
5
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
3
5

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?