@react-native-firebase/messaging
Version:
React Native Firebase - React Native Firebase provides native integration of Firebase Cloud Messaging (FCM) for both Android & iOS. FCM is a cost free service, allowing for server-device and device-device communication. The React Native Firebase Messaging
247 lines • 13.8 kB
TypeScript
import type { Messaging, RemoteMessage, NativeTokenOptions, GetTokenOptions, IOSPermissions, AuthorizationStatus, SendErrorEvent } from './types/messaging';
import type { ReactNativeFirebase } from '@react-native-firebase/app';
/**
* Returns a Messaging instance for the given app.
* @param app - FirebaseApp. Optional.
* @returns Messaging instance
*/
export declare function getMessaging(app?: ReactNativeFirebase.FirebaseApp): Messaging;
/**
* Removes access to an FCM token previously authorized by its scope.
* Messages sent by the server to this token will fail.
* @param messaging - Messaging instance.
* @param tokenOptions - Options to override senderId (iOS) and projectId (Android).
* @returns Promise that resolves when the token is deleted.
*/
export declare function deleteToken(messaging: Messaging, tokenOptions?: NativeTokenOptions): Promise<void>;
/**
* Returns an FCM token for this device. Optionally, you can specify custom options for your own use case.
* @param messaging - Messaging instance.
* @param options - Options to override senderId (iOS) and appName.
* @returns Promise that resolves with the FCM token.
*/
export declare function getToken(messaging: Messaging, options?: GetTokenOptions & NativeTokenOptions): Promise<string>;
/**
* When any FCM payload is received, the listener callback is called with a `RemoteMessage`.
* > This subscriber method is only called when the app is active (in the foreground).
* @param messaging - Messaging instance.
* @param listener - Called with a `RemoteMessage` when a new FCM payload is received from the server.
* @returns Function to unsubscribe from the message listener.
*/
export declare function onMessage(messaging: Messaging, listener: (message: RemoteMessage) => any): () => void;
/**
* When the user presses a notification displayed via FCM, this listener will be called if the app
* has opened from a background state.
* @param messaging - Messaging instance.
* @param listener - Called with a `RemoteMessage` when a notification press opens the application.
* @returns Function to unsubscribe from the notification opened listener.
*/
export declare function onNotificationOpenedApp(messaging: Messaging, listener: (message: RemoteMessage) => any): () => void;
/**
* Called when a new registration token is generated for the device. For example, this event can happen when a
* token expires or when the server invalidates the token.
* > This subscriber method is only called when the app is active (in the foreground).
* @param messaging - Messaging instance.
* @param listener - Called with a FCM token when the token is refreshed.
* @returns Function to unsubscribe from the token refresh listener.
*/
export declare function onTokenRefresh(messaging: Messaging, listener: (token: string) => any): () => void;
/**
* On iOS, messaging permission must be requested by the current application before messages can
* be received or sent.
* @param messaging - Messaging instance.
* @param iosPermissions - All the available permissions for iOS that can be requested.
* @returns Promise that resolves with the authorization status.
*/
export declare function requestPermission(messaging: Messaging, iosPermissions?: IOSPermissions): Promise<AuthorizationStatus>;
/**
* Returns whether messaging auto initialization is enabled or disabled for the device.
* @param messaging - Messaging instance.
* @returns Boolean indicating whether auto initialization is enabled.
*/
export declare function isAutoInitEnabled(messaging: Messaging): boolean;
/**
* Sets whether messaging auto initialization is enabled or disabled for the device.
* @param messaging - Messaging instance.
* @param enabled - A boolean value to enable or disable auto initialization.
* @returns Promise that resolves when the setting is updated.
*/
export declare function setAutoInitEnabled(messaging: Messaging, enabled: boolean): Promise<void>;
/**
* When a notification from FCM has triggered the application to open from a quit state,
* this method will return a `RemoteMessage` containing the notification data, or `null` if
* the app was opened via another method.
* @param messaging - Messaging instance.
* @returns Promise that resolves with the initial notification or null.
*/
export declare function getInitialNotification(messaging: Messaging): Promise<RemoteMessage | null>;
/**
* When the app is opened from iOS notifications settings from a quit state,
* this method will return `true` or `false` if the app was opened via another method.
* @param messaging - Messaging instance.
* @returns Promise that resolves with a boolean indicating if the app was opened from settings.
*/
export declare function getDidOpenSettingsForNotification(messaging: Messaging): Promise<boolean>;
/**
* Returns whether the root view is headless or not
* i.e true if the app was launched in the background (for example, by data-only cloud message)
* @param messaging - Messaging instance.
* @returns Promise that resolves with a boolean indicating if the app is headless.
*/
export declare function getIsHeadless(messaging: Messaging): Promise<boolean>;
/**
* On iOS, if your app wants to receive remote messages from FCM (via APNs), you must explicitly register
* with APNs if auto-registration has been disabled.
* @param messaging - Messaging instance.
* @returns Promise that resolves when the device is registered.
*/
export declare function registerDeviceForRemoteMessages(messaging: Messaging): Promise<void>;
/**
* Returns a boolean value whether the user has registered for remote notifications via
* `registerDeviceForRemoteMessages()`. For iOS. Android always returns `true`.
* @param messaging - Messaging instance.
* @returns Boolean indicating if the device is registered for remote messages.
*/
export declare function isDeviceRegisteredForRemoteMessages(messaging: Messaging): boolean;
/**
* Unregisters the app from receiving remote notifications.
* @param messaging - Messaging instance.
* @returns Promise that resolves when the device is unregistered.
*/
export declare function unregisterDeviceForRemoteMessages(messaging: Messaging): Promise<void>;
/**
* On iOS, it is possible to get the users APNs token. This may be required if you want to send messages to your
* iOS devices without using the FCM service.
* @param messaging - Messaging instance.
* @returns Promise that resolves with the APNs token or null.
*/
export declare function getAPNSToken(messaging: Messaging): Promise<string | null>;
/**
* On iOS, This method is used to set the APNs Token received by the application delegate.
* Note that the token is expected to be a hexadecimal string, as it is an NSData type in
* the underlying native firebase SDK, and raw data may only be passed as a string if it is
* hex encoded. Calling code is responsible for correct encoding, you should verify by comparing
* the results of `getAPNSToken()` with your token parameter to make sure they are equivalent.
*
* Messaging uses method swizzling to ensure that the APNs token is set automatically.
* However, if you have disabled swizzling by setting FirebaseAppDelegateProxyEnabled to NO
* in your app's Info.plist, you should manually set the APNs token in your application
* delegate's application(_:didRegisterForRemoteNotificationsWithDeviceToken:) method.
*
* If you would like to set the type of the APNs token, rather than relying on automatic
* detection, provide a type of either 'prod', 'sandbox'. Omitting the type parameter
* or specifying 'unknown' will rely on automatic type detection based on provisioning profile.
*
* At a native level you may also call objective-c `[FIRMessaging setAPNSToken];` as needed.
*
* @param messaging - Messaging instance.
* @param token - A hexadecimal string representing your APNs token.
* @param type - Optional. A string specifying 'prod', 'sandbox' or 'unknown' token type.
* @returns Promise that resolves when the APNs token is set.
*/
export declare function setAPNSToken(messaging: Messaging, token: string, type?: string): Promise<void>;
/**
* Returns a `AuthorizationStatus` as to whether the user has messaging permission for this app.
* @param messaging - Messaging instance.
* @returns Promise that resolves with the authorization status.
*/
export declare function hasPermission(messaging: Messaging): Promise<AuthorizationStatus>;
/**
* Called when the FCM server deletes pending messages.
* @param messaging - Messaging instance.
* @param listener - Called when the FCM deletes pending messages.
* @returns Function to unsubscribe from the deleted messages listener.
*/
export declare function onDeletedMessages(messaging: Messaging, listener: () => void): () => void;
/**
* When sending a `RemoteMessage`, this listener is called when the message has been sent to FCM.
* @param messaging - Messaging instance.
* @param listener - Called when the FCM sends the remote message to FCM.
* @returns Function to unsubscribe from the message sent listener.
*/
export declare function onMessageSent(messaging: Messaging, listener: (messageId: string) => any): () => void;
/**
* When sending a `RemoteMessage`, this listener is called when an error is thrown and the
* message could not be sent.
* @param messaging - Messaging instance.
* @param listener - Called when the FCM sends the remote message to FCM.
* @returns Function to unsubscribe from the send error listener.
*/
export declare function onSendError(messaging: Messaging, listener: (evt: SendErrorEvent) => any): () => void;
/**
* Set a message handler function which is called when the app is in the background
* or terminated. In Android, a headless task is created, allowing you to access the React Native environment
* to perform tasks such as updating local storage, or sending a network request.
* @param messaging - Messaging instance.
* @param handler - Called when a message is sent and the application is in a background or terminated state.
* @returns void
*/
export declare function setBackgroundMessageHandler(messaging: Messaging, handler: (message: RemoteMessage) => Promise<any>): void;
/**
* Set a handler function which is called when the `${App Name} notifications settings`
* link in iOS settings is clicked.
* @param messaging - Messaging instance.
* @param handler - Called when link in iOS settings is clicked.
* @returns void
*/
export declare function setOpenSettingsForNotificationsHandler(messaging: Messaging, handler: (message: RemoteMessage) => any): void;
/**
* Send a new `RemoteMessage` to the FCM server.
* @param messaging - Messaging instance.
* @param message - A `RemoteMessage` interface.
* @returns Promise that resolves when the message is sent.
*/
export declare function sendMessage(messaging: Messaging, message: RemoteMessage): Promise<void>;
/**
* Apps can subscribe to a topic, which allows the FCM server to send targeted messages to only those
* devices subscribed to that topic.
* @param messaging - Messaging instance.
* @param topic - The topic name.
* @returns Promise that resolves when the subscription is complete.
*/
export declare function subscribeToTopic(messaging: Messaging, topic: string): Promise<void>;
/**
* Unsubscribe the device from a topic.
* @param messaging - Messaging instance.
* @param topic - The topic name.
* @returns Promise that resolves when the unsubscription is complete.
*/
export declare function unsubscribeFromTopic(messaging: Messaging, topic: string): Promise<void>;
/**
* Returns a boolean whether message delivery metrics are exported to BigQuery.
* @param messaging - Messaging instance.
* @returns Boolean indicating if message delivery metrics are exported to BigQuery.
*/
export declare function isDeliveryMetricsExportToBigQueryEnabled(messaging: Messaging): boolean;
/**
* Returns a boolean whether message delegation is enabled. Android only,
* always returns false on iOS
* @param messaging - Messaging instance.
* @returns Boolean indicating if notification delegation is enabled.
*/
export declare function isNotificationDelegationEnabled(messaging: Messaging): boolean;
/**
* Sets whether message notification delegation is enabled or disabled.
* The value is false by default. Set this to true to allow delegation of notification to Google Play Services.
* Note if true message handlers will not function on Android, and it has no effect on iOS
* @param messaging - Messaging instance.
* @param enabled - A boolean value to enable or disable delegation of messages to Google Play Services.
* @returns Promise that resolves when the setting is updated.
*/
export declare function setNotificationDelegationEnabled(messaging: Messaging, enabled: boolean): Promise<void>;
/**
* Checks if all required APIs exist in the browser.
* @param messaging - Messaging instance.
* @returns Promise that resolves with a boolean indicating if the APIs are supported.
*/
export declare function isSupported(messaging: Messaging): Promise<boolean>;
/**
* Sets whether message delivery metrics are exported to BigQuery is enabled or disabled.
* The value is false by default. Set this to true to allow exporting of message delivery metrics to BigQuery.
* @param messaging - Messaging instance.
* @param enabled - A boolean value to enable or disable exporting of message delivery metrics to BigQuery.
* @returns Promise that resolves when the setting is updated.
*/
export declare function experimentalSetDeliveryMetricsExportedToBigQueryEnabled(messaging: Messaging, enabled: boolean): Promise<void>;
export { AuthorizationStatus, NotificationAndroidPriority, NotificationAndroidVisibility, } from './statics';
//# sourceMappingURL=modular.d.ts.map