☁️ くもをもくもくまなぶ

クラウドコンピューティングサービスの学んだことを中心につらつらと書いています

Slack APIでユーザが所属するグループの探索

Slack API

レガシートークン

xoxp- で始まるトークンについて過去発行できましたが、現在は発行できないようになっています。

発行 できるToken

Bot Token

xoxb- で始まるトークン

ワークスペース、チャンネルにインストールが必要です。

スラッシュコマンド /invite $App_name が必要なものです。

User Token

xoxp- で始まるトークン

OAuth Scope としてロールを事前に定義する必要があります。

定義後はワークスペースにインストールするだけでよいです。

App-level tokens

xapp- で始まるトークン

Organization全体のすべての認証に関わるイベントを表示できるなど、前述したトークンと比べるとより幅広く権限があるので常用は避けたほうがよいかも

検索で利用するAPI

API Scope Content Type
users.list users:read application/x-www-form-urlencoded
users:read.email
conversations.list channels:read application/x-www-form-urlencoded
groups:read
im:read
mpim:read
usergroups:read

Bearer Token

OAuthで一般的な認証方式として、Bearer TokenがRFC6750で定義されています。

実際にやってみる

前述したトークンの種類からUser Tokenで実施していこうと思います。

Slackアプリの作成

search-channels-start-with-user という名前のAppを作成しました

特定のユーザのSlack IDを抽出する

slackToken="xoxp-xxxxxxxx-xxxxxxxx-xxxxxxxx-xxxxxxxxxxxxxxxxxxx"
slackTarget="xxx@xxx.xxx"

slackId=$(
curl -s \
    -H 'Authorization: Bearer '${slackToken} \
    -H 'Content-type: application/x-www-form-urlencoded' \
    https://slack.com/api/users.list | \
    jq -r '.members[] | select(.profile.email == "'${slackTarget}'") | .id'
) && echo $slackId

対象のチャネルに参加しているアカウント数を確認

slackToken="xoxp-xxxxxxxx-xxxxxxxx-xxxxxxxx-xxxxxxxxxxxxxxxxxxx"
slackTargetChannelId="xxxxxxxx"

slackChannelMemCount=$(
curl -s \
  -H 'Authorization: Bearer '${slackToken} \
  -H 'Content-type: application/x-www-form-urlencoded' \
  -d 'channel='${slackTargetChannelId} \
  -d 'include_num_members=true' \
  https://slack.com/api/conversations.info | \
  jq  -r '.channel.num_members'
) && echo $slackChannelMemCount

まとめ

Slack APIをDocsの基本から参照して、これまで雰囲気で利用していたものが整理できてよかったです。

一方で過去にいろいろな方のブログに上がっているAPIが今ではDeprecated(非推奨)となっていて、

実行してみたいなと思ったAPIの多くが admin.xxx というEnterprise Gridを利用中のワークスペースでのみ利用可能なものになっていました。

それが分かっただけでも今回は収穫があったとは個人的には思います。

参考