Skip to content

AppCheck Error: reCAPTCHA placeholder element must be empty #3089

Open
@anisabboud

Description

@anisabboud

Version info

  • Angular: 13.0.3
  • Firebase: 9.6.0 (released last week)
  • AngularFire: 7.2.0 (with rxfire 6.0.3)
  • FirebaseUI: 6.0.0 (with firebaseui-angular 6.1.0)

How to reproduce these conditions

Added and configured Firebase App Check following the documentation. In app.module.ts:

    provideAppCheck(() => initializeAppCheck(getApp(),
      { provider: new ReCaptchaV3Provider(recaptcha3SiteKey), isTokenAutoRefreshEnabled: true })),

Error in production build: (ng build --configuration=production deployed on Firebase Hosting)

Error: reCAPTCHA placeholder element must be empty which then causes: @firebase/firestore: Could not reach Cloud Firestore backend.

reCAPTCHA error in prod

Why this happens?

According to an old Stackoverflow question, it might be because "You are loading the google recaptcha library twice."

Network tab

Indeed, looking at the Network tab, recaptcha__en.js is loaded twice.
reCAPTCHA loaded twice

Could the second recaptcha be loaded by something else?

I initially suspected FirebaseUI is loading the second recaptcha.
However, commenting out provideAppCheck() in app.module.ts then checking the network tab shows 0 instances of recaptcha__en.js, leading to the conclusion that both were loaded through provideAppCheck().

Summary

provideAppCheck() seems to load recaptcha library twice, causing a console error and disrupting Firestore completely.

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions