flutter_gb_authentication_fire_social 1.0.0
flutter_gb_authentication_fire_social: ^1.0.0 copied to clipboard
A utility package when integrating authentication with social media (facebook,apple,google) using BLoC pattern
Authentication Fire Social #
Features #
⚠️ WARNING ⚠️ #
First of all, you should make sure that the Firebase project is already configured and you have access to it.
Necessary Dependencies #
Add the following dependencies to your pubspec.yaml
file:
firebase_auth: ^3.3.20 # Or higher
firebase_core: ^1.18.0 # Or higher
flutter_gb_authentication_fire_social:
git:
url: git@gitlab.com:geekbears/utilities/flutter/gb-authentication-fire-social.git
ref: 0.6.0 # Or higher
# if using Facebook Auth
flutter_facebook_auth: ^4.3.4+2 # Or higher
# if using Google Auth
google_sign_in: ^5.3.3
# if using Apple Auth
sign_in_with_apple: ^4.1.0 # Or higher
Android Configuration #
-
Go to the Firebase Console and then open the project configuration.
-
Scroll down until Your apps section, you will see the configured applications.
-
Click the google-services.json button to download the configuration file in both Android apps (Dev and Production).
-
Now in your project folder, go to the
android/app/src/
folder. -
Create a folder for each flavor inside the mentioned folder above and paste the corresponding
google-services.json
file for each one. -
After that, in the
android/build.gradle
file, add the Google Services plugin within dependencies.
dependencies {
classpath 'com.android.tools.build:gradle:4.1.0'
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
classpath 'com.google.gms:google-services:4.3.10' // Google Services plugin
}
- In the
android/app/build.gradle
file, apply the Google Services plugin.
apply plugin: 'com.android.application'
apply plugin: 'kotlin-android'
apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle"
apply plugin: 'com.google.gms.google-services' // Google Services plugin
- We need to implement Multidex support in our Gradle dependencies inside the
android/app/build.gradle
file to prevent any issues while using Firebase.
dependencies {
implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
implementation 'com.android.support:multidex:2.0.1' // MultiDex
}
- Also, we will need to enable the Multidex support within the mentioned file above but inside of
defaultConfig
.
defaultConfig {
applicationId "com.example.app"
minSdkVersion flutter.minSdkVersion
targetSdkVersion flutter.targetSdkVersion
versionCode flutterVersionCode.toInteger()
versionName flutterVersionName
multiDexEnabled true // Enable MultiDex
}
-
Google
- Google Config
- Make sure you add your key SHA to firebase project configuration.
- Google Config
-
Facebook
-
Facebook Config
- If your project handles login-signup with Facebook, you should add your
facebook_app_id
andfacebook_client_token
withinandroid/app/src/main/res/values/strings.xml
file.
<resources> <string name="facebook_app_id">YOUR_ID</string> <string name="facebook_client_token">YOUR_CLIENT_TOKEN</string> </resources>
-
You will need to add a query and meta-data tag within
android/src/app/main/AndroidManifest.xml
file to finish the FaceBook configuration.<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.boxxie.app"> <!-- If using Facebook ADD THIS queries --> <queries> <provider android:authorities="com.facebook.katana.provider.PlatformProvider" /> </queries> <application android:label="@string/app_name" android:name="${applicationName}" android:icon="@mipmap/launcher_icon"> <!-- If using Facebook ADD BOTH meta-data --> <meta-data android:name="com.facebook.sdk.ApplicationId" android:value="@string/facebook_app_id" /> <meta-data android:name="com.facebook.sdk.ClientToken" android:value="@string/facebook_client_token" /> ...More code </application> ...More code </manifest>
- If your project handles login-signup with Facebook, you should add your
-
-
Apple Sign In
- Apple Config
- Activate Apple Sign-In method under Firebase Console → Authentication → Sign In method
- We recommend following these instructions to configure Apple Services to create an Apple Sign-in service ID
- Create Apple Sign-in service
- Enable Apple Sign-in capability on each App ID
- Generate a Key for the Apple Sign in Service
- Fill Firebase configuration data in Apple Sign-in method
- Configure
AuthenticationFireSocialConfigModel.appleWebAuthentication (WebAuthenticationOptions)
setting.
- Apple Config
iOS Configuration #
-
Go to the Firebase Console and then open the project configuration.
-
Scroll down until Your apps section, you will see the configured applications.
-
Click the GoogleService-Info.plist button to download the configuration file in both iOS apps (Dev and Production).
-
Now in your project folder, go to the
ios
folder and create a new one calledconfig
, in case it doesn’t exists. -
Within
config
folder create a folder for each scheme and paste the correspondingGoogleService-Info.plist
file for each one. -
Make sure you follow this instructions if using a flavored project.
-
Open your
ios/Runner/Info.plist
file and add the following code.
<key>CFBundleURLTypes</key>
<array>
<dict>
<key>CFBundleTypeRole</key>
<string>Editor</string>
<key>CFBundleURLSchemes</key>
<array>
<!-- Copied from GoogleService-Info.plist key REVERSED_CLIENT_ID -->
<string>$(GOOGLE_REVERSED_ID)</string>
</array>
</dict>
</array>
- For Facebook:
-
Add in you
ios/Runner/Info.plist
:<key>CFBundleURLTypes</key> <array> <dict> <key>CFBundleURLSchemes</key> <array> <string>fb{FACEBOOK_CLIENT_ID}</string> </array> </dict> </array> <key>FacebookAppID</key> <string>{FACEBOOK_CLIENT_ID}</string> <key>FacebookClientToken</key> <string>{FACEBOOK_CLIENT_TOKEN}</string> <key>FacebookDisplayName</key> <string>{App Name}</string> <key>LSApplicationQueriesSchemes</key> <array> <string>fbapi</string> <string>fb-messenger-share-api</string> <string>tel</string> <string>https</string> <string>http</string> </array>
-
- For Apple:
- Enable Apple Sign-In capability inside the XCode project.
Injection Configuration #
- In your
lib/core/injection_config.dart
file you should create an instance ofAuthenticationFireSocialConfigModel
and add your custom endpoints, do it withinconfigureDependencies
method.
final authConfig = AuthenticationFireSocialConfigModel(
loginCredentialsAPIendpoint: () {
return EnvironmentConfig.api_url + ApiEndpoints.login();
},
customLoginRequestMapper: (email, password) {
return {
"emailOrUsername": email,
"password": password,
};
},
signupCredentialsAPIendpoint: () {
return EnvironmentConfig.api_url + ApiEndpoints.signup();
},
authenticateGoogleAPIendpoint: (_) {
return EnvironmentConfig.api_url + ApiEndpoints.authFirebaseSocial();
},
authenticateFacebookAPIendpoint: (_) {
return EnvironmentConfig.api_url + ApiEndpoints.authFirebaseSocial();
},
authenticateAppleAPIendpoint: (_) {
return EnvironmentConfig.api_url + ApiEndpoints.authFirebaseSocial();
},
);
- Also you will need call
configureAuthenticationAdvancedInjection
inside ofconfigureDependencies
method.
// configure Auth Package
await configureAuthenticationAdvancedInjection(
environment,
authConfig,
customAuthServiceFactory: (() {
// register custom impl of auth Service
return CustomAuthenticationServiceImpl(
config: authConfig,
httpClient: getIt(),
sharedPreferences: getIt(),
appleSignInFacade: getIt(),
facebookSignInFacade: getIt(),
googleSignInFacade: getIt(),
logger: getAuthenticationSocialLogger(authConfig),
);
}),
);
Firebase Initialization #
Make sure you initialize Firebase at the beginning of your application, normally main.dart.