data:image/s3,"s3://crabby-images/acbad/acbad1349e57aa8154bb9c576b5cc206a95e7e11" alt="見出し画像"
Python Slack SDKの使い方
概要
Python Slack SDKとIncoming Webhooksを利用したコーディングについて解説します。最終的には下図のような通知をslackチャンネルに送れます。
data:image/s3,"s3://crabby-images/9c1c5/9c1c5527fa189345b371ce962cf60bf21758aebc" alt=""
手順
Incoming Webhooksの設定
https://api.slack.com/apps?new_app=1 にアクセスしてFrom scrathでアプリを作成
data:image/s3,"s3://crabby-images/e8c1d/e8c1d393619b3c4585e148c7b42a67b7b5934121" alt=""
App Nameとworkspaceを選択してCreate App
data:image/s3,"s3://crabby-images/c1e29/c1e29a9e432e828433e20a59685823b1d4452624" alt=""
OAuth & Permissionsでchat:writeを選択
data:image/s3,"s3://crabby-images/85c4c/85c4cfb3e4d3ecd9913bcda3c58a3ff8618f9cc7" alt=""
Install to Workspace
data:image/s3,"s3://crabby-images/50897/5089749c100e75c56cfdfcb206705649e982458f" alt=""
許可する
data:image/s3,"s3://crabby-images/5c30a/5c30ab77c9ae27b40dadd00e17e062bef599feed" alt=""
Incoming Webhooksをonにする
data:image/s3,"s3://crabby-images/fdca6/fdca67c98734c3baad61e7a41edcd0353198c68b" alt=""
reinstall your appを選択
data:image/s3,"s3://crabby-images/b3198/b31982cb06ed17ba529204851b71f4be17929208" alt=""
投稿先を選択して許可するを選択
data:image/s3,"s3://crabby-images/e14bf/e14bfecf85b0ac25963c95a270157ef82d91bf2f" alt=""
Webhook URLをCopy
data:image/s3,"s3://crabby-images/ed956/ed95601613c2889351f3d74c80ef047d107d237f" alt=""
ライブラリの準備
ライブラリをインストール
poetry add slack-sdk
Pythonスクリプトを作成。urlにコピーしたwebhook URLをいれます。
from slack_sdk.webhook import WebhookClient
url = "https://hooks.slack.com/services/T00000000/B00000000/XXXXXXXXXXXXXXXXXXXXXXXX"
webhook = WebhookClient(url)
response = webhook.send(text=":wave: こんにちは!")
実行して動作確認
data:image/s3,"s3://crabby-images/3e30e/3e30eeff7c1a308f3dcd468b6e8585c613432349" alt=""
blocksの作成
blocksを使うことでよりリッチなメッセージを送信可能。
from slack_sdk.webhook import WebhookClient
url = "https://hooks.slack.com/services/T00000000/B00000000/XXXXXXXXXXXXXXXXXXXXXXXX"
webhook = WebhookClient(url)
response = webhook.send(
text="fallback",
blocks=[
{
"type": "section",
"text": {
"type": "mrkdwn",
"text": "You have a new request:\n*<fakeLink.toEmployeeProfile.com|Fred Enriquez - New device request>*"
}
}
]
)
data:image/s3,"s3://crabby-images/d405c/d405ca6a5237d161c7c5305a4a358831ec4f8dfa" alt=""
Block Kit Builder の左側をポチポチして作成すると楽。
data:image/s3,"s3://crabby-images/51654/516543f14eca8d3ae190103d77a897366210d671" alt=""
試しにこのようなblocksを作成。blocksの中身をコピーしてPythonスクリプトのblocks=[]の中にペーストして実行。
data:image/s3,"s3://crabby-images/cffde/cffde74edebb953a8217c5c55983caa9142953ce" alt=""
data:image/s3,"s3://crabby-images/2f0c5/2f0c598bfc4e7ab325d715fc830f13a25ddfc28e" alt=""
同じメッセージを送信できています。
Block Kit Builder ではboolがtrueだがpythonではTrueにしなければいけないことに留意
textはblocksを持つ場合は以下のようにフォールバックとして働くため、使用されることが公式で推奨されています。
data:image/s3,"s3://crabby-images/3ef08/3ef08fb3becee0a5af7c01edbc2f374533ca1970" alt=""
Attachmentsの作成
data:image/s3,"s3://crabby-images/49451/494512f92942469fa768483ed2abf92b5e20fa20" alt=""
response = webhook.send(
text="fallback",
blocks=[
# 省略
],
attachments = [
# paste here
]
)
data:image/s3,"s3://crabby-images/b806e/b806e991a2853ea23d2bf9137deec0cb368e8608" alt=""
ボタンでURL押せるのは便利ですね。
最終形とスクリプトを貼っておくので参考にしていただければ幸いです。
data:image/s3,"s3://crabby-images/fe224/fe224d840362c0b633e8e7419ddf5393b861e66e" alt=""
from slack_sdk.webhook import WebhookClient
url = "https://hooks.slack.com/services/T00000000/B00000000/XXXXXXXXXXXXXXXXXXXXXXXX"
webhook = WebhookClient(url)
response = webhook.send(
text="fallback",
blocks=[
{
"type": "header",
"text": {
"type": "plain_text",
"text": "header title"
}
},
{
"type": "section",
"fields": [
{
"type": "mrkdwn",
"text": "*column 1*"
},
{
"type": "mrkdwn",
"text": "*column 2*"
},
{
"type": "plain_text",
"text": "description 1"
},
{
"type": "plain_text",
"text": "description 2"
}
]
},
{
"type": "section",
"text": {
"type": "mrkdwn",
"text": "*section 2*\ndescrption 3"
}
},
{
"type": "divider"
},
{
"type": "context",
"elements": [
{
"type": "plain_text",
"text": "Send from Cloud Run"
}
]
},
{
"type": "section",
"text": {
"type": "mrkdwn",
"text": " "
},
"accessory": {
"type": "button",
"text": {
"type": "plain_text",
"text": "Go to Cloud Run Service"
}
}
}
],
attachments = [
{
"color": "#ff6666",
"blocks": [
{
"type": "section",
"text": {
"type": "mrkdwn",
"text": "*attachment section*"
}
},
{
"type": "section",
"text": {
"type": "mrkdwn",
"text": "gs://project/backet/file1"
},
"accessory": {
"type": "button",
"text": {
"type": "plain_text",
"text": "Check",
},
"url": "https://google.com",
}
},
{
"type": "section",
"text": {
"type": "mrkdwn",
"text": "gs://project/backet/file2"
},
"accessory": {
"type": "button",
"text": {
"type": "plain_text",
"text": "Check",
},
"url": "https://google.com",
}
}
]
}
]
)
print(response.body)
メンションの作成
以下の表記でメンションを送れます。
ユーザーへのメンションだけ<@UXXXXXXXXXX>になることだけ注意してください。(UXXXXXXXXXXはユーザーID)
{
"type": "section",
"fields": [
{
"type": "mrkdwn",
"text": "<!here> <!channel> <!everyone> <@UXXXXXXXXXX>"
}
]
},
data:image/s3,"s3://crabby-images/95155/951550a5b6ff4bbedfc0d4d485a6d2b06d45c7d5" alt=""