Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

An API this library relies on will be turned off June 20, 2024 #68

Open
RandomEngy opened this issue Jul 17, 2023 · 27 comments
Open

An API this library relies on will be turned off June 20, 2024 #68

RandomEngy opened this issue Jul 17, 2023 · 27 comments

Comments

@RandomEngy
Copy link

This library calls https://fcm.googleapis.com/fcm/connect/subscribe for the final FCM subscription step, which I confirmed with the Firebase team to be slated for removal on June 20, 2024. This is not in the explicit list of URLs affected but is considered part of the "Legacy Web SDK".

@KillTrot
Copy link

Do you have any official ressource for that, where I can find more information and needed changes?

@RandomEngy
Copy link
Author

I linked to the official resource...

@developerfromjokela
Copy link

developerfromjokela commented Aug 14, 2023

Hmm, that's troubling. Did firebase team advise to which API endpoint we should change to keep it running? @RandomEngy

@RandomEngy
Copy link
Author

RandomEngy commented Aug 14, 2023

They did not. They referenced this guide to setting up FCM on a web app. I think the best bet right now is adapting from the firebase-js-sdk source code.

Per our engineers, the endpoint https://fcm.googleapis.com/fcm/connect/subscribe is included in the list of APIs that will be deprecated. It's part of Legacy Web SDK, although users may call it directly before. For now, I think you'll need to use FCM Web SDKs for obtaining FCM registration tokens.

I've also filed a request to include the endpoint in our FAQ page to avoid confusion moving forward. Let me know if there's anything else I could help you with.

@saenzramiro
Copy link

Any updates on this?

@RandomEngy
Copy link
Author

I took a stab at this today and decided I'm going to give up and use Amazon SNS for my desktop apps instead of trying to get FCM working. It has actual support for running in NodeJS and Rust. Fixing this library would mean implementing the web push protocol from scratch.

@alchemicas
Copy link

alchemicas commented Dec 25, 2023

Hello! Given that this library seems to not be supported by the author anymore, it's using soon-to-be deprecated APIs and has various bugs accumulated over time, I decided to write my own version.

It does everything that push-receiver already does and a little bit more. For the people who are going to migrate to my library, there is also a function exposed for retro-compatibility that subscribes to FCM using the sender ID.

Documentation: Aracna FCM Docs
Source: Aracna FCM Source

@RandomEngy
Copy link
Author

Oh heck yes. I was looking more into SNS and it's not really a good replacement for proper push. I think I may actually be able to save push notifications in Rust/Tauri and update fcm-push-listener by following this library.

@saenzramiro
Copy link

@alchemicas Sounds interesting! Thank you for sharing your library. Does it support Electron?

@developerfromjokela
Copy link

@alchemicas is there a possibility to not use FCM credentials like in this library? Or has the methodology changed in new API?

@alchemicas
Copy link

@alchemicas Sounds interesting! Thank you for sharing your library. Does it support Electron?

Hi @saenzramiro , yes it does work with Electron, only on the main process of course.

@alchemicas is there a possibility to not use FCM credentials like in this library? Or has the methodology changed in new API?

Hi @developerfromjokela , I can't give a 100% accurate answer because we're always talking about APIs that are not documented anywhere by Google, everything that is inside these libraries is an effort of reverse engineering. Having said this, the way the latest Firebase js sdk does things is with a new registration endpoint that requires an auth token generated with Firebase API Key, App ID and Project ID.

Maybe, and I say maybe, we could find an alternative way by reverse engineering the API calls made by native apps using FCM, but the way the web sdk does things is what's currently in my library.

If you're worried about exposing your Firebase api key, I'm pretty sure it's safe to have out in the open 👍

@developerfromjokela
Copy link

@alchemicas can I use sender ID argument? I have a third party service I want to receive push notifs from, with push-receiver i just put it there and it worked. In arcana i coudln't quite figure out.

@alchemicas
Copy link

@alchemicas can I use sender ID argument? I have a third party service I want to receive push notifs from, with push-receiver i just put it there and it worked. In arcana i coudln't quite figure out.

You can @developerfromjokela , just use the subscribeToFCM function. But by June you'll have to figure out a way to leverage the new APIs and generate tokens through registerToFCM.

If you already have a sender id you should also be able to get the firebase config somehow if you do have access to the firebase console.

@developerfromjokela
Copy link

@alchemicas can I use sender ID argument? I have a third party service I want to receive push notifs from, with push-receiver i just put it there and it worked. In arcana i coudln't quite figure out.

You can @developerfromjokela , just use the subscribeToFCM function. But by June you'll have to figure out a way to leverage the new APIs and generate tokens through registerToFCM.

If you already have a sender id you should also be able to get the firebase config somehow if you do have access to the firebase console.

I just tried with both registerToFCM and subscribeToFCM and none of them receive notifications. But using push-receiver notifications get delivered.

@pedroGitt
Copy link

