Skip to content

Windows - FirebaseAppCheckError: App attestation failed. #2308

@daviddomkar

Description

@daviddomkar

Environment

  • Operating System version: Windows 11
  • Firebase SDK version: "firebase-admin": "^11.10.1"
  • Firebase Product: appcheck
  • Node.js version: 18.17.0
  • NPM version: 9.6.7

Problem description

When trying to use firebase admin SDK to generate custom appcheck token, the code throws the following exception:

FirebaseAppCheckError: App attestation failed.
    at AppCheckApiClient.toFirebaseError (C:\Users\David\Projects\temp\node_modules\firebase-admin\lib\app-check\app-check-api-client-internal.js:150:16)
    at C:\Users\David\Projects\temp\node_modules\firebase-admin\lib\app-check\app-check-api-client-internal.js:72:24
    at process.processTicksAndRejections (node:internal/process/task_queues:95:5) {
  errorInfo: {
    code: 'app-check/permission-denied',
    message: 'App attestation failed.'
  },
  codePrefix: 'app-check'
}

This happens on my PC (Windows 11) and my laptop (Windows 11). However, it does not happen on my colleague's MacOS machine. The Firebase configuration was exactly the same on all these machines. I tried everything from switching node and dependency versions to tracing token requests with Wireshark to see the issue, but I just lost 3 whole days trying to fix this with no positive outcome. I seek any help I can.

Steps to reproduce:

I made a simple reproduction repo where the problem occurs: https://github.com/DavidDomkar/firebase-admin-app-check-create-token-bug

  • You will need to create .env file based on .env.example and fill in the FIREBASE_APP_ID based on your project. Also, service-account.json file must be copied over to the repository root.
  • Then run yarn install && yarn tsc && node lib/index.js to run the example and see the error.

Relevant Code:

import { initializeApp } from "firebase-admin/app";
import { getAppCheck } from "firebase-admin/app-check";

async function main() {
  const app = initializeApp();
  const appCheck = getAppCheck(app);
  const token = await appCheck.createToken(process.env.FIREBASE_APP_ID);
  console.log(token);
}

main();

Metadata

Metadata

Assignees

Type

No type

Projects

No projects

Milestone

No milestone

Relationships

None yet

Development

No branches or pull requests

Issue actions