Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
microCMS と Firebase Clound Messaging で実現する Web ...
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
stin
April 19, 2023
Programming
1k
0
Share
microCMS と Firebase Clound Messaging で実現する Web Push 通知
stin
April 19, 2023
More Decks by stin
See All by stin
ジャムスタックチョットデキル_シブヤ_LT資料
stin
1
1.1k
Other Decks in Programming
See All in Programming
LLM Plugin for Node-REDの利用方法と開発について
404background
0
150
Oxcを導入して開発体験が向上した話
yug1224
4
280
Java × distroless で 軽量なコンテナイメージを / Java on Distroless
contour_gara
0
460
jQueryをバージョンアップする前に使いたいjQuery Migrate
matsuo_atsushi
0
160
CLIであることを活かしたGitHub Copilot CLI活用術 / GitHub Copilot CLI Pro Tips & Tricks
nao_mk2
1
1.2k
AI時代の仕事技芸論 — ソフトウェア開発で「遊ぶように働く」職人的熟達のすすめ
kuranuki
1
600
RTSPクライアントを自作してみた話
simotin13
0
430
フロントエンドとバックエンドで「1文字」を揃えよう
youkidearitai
PRO
0
150
Inside Stream API
skrb
1
600
tsserverとは何だったのか、これからどうなるのか
nowaki28
1
430
初めてのRubyKaigiはこう見えた
jellyfish700
0
410
TypeSpec で繋ぐ複数プロダクトの型安全
maroon8021
1
320
Featured
See All Featured
Done Done
chrislema
186
16k
Producing Creativity
orderedlist
PRO
348
40k
Embracing the Ebb and Flow
colly
88
5.1k
Utilizing Notion as your number one productivity tool
mfonobong
4
310
The Director’s Chair: Orchestrating AI for Truly Effective Learning
tmiket
1
180
What the history of the web can teach us about the future of AI
inesmontani
PRO
1
600
Unlocking the hidden potential of vector embeddings in international SEO
frankvandijk
0
830
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
133
19k
The SEO identity crisis: Don't let AI make you average
varn
0
480
実際に使うSQLの書き方 徹底解説 / pgcon21j-tutorial
soudai
PRO
200
74k
For a Future-Friendly Web
brad_frost
183
10k
Believing is Seeing
oripsolob
1
140
Transcript
microCMS と Firebase Clound Messaging で 実現する Web Push 通
知
About Me すてぃん chot Inc. フロントエンドエンジニア https://twitter.com/stin_factory
内容について 先に Zenn に投稿したハンズオン記事の内容を少しアップデートしてお 話します。 https://zenn.dev/chot/articles/web-push-with-microcms-and-fcm 未読の方でも内容が把握できるよう努めます。
概要 - microCMS - Firebase Cloud Messaging(以降 FCM) を用いて、架空のメディアサイトにWeb Push
通知で新着記事をお知ら せする機能を実装します。 記事にはカテゴリーが設定されており、プッシュ通知はカテゴリー別に購 読できるように実装します。
試してみたきっかけ ついに iOS Safari にも Web Push 通知が実装されて、プッシュ通知を 搭載したWebサイト開発が現実的になりました。 chot
Inc. が得意とする microCMS を使った Jamstack 開発でも、iOS サポートを含むプッシュ通知の実装が必要になっていくでしょう。 その準備として、microCMS と FCM による実装を学びます。
話さないこと - microCMS, Firebase のプロジェクト作成手順 - microCMS, Firebase の SDK
インストール手順 - Firebase CLI インストール手順 - microCMS を使った Web サイトの作り方など かなり掻い摘んでお話しますので、ブログ記事や公開しているソース コード等も併せて御覧ください
microCMS とは - 国産のヘッドレスCMS - コンテンツを JSON 形式で取得できる - コンテンツ編集時の
Webhook 機能 ⭐ コンテンツを追加したタイミングの Webhook をプッシュ通知に利用しま す (無料プランの範囲で試すことができます!)
Firebase Cloud Messaging とは - Firebase が提供するプッシュ通知サービス - Web に限らずネイティブアプリにも対応
- 完全無料で使用可能 Cloud Functions for Firebase, Firestore も併用して実装します。 (Functions は従量課金プランでないと使用できませんが無料枠が大き いので気軽に試せます!)
サービス構成
microCMS のスキーマ設定
通知設定画面を用意 microCMS から取得したカテゴリー一覧 から通知設定画面をビルドします このチェックボックスは…
通知設定画面を用意 Firestore のドキュメントにこんなデータ を保存します token は FCM の Client SDK
で取得で きるトークンで、Functions で使います (通知送信先デバイスの識別子です)
通知設定を FCM に反映 通知設定を保存した Firestore ドキュメントの更新イベント(onCreate, onUpdate)で Functions をトリガーします Functions
では FCM の Admin SDK によってトークンとトピック(記事カ テゴリー)の紐付けを行います
None
Webhook を受け取ってプッシュ通知を送信する 同じく Functions で https リクエストを受け付ける関数を用意します。 microCMS の記事作成時に送信される Webhook
を受け取るための関 数です。 Webhook のリクエストボディに含まれる記事データからカテゴリーを確 認して通知送信を行います。
webhook に microCMS からのリクエストボディが含まれています。 webpush.fcmOptions.link は通知バーをクリックしたらブラウザが開く URL。
microCMS で Webhook の設定をする microCMS 管理画面の {コンテンツ} > API 設定
> Webhook で、コンテンツ編集時の Webhook を設定できます。 Functions で作成した https 関数の URL を指定し、コンテンツ公開時 に送信されるような設定にしておきます。
None
通知を送信してみる! microCMS で記事を作成すると、 プッシュ通知が配信されます! 通知をタップすれば記事詳細ページ がブラウザで開かれます。 右の画像は Android Chrome の通知
バーです。
まとめ microCMS と Firebase Cloud Messaging を組み合わせてプッシュ通 知を送信するサイトの実装方法を紹介しました。 - サイト上で購読設定を
Firestore に保存して、 Functions でトピック 購読設定 - microCMS から Webhook を Functions に送信 - Functions で記事カテゴリーをトピックとして通知送信
まとめ 実際にデプロイされたデモサイト https://microcms-notification-media.vercel.app/ ソースコード https://github.com/y-hiraoka/microcms-notification-media 本内容は掻い摘んでいるので、より詳細な手順は是非ブログもご覧ください https://zenn.dev/chot/articles/web-push-with-microcms-and-fcm
それではよい PWA ライフを!