I am using HTTP POST to send notifications to all users on the app. To do this I have a topic to subscribe to called "global". I want every user to be automatically subscribed to this topic to make sure they get the notifications (assuming they have notifications turned on).
Where in my code should I put the subscription to make sure they will always be subscribed? My fear is that I put it somewhere wrong and they never end up being subscribed. I tried to subscribe at the end of didFinishLaunchingWithOptions but it looks like it is too early to do it here (I guess since user may not have accepted notification prompt yet?).
Currently the subscription is in didRegisterForRemoteNotificationsWithDeviceToken however this does not get called on the first app run so for it to work I have to run the app a second time... Here is my relevant code in AppDelegate:
import UIKit
import Firebase
import FirebaseMessaging
import UserNotifications
@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate, UNUserNotificationCenterDelegate, FIRMessagingDelegate {
var window: UIWindow?
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
FIRApp.configure()
if #available(iOS 10.0, *) {
let authOptions: UNAuthorizationOptions = [.alert, .badge, .sound]
UNUserNotificationCenter.current().requestAuthorization(
options: authOptions,
completionHandler: {_, _ in })
// For iOS 10 display notification (sent via APNS)
UNUserNotificationCenter.current().delegate = self
// For iOS 10 data message (sent via FCM)
FIRMessaging.messaging().remoteMessageDelegate = self
} else {
let settings: UIUserNotificationSettings =
UIUserNotificationSettings(types: [.alert, .badge, .sound], categories: nil)
application.registerUserNotificationSettings(settings)
}
application.registerForRemoteNotifications()
return true
}
func applicationReceivedRemoteMessage(_ remoteMessage: FIRMessagingRemoteMessage) {
print("applicationReceivedRemoteMessage")
}
func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {
if let refreshedToken = FIRInstanceID.instanceID().token() {
print("InstanceID token: \(refreshedToken)")
FIRMessaging.messaging().subscribe(toTopic: "/topics/global")
}
}
@available(iOS 10.0, *)
func userNotificationCenter(_ center: UNUserNotificationCenter, willPresent notification: UNNotification, withCompletionHandler completionHandler: @escaping (UNNotificationPresentationOptions) -> Void) {
completionHandler(UNNotificationPresentationOptions.alert)
}
func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable: Any]) {
// If you are receiving a notification message while your app is in the background,
// this callback will not be fired till the user taps on the notification launching the application.
}
func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable: Any], fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void) {
// If you are receiving a notification message while your app is in the background,
// this callback will not be fired till the user taps on the notification launching the application.
}
fun sendMessage(title: String, content: String,topic: String) — This method is used to send Messages as Push Notifications to devices that are subscribed to a particular topic. Let's see how this method works internally. It uses HttpUrlConnection internally to trigger an API.
You can subscribe client app instances to any existing topic, or you can create a new topic. When you use the API to subscribe a client app to a new topic (one that does not already exist for your Firebase project), a new topic of that name is created in FCM and any client can subsequently subscribe to it.
Subscribe the client app to a topicBefore calling subscribeToTopic:topic , make sure that the client app instance has already received a registration token via the callback didReceiveRegistrationToken . Each time the app starts, FCM makes sure that all requested topics have been subscribed.
You need to have the topic subscription in two places.
One just after FIRApp.configure(). Also update the Firebase iOS SDK version. Seems like you're having an older version.
According to new version (FirebaseMessaging 2.0.1).
if Messaging.messaging().fcmToken != nil {
Messaging.messaging().subscribe(toTopic: “foo”)
}
Then the second one when token is refreshed.
func messaging(_ messaging: Messaging, didRefreshRegistrationToken fcmToken: String) {
Messaging.messaging().subscribe(toTopic: “foo”)
}
Here's the link to original answer. Check the answer contributor has provided.
https://github.com/firebase/quickstart-ios/issues/307
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With