payload
Version:
Node, React, Headless CMS and Application Framework built on Next.js
44 lines (43 loc) • 1.83 kB
JavaScript
import { JobCancelledError } from '../../../errors/index.js';
import { updateJob } from '../../../utilities/updateJob.js';
/**
* Helper for updating a job that does the following, additionally to updating the job:
* - Merges incoming data from the updated job into the original job object
* - Handles job cancellation by throwing a `JobCancelledError` if the job was cancelled.
*/ export function getUpdateJobFunction(job, req) {
return async (jobData)=>{
const updatedJob = await updateJob({
id: job.id,
data: jobData,
depth: req.payload.config.jobs.depth,
disableTransaction: true,
req
});
if (!updatedJob) {
return job;
}
// Update job object like this to modify the original object - that way, incoming changes (e.g. taskStatus field that will be re-generated through the hook) will be reflected in the calling function
for(const key in updatedJob){
if (key === 'log') {
// Add all new log entries to the original job.log object. Do not delete any existing log entries.
// Do not update existing log entries, as existing log entries should be immutable.
for (const logEntry of updatedJob?.log ?? []){
if (!job.log || !job.log.some((entry)=>entry.id === logEntry.id)) {
;
(job.log ??= []).push(logEntry);
}
}
} else {
;
job[key] = updatedJob[key];
}
}
if (updatedJob?.error?.cancelled) {
throw new JobCancelledError({
job
});
}
return updatedJob;
};
}
//# sourceMappingURL=getUpdateJobFunction.js.map