It does everything that push-receiver already does and a little bit more. For the people who are going to migrate to my library, there is also a function exposed for retro-compatibility that subscribes to FCM using the sender ID.

Documentation: Aracna FCM Docs Source: Aracna FCM Source
@alchemicas

  • I just went through your documentation.. what is exactly the YOUR_VAPID_KEY ? The public key we generate from the "Cloud messaging" tab in the "Web Push certificates" section?
  • One could have expected a symmetrical use of ./google-service-account.json file from sendFcmMessage() in registerToFCM(),
  • I'm going to try your lib.. nice job!

@alchemicas
Copy link

I just tried with both registerToFCM and subscribeToFCM and none of them receive notifications. But using push-receiver notifications get delivered.

Uhm, I can't help you further without seeing how you're implementing it.
I'll try to publish an example this week on the repo to avoid any confusion.

  • I just went through your documentation.. what is exactly the YOUR_VAPID_KEY ? The public key we generate from the "Cloud messaging" tab in the "Web Push certificates" section?
  • One could have expected a symmetrical use of ./google-service-account.json file from sendFcmMessage() in registerToFCM(),
  • I'm going to try your lib.. nice job!
  • The VAPID key is entirely optional so you can omit it from the configuration and it will still work, if you want to know more about what it's for you can read the official specifications: https://datatracker.ietf.org/doc/rfc8292/
  • Mh, sendFcmMessage isn't meant to be used in clients because it requires secrets that must not be exposed, it should only be used in servers
  • Thank you! Let me know if it works well for you

@ychumpov
Copy link

ychumpov commented Jan 2, 2024

@alchemicas Does you use https://fcm.googleapis.com/fcm/connect/subscribe for your fcm registration?

@alchemicas
Copy link

@alchemicas Does you use https://fcm.googleapis.com/fcm/connect/subscribe for your fcm registration?

Hi @ychumpov , only if you use the deprecated subscribeToFCM function, otherwise you can use the new APIs with registerToFCM, it's all written in the docs

@developerfromjokela
Copy link

@alchemicas Does you use https://fcm.googleapis.com/fcm/connect/subscribe for your fcm registration?

Hi @ychumpov , only if you use the deprecated subscribeToFCM function, otherwise you can use the new APIs with registerToFCM, it's all written in the docs

If you could do a implementation like in https://github.com/BRUHItsABunny/go-android-firebase, so that I can just copy info from this mobile app and insert it there. Basixally you use different firebaseinstallations request body.

@miafoo
Copy link

miafoo commented Feb 10, 2024

I've just published this package: https://github.com/miafoo/fcm-web-push - it's based on this library + the rust implementation by @RandomEngy above. It's using the new APIs, is quite minimal and has very few dependencies. I've only tested it on a private electron project and it seems to work quite well there so far.

@ychumpov
Copy link

@alchemicas I noticed that in "old" implementation the appId was generated each time with new value:
// Should be unique by app - One GCM registration/token by app/appId
string appId = "wp:receiver.push.com#" + some kind of guid

Is it also the same in your lib?

@alchemicas
Copy link

@alchemicas I noticed that in "old" implementation the appId was generated each time with new value: // Should be unique by app - One GCM registration/token by app/appId string appId = "wp:receiver.push.com#" + some kind of guid

Is it also the same in your lib?

The app_id randomness is up to the integrator of @aracna/fcm

@choiman1559
Copy link

choiman1559 commented Mar 14, 2024

Guys, I just completed to write FCM receive library exclusive for electron
@cuj1559/electron-push-receiver

It was originally built based on this FCM library for electron, so it can be used almost as is, except that you need to add an API key.

If you're interested, Please check it out.

@javajuice1337
Copy link

I too was dreading the Google API removal for FCM subscribing so I tried the @aracna/fcm library, but the receiver would error when reading the notification.

I ended up porting the FCM registration from it into a fork of push-receiver here: https://github.com/javajuice1337/push-receiver-v2

Happy coding! 😃

@piyushgarg
Copy link

Has anyone able to get the notification from third party sender using the new fcm registration? As @developerfromjokela also checked, its not working.
In the old api there is a way to authorize the sender but in the newer API's there is no such as senderId.

async function registerFCM({ senderId, token }) {
...
 form : {
      authorized_entity : senderId,
....

@developerfromjokela
Copy link

Has anyone able to get the notification from third party sender using the new fcm registration? As @developerfromjokela also checked, its not working.

In the old api there is a way to authorize the sender but in the newer API's there is no such as senderId.


async function registerFCM({ senderId, token }) {

...

 form : {

      authorized_entity : senderId,

....

With old API i just set sender ID and it just worked fine with my usecase. On newer one it doesn't.

@amilich
Copy link

amilich commented May 31, 2024

-v2

I'm seeing unauthorized errors or invalid authorization credentials. Does this library support the new FCM authorization changes?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests