functions-samples icon indicating copy to clipboard operation
functions-samples copied to clipboard

[BUG] in sample: taskqueues-backup-images

Open CoocooFroggy opened this issue 1 year ago • 1 comments

Which sample has a bug?

https://github.com/firebase/functions-samples/blob/703c0359eacf07a551751d1319d34f912a2cd828/Node/taskqueues-backup-images/functions/index.js#L115-L132

How to reproduce the issue

Used getFunctionUrl exactly as shown.

Steps to set up and reproduce

Attempt to queue a function using the code shown. EG:

const queue = getFunctions().taskQueue("reminderEmail");
const targetUrl = await getFunctionUrl("reminderEmail");

queue.enqueue({bookingRequestId: event.params.docId}, {
  scheduleTime: new Date(),
  uri: targetUrl,
}).then(() => {
  console.log(`Queued reminder email for ${date}.`);
});

Debug output

Status code 7 (PERMISSION_DENIED)
Reason to retry PERMISSION_DENIED(7): HTTP status code 403
SCR-20240621-nrfl

Expected behavior

The function runs successfully. The documentation states,

Due to the way Cloud Tasks creates authentication tokens to authenticate requests to the underlying task queue functions, you must specify the Cloud Run URL of the function when enqueuing tasks. We recommend that you programmatically retrieve the URL for your function as demonstrated below...

However, the uri itself does not seem sufficient to authenticate the cloud function.

Actual behavior

The function is missing the necessary authentication.

CoocooFroggy avatar Jun 21 '24 20:06 CoocooFroggy

Seems related to #1105

CoocooFroggy avatar Jun 21 '24 20:06 CoocooFroggy