Дайте действие для удаленного уведомления Firebase в Swift - PullRequest
0 голосов
/ 07 марта 2019

Я пытаюсь обработать уведомление, отправленное с консоли Firebase, и когда пользователь нажимает на уведомление, оно выполняет определенное действие, но Пример: если ключ находится дома, он переводит пользователя на домашнюю страницу приложения. это мой делегат приложения, теперь все, что он делает, это открывает приложение. Есть ли что-нибудь, что нужно сделать из вида контроллера

var window: UIWindow?
let  gcmMessageIDKey = "gcm.message_id"

func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable: Any],
                 fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void) {

    Messaging.messaging().appDidReceiveMessage(userInfo)

    // Print message ID.
    if let messageID = userInfo[gcmMessageIDKey] {
        print("Message ID: \(messageID)")

    }

    // Print full message.
    print(userInfo)

    completionHandler(UIBackgroundFetchResult.newData)
}
func messaging(_ messaging: Messaging, didReceiveremoteMessage: MessagingRemoteMessage) {
    //         Convert to pretty-print JSON, just to show the message for testing

}

func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {
    Messaging.messaging().apnsToken = deviceToken
    connectToFCM()
}

func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {

    FirebaseApp.configure()
    if #available(iOS 10.0, *) {
        // For iOS 10 display notification (sent via APNS)
        UNUserNotificationCenter.current().delegate = self

        let authOptions: UNAuthorizationOptions = [.alert, .badge, .sound]
        UNUserNotificationCenter.current().requestAuthorization(
            options: authOptions,
            completionHandler: {_, _ in })
    } else {
        let settings: UIUserNotificationSettings =
            UIUserNotificationSettings(types: [.alert, .badge, .sound], categories: nil)
        application.registerUserNotificationSettings(settings)
    }

    Messaging.messaging().delegate = self

    application.registerForRemoteNotifications()


    return true
}


func applicationWillResignActive(_ application: UIApplication) {

}
func applicationDidEnterBackground(_ application: UIApplication) {
}

func applicationWillEnterForeground(_ application: UIApplication) {
    connectToFCM()
}
func applicationDidBecomeActive(_ application: UIApplication) {
}

func applicationWillTerminate(_ application: UIApplication) {
}
func tokenRefreshNorification(notification : NSNotification){
    let refreshedToken = InstanceID.instanceID().token()
    print("InstanceID Token: \(String(describing: refreshedToken))")
    FirebaseApp.configure()
    connectToFCM()
}
func connectToFCM(){
    Messaging.messaging().connect { (error) in
        if (error != nil){
            print("unable to connect to FCM \(error)")
        }else{
            print("Connected To FCM")
        }
    }
}

}

func userNotificationCenter(_ center: UNUserNotificationCenter,
                            willPresent notification: UNNotification,
                            withCompletionHandler completionHandler: @escaping (UNNotificationPresentationOptions) -> Void) {
    let userInfo = notification.request.content.userInfo

    // With swizzling disabled you must let Messaging know about the message, for Analytics
    Messaging.messaging().appDidReceiveMessage(userInfo)


    if let messageID = userInfo[gcmMessageIDKey] {
        print("Message ID: \(messageID)")
    }

    // Print full message.
    print("user info is :" ,userInfo)

    // Change this to your preferred presentation option
    completionHandler([.alert, .sound, .sound])
}
...