RaspberryPIでSlack APIを利用して通知アプリを作成#1(SlackのAPI登録編)


今日のゴール

Slackのアカウント登録及びAPI関連設定を行う。
最後はSlackチャネルの一覧を取得するサンプルを実行します。

事前準備

①SlackのアカウントとWork spaceを作成します。
②Appを作成とScopeを指定します。

①SlackのアカウントとWork spaceを作成します。

下記の情報を入力します。

登録したEmailを確認し、その情報を入力します。






※これでWorkSpaceの作成が完了しました。

②Appを作成とScopeを指定します

Slackアカウントを作成し、下記のアドレスにアクセスします。

[Create an App]ボタンを押下します。

下記の情報を入力します。

APPの作成できました。下記のOff→ONにする必要があります。

下記のWebhooksをONにします。他のところも必要に応じてOnにします。

Basic information画面に戻ります。

自分のWorkspaceにAppをインストールします。

チャネルを選択し、Allowボタンを押下します。

Basic information画面に戻ります。次は「Manage distribution」を設定します。

「Set Up Redirect URLs」ボタンを押下します。

「Add New Redirect URL」ボタンでURLを追加し、「Save URLs」ボタンを押下します。

apiを使うため、下記の画面でScopeを指定します。

次のURLはScopeの一覧です。沢山ありますが、これは次回に追加しながら確認します。
https://api.slack.com/scopes
Bot Token;これはSlackのBotから実行されるScope指定です。
User Token:これはAppの管理者のアカウントで実行されるScopeです。

Slackアプリの機能と権限は、名前付きスコープとそれらがサポートするトークンによって管理されます。

③Appで使えるScopeを追加します。

次のScopeを追加します。「Add an OAuth Scope」ボタンを押下して下記のScope名を入力します。

★Scopeを追加した後は、「Reinstall App」ボタンでAPPに再インストールします。★

チャネルを選択し、「Allow」ボタンを押下します。

Manage distributionが終わってないので、下記のボタンを押下します。

下記のチェックを入れます。そして「Update Redirect URIs」ボタンを押下します。

サンプルを実行

次の画面でbotのTokenを確認します。

下記のサンプルコードに上記のBotのTokenを設定し、実行します。

現在のチャネル一覧が表示されます。

import requests
import json

url = "https://slack.com/api/channels.list"
token = "token key"

def main():
    userlist = {}
    payload = {"token":token }
    response = requests.get(url,params=payload)
    user_json = response.json()
    for i in user_json["channels"]:
        userlist[i["id"]] = i["name"]
        print("id=" + i["id"] + " name=" + i["name"])

if __name__ == '__main__':
    main()

実行結果

pi@raspberry:~ $ python ch.list.py
id=C014JP6MNPR name=welcome
id=C014JP8GC3Z name=team
id=C015PAVGRT2 name=project
pi@raspberry:~ $

終わりに

SlackのAPIを試すため、このような手順を行わないとできないのが大変ですね。
私の手順も間違えている可能性もあるかもしれないですが、
一応Slackのチャネル一覧を取得することはできました。
Qiitaに残すために0からアカウントを作成し、手順を作成しましたので、
興味ある方はこの手順通りに実施して問題があれば教えていただけますでしょうか。
よろしくお願いいたします。