[BUG] in sample: taskqueues-backup-images
CoocooFroggy opened this issue · 1 comments
Which sample has a bug?
functions-samples/Node/taskqueues-backup-images/functions/index.js
Lines 115 to 132 in 703c035
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 |
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.
Seems related to #1105