今回はFlutterFlowとFireBaseの連携してFlutterFlowのプロジェクトを作成するところまでやってみたいと思います。
FlutterFlowについてはこちらをご覧ください。
FlutterFlow で FireBase と連携する目的
FlutterFlowとFireBaseを連携する目的はユーザのログインなどの認証情報や、画像などのアセットをアプリから使用する場合に、情報の保存先として使用するために連携します。
特に使わないという方は連携は不要な操作になりますのでご注意ください。
Firebaseの設定
data:image/s3,"s3://crabby-images/ad1b3/ad1b3bafa824837aac22aee099ae549c2c39bf77" alt=""
まずはfirebaseにログインします。
「使ってみる」をクリックします。
data:image/s3,"s3://crabby-images/d778a/d778a19a62c1221bd46d167b7de46685dcb151f6" alt=""
プロジェクトを作成します。
data:image/s3,"s3://crabby-images/180d7/180d7941fb4558f57a4c09ef68160f85d1bcd449" alt=""
任意のプロジェクト名を付けたら、チェックボックスにチェックを入れて「続行」を押します。
data:image/s3,"s3://crabby-images/f6dcc/f6dcc3b2de41e42e2df297695050756909dfc380" alt=""
今回アナリティクスは使いませんので「有効」をOFFにします。
data:image/s3,"s3://crabby-images/84d8d/84d8d8018dc4879dc67f7fffa39526875980dd84" alt=""
ダッシュボードに遷移すれば、Firebaseの事前設定は完了です。
FlutterFlowに接続するためには、Firebaseでいくつかの設定が必要となります。
まずは、FlutterFlowがFirebaseにアクセスするためのユーザーを追加していきます。
プロジェクトの設定
data:image/s3,"s3://crabby-images/334ec/334ec7e81f699d65b9647d9e4af4c999f3328d9f" alt=""
ここでは、プロジェクトに使う権限の設定などをしています。
サイドバーのプロジェクトの概要の横にある歯車マークより、「プロジェクトの設定」をクリックします。
data:image/s3,"s3://crabby-images/2903e/2903e2c5bec8e0adc373cbc8d843138b89881086" alt=""
「メンバーを追加」を押します。
data:image/s3,"s3://crabby-images/6da94/6da94ada14617035bab33f6076e8593bc2ad1647" alt=""
次に、メールアドレスとロールを以下のように設定します。
メールアドレス:firebase@flutterflow.io
ロール:編集者
data:image/s3,"s3://crabby-images/744ec/744ec7634a308bcd2afec7824520c1c0768cde66" alt=""
権限に関する詳細設定に移動します。
data:image/s3,"s3://crabby-images/2352c/2352ce6dcc9d5f66ade7c6db7589641ca13c1452" alt=""
firebase@flutterflow.ioを含む行の「メンバーの編集」(右端にある鉛筆マーク)を押します。
data:image/s3,"s3://crabby-images/f1e32/f1e32fade9efaa929df8033b451cee2f1660b5e6" alt=""
サービスアカウントユーザーを検索してクリックします。
data:image/s3,"s3://crabby-images/943ca/943ca4f0b9533cc6c7d0f27d7a9d8750ac9e753f" alt=""
「Cloud Functions 管理者」と「サービスアカウントユーザー」を選択肢から選んで追加します。
Firestore データベースを構成する
FlutterFlowで使用するFirestoreの設定をします。
data:image/s3,"s3://crabby-images/1b65b/1b65b75e8bc5dcf5c199b0297e91785a7d95647f" alt=""
プロジェクトの Firebase ダッシュボードから、左端のメニューに移動します。
「Firestore データベース」を選択ます。
data:image/s3,"s3://crabby-images/f4c89/f4c897c832cb2a234608faf0462a99ed8aba5f6b" alt=""
「データベースの作成」 を選択します。
data:image/s3,"s3://crabby-images/d3c34/d3c34fff77ab5cbe24ea6eaee43d5d2a901bfa8a" alt=""
テストモード
テストモードの場合は、基本的に全てのアクセスが許可されています。 インターネットに公開しないで、開発する場合は、このモードを使うとまずは開発の基本的な機能の開発に集中できます。期限をつけて許可をしているので設定した日時(通常はデータベースを作成してから 30 日間)を過ぎるとアクセスができなくなります。
ロックモード(本番環境モード)
ロックモード(本番環境モード)デフォルト ルールは、すべてのユーザーに対してアクセスを拒否します。
とりあえず繋げること優先したい人はテストモードでOKです。
今回はテストモードして、テスト後にルールを変更する方法をとります。
テストモードだと以下の日時が指定されているはず。一定期間を過ぎるとアクセス拒否されると思いますが、書き直せばOKです。
allow read, write: if request.time < timestamp.date(2025, 1, 16);
参考:セキュリティルール
https://firebase.google.com/docs/rules/basics?authuser=0&hl=ja
https://coconala.com/blogs/1638666/61563
data:image/s3,"s3://crabby-images/e8ae5/e8ae5f9589ed86d82890d178d8c6e6f6fa33a91c" alt=""
ロケーションは日本を選択します。
参考:ロケーション
https://firebase.google.com/docs/projects/locations?authuser=0&hl=ja
その他
認証を使いたい方はこっちも参考にしてください。
https://firebase.google.com/docs/auth?hl=ja
https://docs.flutterflow.io/data-and-backend/firebase/authentication
data:image/s3,"s3://crabby-images/4127e/4127e5be35e3d172ea244ef96cc00dbacdd713cb" alt=""
Authenticationを押します。
data:image/s3,"s3://crabby-images/b84a1/b84a1613f599661a967ae0d7e4775646753590e7" alt=""
始めるを押します。
data:image/s3,"s3://crabby-images/c3adc/c3adc836808c93ab6cbdaf7cb93f8b699f1d7770" alt=""
メール/パスワードを押します。
data:image/s3,"s3://crabby-images/4ec5a/4ec5a11378cc75bb69761e4254e5cf3ab5e9939d" alt=""
有効にします。
これでOKです。
FlutterFlowのFireBaseの設定
data:image/s3,"s3://crabby-images/334ec/334ec7e81f699d65b9647d9e4af4c999f3328d9f" alt=""
左メニューからプロジェクトの設定を選択します。
data:image/s3,"s3://crabby-images/98ca1/98ca18e588bb266fe7a6fd76dc309c8fb0c9e1af" alt=""
プロジェクトIDをコピーします。
FlutterFlowの画面に移動します。
https://app.flutterflow.io/dashboard
data:image/s3,"s3://crabby-images/b6ab9/b6ab902e10c6ae1eda49ebb528f53109f43bee00" alt=""
プロジェクト名をいれます。
テンプレートを選んでプロジェクトを新規に作成します。
data:image/s3,"s3://crabby-images/cad10/cad10cd46789b72aac2b730c79d08a90c4b02149" alt=""
Setuo Firebaseにチェックを入れ次へ。
data:image/s3,"s3://crabby-images/07859/078593381ff9fd7b785849e5fc66ab810fd4693b" alt=""
コピーしたFireBaseのプロジェクトIDを入力し、Connectを押します。
data:image/s3,"s3://crabby-images/7a9e5/7a9e57fb7a1422d6802dfebeb9d574ebd19c7b1c" alt=""
Auto Generate Config Filesをクリックしてください。
他のオプションは、Enable Authentication がユーザー認証機能、Create user Collectionがユーザーテーブルを自動生成してくれる機能です。
ユーザー登録画面とログイン画面を使う場合は、「Unset」をクリックしてテンプレートを選んでください。
Start Buildingを押せば完了です。
data:image/s3,"s3://crabby-images/2fbc1/2fbc1e095c388165c45a09e6ae818c2617a80d73" alt=""
オプションによっては上記がでます。
DeployしてStart Buildingを押してください。
data:image/s3,"s3://crabby-images/83450/83450cdd563661a9bbe0415f609bdaedb2693a67" alt=""
ユーザーテーブルを自動生成した場合は上記のようにユーザテーブルができてますね。
今回はここまでです。
お疲れ様でした!