
Research
/Security News
Critical Vulnerability in NestJS Devtools: Localhost RCE via Sandbox Escape
A flawed sandbox in @nestjs/devtools-integration lets attackers run code on your machine via CSRF, leading to full Remote Code Execution (RCE).
adonisjs-scheduler
Advanced tools
Install the package from npm using the following command:
node ace add adonisjs-scheduler
node ace scheduler:run
# or
node ace scheduler:work
# automatically restart the scheduler when files are modified during development mode
node ace scheduler:run --watch
// start/scheduler.ts
import scheduler from 'adonisjs-scheduler/services/main'
import PurgeUsers from '../commands/purge_users'
scheduler.command('inspire').everyFiveSeconds()
scheduler.command(PurgeUsers, ['30 days']).everyFiveSeconds().withoutOverlapping()
scheduler.withoutOverlapping(
() => {
scheduler.command('inspire').everySecond()
scheduler.command(PurgeUsers, ['30 days']).everyFiveSeconds()
},
{ expiresAt: 30_000 }
)
scheduler
.call(() => {
console.log('Pruge DB!')
})
.weekly()
or define schedule directly on command
import { BaseCommand, args } from '@adonisjs/core/ace'
import { schedule } from 'adonisjs-scheduler'
@schedule("* * * * *", ["30 days"])
@schedule((s) => s.everyFiveSeconds().immediate(), ["7 days"])
@schedule((s) => s.everyMinute(), ["42 days"])
export default class PurgeUsers extends BaseCommand {
static commandName = 'purge:users'
static description = ''
static options: CommandOptions = {}
@args.string()
declare olderThan: string
async run() {
//
}
}
Method | Description |
---|---|
.cron('* * * * *'); | Run the task on a custom cron schedule |
.everyMinute(); | Run the task every minute |
.everyTwoMinutes(); | Run the task every two minutes |
.everyThreeMinutes(); | Run the task every three minutes |
.everyFourMinutes(); | Run the task every four minutes |
.everyFiveMinutes(); | Run the task every five minutes |
.everyTenMinutes(); | Run the task every ten minutes |
.everyFifteenMinutes(); | Run the task every fifteen minutes |
.everyThirtyMinutes(); | Run the task every thirty minutes |
.hourly(); | Run the task every hour |
.hourlyAt(17); | Run the task every hour at 17 minutes past the hour. |
.everyTwoHours(); | Run the task every two hours |
.everyThreeHours(); | Run the task every three hours |
.everyFourHours(); | Run the task every four hours |
.everyFiveHours(); | Run the task every five hours |
.everySixHours(); | Run the task every six hours |
.daily(); | Run the task every day at midnight |
.dailyAt('13:00'); | Run the task every day at 13:00. |
.twiceDaily(1, 13); | Run the task daily at 1:00 & 13:00. |
.twiceDailyAt(1, 13, 15); | Run the task daily at 1:15 & 13:15. |
.weekly(); | Run the task every Sunday at 00:00 |
.weeklyOn(1, '8:00'); | Run the task every week on Monday at 8:00. |
.monthly(); | Run the task on the first day of every month at 00:00 |
.monthlyOn(4, '15:00'); | Run the task every month on the 4th at 15:00. |
.twiceMonthly(1, 16, '13:00'); | Run the task monthly on the 1st and 16th at 13:00. |
.lastDayOfMonth('15:00'); | Run the task on the last day of the month at 15:00. |
.quarterly(); | Run the task on the first day of every quarter at 00:00. |
.quarterlyOn(4, '14:00'); | Run the task every quarter on the 4th at 14:00. |
.yearly(); | Run the task on the first day of every year at 00:00. |
.yearlyOn(6, 1, '17:00'); | Run the task every year on June 1st at 17:00. |
.timezone('America/New_York'); | Set the timezone for the task. |
.immediate(); | Run the task on startup |
.withoutOverlapping(); | Run the task without overlapping |
Besides using node ace scheduler:run
, you can also manually initialize and control the scheduler worker in your code:
import { Worker } from '@adonisjs/scheduler'
import app from '@adonisjs/core/services/app'
const worker = new Worker(app)
app.terminating(async () => {
await worker.stop()
})
await worker.start()
FAQs
Task scheduler for AdonisJS
The npm package adonisjs-scheduler receives a total of 1,431 weekly downloads. As such, adonisjs-scheduler popularity was classified as popular.
We found that adonisjs-scheduler 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.
Research
/Security News
A flawed sandbox in @nestjs/devtools-integration lets attackers run code on your machine via CSRF, leading to full Remote Code Execution (RCE).
Product
Customize license detection with Socket’s new license overlays: gain control, reduce noise, and handle edge cases with precision.
Product
Socket now supports Rust and Cargo, offering package search for all users and experimental SBOM generation for enterprise projects.