This project shows how to:
- use the various Firebase sign-in methods
- build a robust authentication flow
- use appropriate state management techniques to separate UI, logic and Firebase authentication code
- handle errors and present user-friendly error messages
- write production-ready code following best practices
Feel free to use this in your own projects. 😉
NOTE: This project will be kept up to date with the latest packages and Flutter version.
Google Sign-in
Facebook Sign-in
Email & Password auth
- Anonymous
- Email & Password
- Email link (passwordless)
- GitHub
- Phone
- Email & Password
- GitHub
- Phone
- Email verification (for email & password sign-in)
- Password reset
- Sign-in with custom token
- Navigation to email and password sign-in
- Google sign-in
- Facebook sign-in
- Anonymous sign-in
- Custom submit button with loading state
- Disable all input widgets while authentication is in progress
- Email regex validation
- Error hints
- Focus order (email -> password -> submit by pressing "next" on keyboard)
- Password of at least 8 characters
- Show/hide password
- Password reset flow
- Abstract
AuthService
class, modeled after thefirebase_auth
API -
FirebaseAuthService
implementation -
MockAuthService
for testing - Firebase project configuration for iOS & Android
- Toggle
FirebaseAuthService
andMockAuthService
at runtime via developer menu
- Logic inside models for better separation of concerns (using
ChangeNotifier
) - Use Provider package for dependency injection
- Platform-aware alert dialogs for confirmation/error messages
- Fully compliant with the official Flutter
analysis_options.yaml
rules
- Internationalization
- Full test coverage
- Improve documentation
To use this project with Firebase authentication, some configuration steps are required.
- Create a new project with the Firebase console.
- Add iOS and Android apps in the Firebase project settings.
- On Android, use
com.codingwithflutter.firebase_auth_demo_flutter
as the package name (a SHA-1 certificate fingerprint is also needed for Google sign-in) - then, download and copy
google-services.json
intoandroid/app
- To get SHA-1 certificate do:
- cd C:\Program Files\Java\YOUR_JDK_VERSION_HERE\bin
- Get debug.keystore path in my case is C:\Users\YOUR_USERNAME.android\debug.keystore
- Run "keytool -list -v -keystore C:\Users\name.android\debug.keystore -alias androiddebugkey -storepass android - keypass android" in cmd
- On iOS, use
com.codingwithflutter.firebaseAuthDemoFlutter
as the bundle ID - then, download and copy
GoogleService-Info.plist
intoiOS/Runner
, and add it to the Runner target in Xcode
Additional setup instructions for Google and Facebook sign-in:
- Google Sign-In on iOS: https://firebase.google.com/docs/auth/ios/google-signin
- Google Sign-In on Android: https://firebase.google.com/docs/auth/android/google-signin
- Facebook Login for Android: https://developers.facebook.com/docs/facebook-login/android
- Facebook Login for iOS: https://developers.facebook.com/docs/facebook-login/ios