Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
capacitor-firebase-push
Advanced tools
👉🏼 Note: this Plugin is developed for Capacitor V3
This Plugin it used for Firebase Push Messages. It does support Data (silent) notifications!
This and other Open-Source Cordova Plugins are developed in my free time. To help ensure this plugin is kept updated, new features are added and bugfixes are implemented quickly, please donate a couple of dollars (or a little more if you can stretch) as this will help me to afford to dedicate time to its maintenance. Please consider donating if you're using this plugin in an app that makes you money, if you're being paid to make the app, if you're asking for new features or priority bug fixes.
Table of Content
npm install capacitor-firebase-push
npx cap sync
❤️
This Plugin was created to match every requirement I had for my app. These Plugins helped my a lot to create this one:
Just follow the Android Setup Guide here
This plugin will use the following project variables (defined in your app's variables.gradle file):
$firebaseMessagingVersion
version of com.google.firebase:firebase-messaging (default: `21.1.0)On Android, the Push Notifications icon with the appropriate name should be added to the AndroidManifest.xml file:
<meta-data android:name="com.google.firebase.messaging.default_notification_icon" android:resource="@mipmap/push_icon_name" />
If no icon is specified Android will use the application icon, but push icon should be white pixels on a transparent backdrop. As the application icon is not usually like that, it will show a white square or circle. So it's recommended to provide the separate icon for Push Notifications.
Android Studio has an icon generator you can use to create your Push Notifications icon.
Start setting up your iOS Project like described here: https://capacitorjs.com/docs/v3/guides/push-notifications-firebase#integrating-firebase-with-our-native-ios-app
Stop before the Add the Firebase SDK via CocoaPods
Part - we don't need that one.
After you updated the project (npx cap update ios
), you have to add the following Initialization Code to your AppDelegate.swift:
Add the Firebase Import:
import Firebase
Add the following two functions:
func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {
Messaging.messaging().apnsToken = deviceToken
Messaging.messaging().token(completion: { (token, error) in
if let error = error {
NotificationCenter.default.post(name: .capacitorDidFailToRegisterForRemoteNotifications, object: error)
} else if let token = token {
NotificationCenter.default.post(name: .capacitorDidRegisterForRemoteNotifications, object: token)
}
})
}
func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable : Any], fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void) {
NotificationCenter.default.post(name: Notification.Name.init("didReceiveRemoteNotification"), object: completionHandler, userInfo: userInfo)
}
On iOS you can configure the way the push notifications are displayed when the app is in foreground by providing the `presentationOptions in your capacitor.config.ts as an Array of Strings you can combine.
Possible values are:
badge
: badge count on the app icon is updated (default value)sound
: the device will ring/vibrate when the push notification is receivedalert
: the push notification is displayed in a native dialogAn empty Array can be provided if none of the previous options are desired. pushNotificationReceived event will still be fired with the push notification information.
plugins: {
FirebasePush: {
presentationOptions: ["badge", "sound", "alert"]
}
}
These fields can be overwritten if you pass create_notification: true
in the data Part of the notification.
checkPermissions()
requestPermissions()
register()
unregister()
getBadgeNumber()
setBadgeNumber(...)
getDeliveredNotifications()
removeDeliveredNotifications(...)
removeAllDeliveredNotifications()
addListener('token', ...)
addListener('message', ...)
removeAllListeners()
checkPermissions() => Promise<PermissionStatus>
Check permission to receive push notifications.
Will always return "granted" on Android
Returns: Promise<PermissionStatus>
Since: 1.0.0
requestPermissions() => Promise<PermissionStatus>
Request permission to receive push notifications.
Will always return "granted" on Android
Returns: Promise<PermissionStatus>
Since: 1.0.0
register() => Promise<void>
Register the app to receive push notifications.
Since: 1.0.0
unregister() => Promise<void>
Should be called to unregister the Firebase Instance. For example if a User logs out.
Since: 1.1.0
getBadgeNumber() => Promise<BadgeCount>
Get icon badge Value
Only available on iOS
Returns: Promise<BadgeCount>
Since: 1.2.0
setBadgeNumber(options: BadgeCount) => Promise<void>
Set icon badge Value
Only available on iOS
Param | Type |
---|---|
options | BadgeCount |
Since: 1.2.0
getDeliveredNotifications() => Promise<NotificationsResult>
Get notifications in Notification Center
Returns: Promise<NotificationsResult>
Since: 1.2.0
removeDeliveredNotifications(options: NotificationsIds) => Promise<void>
Remove notifications from the notifications screen based on the id
Param | Type |
---|---|
options | NotificationsIds |
Since: 1.2.0
removeAllDeliveredNotifications() => Promise<void>
Remove all notifications from the notifications screen
Since: 1.2.0
addListener(eventName: 'token', listenerFunc: (result: TokenResult) => void) => Promise<PluginListenerHandle> & PluginListenerHandle
Called when a new fcm token is created
Param | Type |
---|---|
eventName | 'token' |
listenerFunc | (result: TokenResult) => void |
Returns: Promise<PluginListenerHandle> & PluginListenerHandle
Since: 1.0.0
addListener(eventName: 'message', listenerFunc: (message: any) => void) => Promise<PluginListenerHandle> & PluginListenerHandle
Called when a new message is received
Param | Type |
---|---|
eventName | 'message' |
listenerFunc | (message: any) => void |
Returns: Promise<PluginListenerHandle> & PluginListenerHandle
Since: 1.0.0
removeAllListeners() => Promise<void>
Remove all native listeners for this plugin.
Since: 1.0.0
Prop | Type | Since |
---|---|---|
receive | PermissionState | 1.0.0 |
Prop | Type | Since |
---|---|---|
count | number | 1.2.0 |
Prop | Type | Since |
---|---|---|
notifications | any[] | 1.2.0 |
Prop | Type | Since |
---|---|---|
ids | string[] | 1.2.0 |
Prop | Type |
---|---|
remove | () => Promise<void> |
Prop | Type |
---|---|
token | string |
'prompt' | 'prompt-with-rationale' | 'granted' | 'denied'
The full Changelog is available here
FAQs
Capacitor Plugin for Firebase Push
The npm package capacitor-firebase-push receives a total of 17 weekly downloads. As such, capacitor-firebase-push popularity was classified as not popular.
We found that capacitor-firebase-push demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.