##ノーコードのAdaloはお手軽だがメールを送れないと最初思っていた。
ウェブアプリを作るのにノーコードサービスのAdaloは本当にお手軽。開発環境を整えてコーディングをがんばった時期もあったけど、一度これを使うと楽すぎてもう戻れない。
PCからの見栄えに若干不満があるけど、簡単なアプリなら1日もかからずに作れてしまうし、本当に最高。
ただ制約も多く、Adaloではメールを送る機能がないと最初は思っていた。
SendGridのAPIを使ってAdaloからメールを送る方法を見つけたのでやってみたら、改行があるとメールが送信できない問題に遭遇。
この記事を書いた時点ではこの問題を解決する詳しい記事がなかったので書いてみた。
結論から言うと、Integromatを間に挟んで、Webhooks→SendGridでメールを送るシナリオを作ることで解決(ちょっと面倒くさいけど)。
##参考にしたもの
最終的にたどり着いたのがこの神動画。
この動画ではSendGridを使わず既存のメールアカウント(Gmailなど)を使ってAdaloからメールを送信する方法を紹介しているのだが、SendGridでも同じことができるとわかったので、そのときのやり方をメモ。
##まずはIntegromatのアカウントを取得。
Integromatは簡単に言うとシナリオを作ることでZapierみたいに複数のアプリを連携させて処理が可能なサービス。
Adaloに関して言えばZapierよりも相性は良さそう。
まずはアカウントを取得した。
##Integromatのダッシュボードからシナリオを作る
Integromatのダッシュボードはこんな感じ。
Scenariosをクリックして、とりあえず自分のプロジェクトのフォルダを作って、その中にシナリオを作っていく。「Create a new scenario」とするとZapierでZapを作るような画面がでる。
真ん中の大きい+マークをクリックして、Webhooksモジュールを検索して選択する。
次にCustom Webhookを選択。
Addボタンをクリックして、Webhook Nameにわかりやすい名前をつけてSave。
出てくるURLをコピーして後で貼れるようにしておいたら、OKをクリック。
ここまで終わったらこのタブはそのままにしておいて、別のタブでAdaloで作業。
##Adaloのカスタムアクションを定義して、IntegromatのWebhooksにデータを送る
もう書くのがめんどくさくなってきたので、ここからはさっき紹介した神動画の4:10あたりから8:00あたりまでを参考に。
Bodyのところはjsonでemailやらsubject、bodyなどを追加していく。
下の記事に載っているjsonの記述を写経してみたりした。
##SendGridでAPIキーを取得
別タブでSendGridにログイン(アカウントない場合は無料プランで作成)して、ダッシュボードのAPI Keysから「Create API Key」をクリックしてAPIキーを作る。
名前は後でわかりやすいようにIntegromat(作っているサービス名)とした。
この時パーミッションをFull Accessにしないと後でエラーになってハマるので注意。
APIキーを取得したら、後で貼り付けられるようにしておく。
##IntegromatのScenarioに戻って、Webhooksの後ろにSendGridを追加。
Webhooksモジュールの右側の出っ張りをクリックすると下の図のように次のアクションを追加できるようになるので、
「Add another module」としてSendGridを検索して選択。
アクション一覧から「Send an Email」を選択。
次に出てくる画面のConnectionの横にあるAddボタンをクリック。ここにSendGridで作ったAPIキーを貼ってContinueボタンを押下。
ここまできたら、次のステップへ。
##IntegromatのSendGridモジュールで送信先や件名、本文などを設定。
引き続き上の動画の8:00くらいからを参考に。
動画ではEmailモジュールを使っているがSendGridモジュールでもだいたい同じで何とかなった。
Content TypeをPlaintextにするのを忘れずに。
あと動画の10:20あたりから話しているようにシナリオの保存と、シナリオをオンにすることを忘れずに(忘れるとちょっとめんどくさいです)。
あとのチェックなどはそのまま動画を見ながら進めてたらうまくいった。
##おわりに
動画のMichaelさまに感謝しかない。ホンマに神。さんきゅーそーまっちうぇるかむかもーん。
この動画でほぼ解決だったがすでにSendGridの有料アカウントを作ってしまっていて勿体なかったので、SendGridでできる方法を模索してみたところ、すでに持っていたSendGridのAPIキーがフルアクセスになっていなかったのでうまく行かずにはまった。
途中から書くのがめんどくさくなってしまい、最後の方はほぼ動画見てくださいみたいな感じで雑になってしまいました。
申し訳ありません。
同じ課題を持っている方の役に立つことがあればうれしいです。