Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/johnkimdev/sails-hook-node-cron
Sails hook for Cron - Schedule Tasks using node-cron
https://github.com/johnkimdev/sails-hook-node-cron
Last synced: about 1 month ago
JSON representation
Sails hook for Cron - Schedule Tasks using node-cron
- Host: GitHub
- URL: https://github.com/johnkimdev/sails-hook-node-cron
- Owner: JohnKimDev
- License: mit
- Created: 2019-01-10T15:25:17.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2019-01-15T02:25:19.000Z (almost 6 years ago)
- Last Synced: 2024-09-19T01:38:43.026Z (4 months ago)
- Language: JavaScript
- Size: 10.7 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# sails-hook-node-cron
Sails hook for running cron tasks using [node-cron](https://www.npmjs.com/package/node-cron).
## Getting Started
This is a SailsJS's hook for cron jobs using [node-cron](https://www.npmjs.com/package/node-cron). The difference between this package and another popular SailsJS's cron hook, `sails-hook-cron` is that `sails-hook-cron` uses the [cron](https://www.npmjs.com/package/cron) package whereas this **`sails-hook-node-cron`** uses the [node-cron](https://www.npmjs.com/package/node-cron) as a main package to run cron jobs.
---
I prefer **node-cron** package as a cron jobs runner, because **node-cron** uses a pure javascript code (setTimeout) to run a scheduled task whereas *cron* package uses **child_process** for **spwan** command. Using **child_process** *may* open injection vulnerabilities. I prefer not to use a command injection if possible, especially by 3rd party packages. Also if you are running multiple cron jobs, using spawned child_process may use more memory for the server. So for the efficiency and security reasons, I have created this new cron hook package for SailsJS.
Happy Coding!---
If you are switching from sails-hook-cron package, you will see that the parameter fields are similar with sails-hook-cron. You should be able to simply change the package without rewriting the cron configuration.
### Installation
```shell
npm install sails-hook-node-cron --save
```Configure `config/cron.js` in your project:
```javascript
module.exports.cron = {
myFirstJob: {
schedule: '* * * * * *', // [REQUIRED]
onTick: () => { // [REQUIRED]
console.log('You will see this every second');
},
timezone: 'America/New_York', // [OPTIONAL] set timezone
runOnInit: true, // [OPTIONAL] fire onTick function as soon as the cron is initialized
start: true // [OPTIONAL] manually start the cron task (DEFAULT = true) See below for the example
}
};
```## Cron Syntax
This is a quick reference to cron syntax and also shows the options supported by node-cron.
https://crontab.guru/ or https://cronjob.xyz/ might be useful to validate the cron schedule.
Please note that these sites may not accept the SECOND field so you can you them as reference but you should check your run result after.### Allowed fields
```
# ┌────────────── second (optional)
# │ ┌──────────── minute
# │ │ ┌────────── hour
# │ │ │ ┌──────── day of month
# │ │ │ │ ┌────── month
# │ │ │ │ │ ┌──── day of week
# │ │ │ │ │ │
# │ │ │ │ │ │
# * * * * * *
```### Allowed values
| field | value |
|--------------|---------------------|
| second | 0-59 |
| minute | 0-59 |
| hour | 0-23 |
| day of month | 1-31 |
| month | 1-12 (or names) |
| day of week | 0-7 (or names, 0 or 7 are sunday) |## Examples
You can create a cronjob and start\stop them manually:
```javascript
// config/cron.js
module.exports.cron = {
myJob: {
schedule: '* * * * * *',
onTick: () => {
console.log('schedule task');
},
start: false
}
};// api/controllers/SomeController.js
module.exports = {
someAction: function(req, res) {
sails.hooks.cron.jobs.myJob.start();
sails.hooks.cron.jobs.myJob.stop();
sails.hooks.cron.jobs.myJob.destroy();
}
};
```## License
[MIT](./LICENSE)