![Maven Central Adds Sigstore Signature Validation](https://cdn.sanity.io/images/cgdhsj6q/production/7da3bc8a946cfb5df15d7fcf49767faedc72b483-1024x1024.webp?w=400&fit=max&auto=format)
Security News
Maven Central Adds Sigstore Signature Validation
Maven Central now validates Sigstore signatures, making it easier for developers to verify the provenance of Java packages.
djorm-cloud-jobs
Advanced tools
Tiny library that helps you run huge workloads as small distributed jobs in cloud environment
djorm-cloud-jobs
Tiny library that helps you run huge workloads as small distributed jobs in cloud environment.
For the moment, only Google Cloud Platform is supported.
npm install djorm-cloud-jobs
Add djorm-cloud-jobs/config
to apps
djorm config.
const { configure } = require('djorm/config')
configure({
apps: [
'djorm-cloud-jobs/config'
],
jobs: {
model: 'djorm-cloud-jobs.Job',
local: process.env.NODE_ENV === 'local'
}
})
jobs.model
(string, default 'gcpi-models-jobs.Job'
) name of the model used to store jobs. You can either use the Job
model or extend the abstract JobBase
model.
jobs.local
(boolean, default false
) run the jobs locally (don't use that in production)
The jobs are expected to be run in Cloud Function environment. So first, you need to create an entrypoint.
const { createSubscription } = require('djorm-cloud-jobs')
module.exports = createSubscription({
filename: __filename,
topic: 'job-topic',
tasks: job => {
// process job.props
}
})
The processing stores updates job status based on the outcome of the processing function.
You can specify that the entrypoint will process multiple different types of Jobs. Good examples are scrapers, so let's scrape some pets API.
const { createSubscription } = require('djorm-cloud-jobs')
const ScrapeTriggers = {
ownerList: 'load:owner:all',
ownerDetail: 'load:owner:detail',
ownerPetList: 'load:owner:pet:all'
}
module.exports = createSubscription({
filename: __filename,
topic: 'job-topic',
tasks: {
[ScrapeTriggers.ownerList]: job => {
// Fetch owner list and trigger details fetch for each owner
await Promise.all(ownerList.map(owner =>
job.spawnChild({
props: {
owner
}
})
)
},
[ScrapeTriggers.ownerDetail]: job => {
const { owner } = job.props
// Fetch owner details for a specific owner
// Store owner details
// Trigger pets details fetch for each pet
await Promise.all(owner.pets.map(pet =>
job.spawnChild({
props: {
owner,
pet
}
})
)
},
[ScrapeTriggers.ownerPetList]: job => {
const { owner, pet } = job.props
// Now fetch and store the owner's pet's details
}
}
})
To make the jobs interact with each other, you can define hooks. Let's consider ScrapeTriggers
from previous example. We want to trigger another job when the ScrapeTriggers.ownerList
job ends successfully. Please note that it is considered successful only if all the descendants finish with success status.
const { createSubscription } = require('djorm-cloud-jobs')
const LocationTriggers = {
petLocationHistory: 'load:pet:location-history'
}
module.exports = createSubscription({
filename: __filename,
topic: 'job-topic',
tasks: {
[ScrapeTriggers.ownerList]: {
onRequest: job => {
// Same as above
},
onSuccess: job => {
job.constructor.debounce({
type: LocationTriggers.fetchPetLocationHistory,
})
}
}
}
})
runJob
FAQs
Tiny library that helps you run huge workloads as small distributed jobs in cloud environment
We found that djorm-cloud-jobs demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Maven Central now validates Sigstore signatures, making it easier for developers to verify the provenance of Java packages.
Security News
CISOs are racing to adopt AI for cybersecurity, but hurdles in budgets and governance may leave some falling behind in the fight against cyber threats.
Research
Security News
Socket researchers uncovered a backdoored typosquat of BoltDB in the Go ecosystem, exploiting Go Module Proxy caching to persist undetected for years.