-
Notifications
You must be signed in to change notification settings - Fork 402
Open
Labels
Description
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 theFIREBASE_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();
KarolinaChladikova, daviddomkar, Harm-Nullix and BenJackGill