欢迎参加我们将于 2022 年 10 月 18 日举办的 Firebase 峰会(线上线下同时进行),了解 Firebase 如何帮助您加快应用开发速度、满怀信心地发布应用并在之后需要时轻松地扩大应用规模。立即报名

Habilitar el cumplimiento de App Check para Cloud Functions

Cuando comprenda cómo App Check afectará a sus usuarios y esté listo para continuar, puede habilitar la aplicación de App Check.

Para comenzar a hacer cumplir los requisitos del token de verificación de aplicaciones en sus funciones en la nube a las que se puede llamar, modifique sus funciones para verificar si hay tokens de verificación de aplicaciones válidos, como se muestra a continuación. Una vez que habilite la aplicación, se rechazarán todas las solicitudes no verificadas.

  1. Actualice la firebase-functions de base de fuego de su proyecto a la versión 3.14.0 o más reciente:

    npm install firebase-functions@">=3.14.0"
    

    Y actualice la dependencia firebase-admin de su proyecto a la versión 9.8.0 o posterior:

    npm install firebase-admin@">=9.8.0"
    
  2. Agregue un cheque para context.app a su función. Su función debería fallar si context.app no ​​está definido.

    exports.yourCallableFunction = functions.https.onCall((data, context) => {
      // context.app will be undefined if the request doesn't include an
      // App Check token. (If the request includes an invalid App Check
      // token, the request will be rejected with HTTP error 401.)
      if (context.app == undefined) {
        throw new functions.https.HttpsError(
            'failed-precondition',
            'The function must be called from an App Check verified app.')
      }
    
      // Your function logic follows.
    });
    
  3. (Opcional) Si desea manejar tokens de verificación de aplicaciones no válidos con su propia lógica (por ejemplo, si desea registrar temporalmente, en lugar de rechazar, solicitudes no válidas antes de habilitar la aplicación total), establezca allowInvalidAppCheckToken en true :

    exports.yourCallableFunction = functions.
      .runWith({
        allowInvalidAppCheckToken: true  // Opt-out: Requests with invalid App
                                         // Check tokens continue to your code.
      })
      .https.onCall((data, context) => {
        // Now, requests with an invalid App Check token are not rejected.
        //
        // context.app will be undefined if the request:
        //   1) Does not include an App Check token
        //   2) Includes an invalid App Check token
        if (context.app == undefined) {
          // You can inspect the raw request header to check whether an App
          // Check token was provided in the request. If you're not ready to
          // fully enable App Check yet, you could log these conditions instead
          // of throwing errors.
          const rawToken = context.rawRequest.header['X-Firebase-AppCheck'];
          if (rawToken == undefined) {
            throw new functions.https.HttpsError(
                'failed-precondition',
                'The function must be called from an App Check verified app.'
            );
          } else {
            throw new functions.https.HttpsError(
                'unauthenticated',
                'Provided App Check token failed to validate.'
            );
          }
        }
    
        // Your function logic follows.
      });
    

    Para habilitar la protección completa de App Check, establezca allowInvalidAppCheckToken en false .

  4. Redistribuya sus funciones:

    firebase deploy --only functions
    

Una vez que se implementen estos cambios, sus Cloud Functions a las que se puede llamar requerirán tokens de verificación de aplicaciones válidos. Los SDK de cliente de Cloud Functions adjuntan automáticamente un token de App Check cuando invocas una función invocable.