diff --git a/android/app/build.gradle b/android/app/build.gradle
index 7aef609b..3727217d 100644
--- a/android/app/build.gradle
+++ b/android/app/build.gradle
@@ -113,11 +113,11 @@ flutter {
}
dependencies {
- implementation 'com.google.crypto.tink:apps-webpush:1.3.0-rc1'
- implementation 'com.google.firebase:firebase-core:17.2.1'
+ implementation 'com.google.crypto.tink:apps-webpush:1.3.0'
+ implementation 'com.google.firebase:firebase-messaging:20.1.6'
implementation 'org.bouncycastle:bcprov-jdk16:1.46'
- testImplementation 'junit:junit:4.12'
+ testImplementation 'junit:junit:4.13'
androidTestImplementation 'androidx.test:runner:1.2.0'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.2.0'
diff --git a/android/app/src/main/AndroidManifest.xml b/android/app/src/main/AndroidManifest.xml
index 674c37b7..74b4b424 100644
--- a/android/app/src/main/AndroidManifest.xml
+++ b/android/app/src/main/AndroidManifest.xml
@@ -15,16 +15,18 @@
+
onBackgroundMessage(Map message) {
+ //TODO: Add functionality
+ _logger.info("onBackgroundMessage $message");
+ return Future(null);
+}
+
class PushManager {
final _firebaseMessaging = FirebaseMessaging();
final _notificationManager = DisplayNotificationManager();
- final _logger = Logger("push_manager");
BuildContext _buildContext;
PushBloc _pushBloc;
@@ -83,11 +90,13 @@ class PushManager {
final decryptedContent = await decryptAsync(notificationData.content);
if (_isValidationPush(decryptedContent)) {
final validation = _getPushValidation(decryptedContent).validation;
+ _logger.info("Validation message with state validation: $validation received");
_pushBloc.add(ValidateMetadata(validation: validation));
} else {
final pushChatMessage = _getPushChatMessage(decryptedContent);
final fromEmail = pushChatMessage.fromEmail;
final body = "I sent you a new chat message"; // TODO replace decrypt
+ _logger.info("Chat message received from: $fromEmail");
await _notificationManager.showNotificationFromPushAsync(fromEmail, body);
}
}
@@ -103,6 +112,7 @@ class PushManager {
_logger.info("onLaunch $message");
return Future(null);
},
+ onBackgroundMessage: onBackgroundMessage,
);
_firebaseMessaging.requestNotificationPermissions(const IosNotificationSettings(sound: true, badge: true, alert: true));
}