13 releases

0.2.7 Nov 29, 2024
0.2.6 Nov 29, 2024
0.2.3 Sep 13, 2024
0.2.2 Aug 29, 2024
0.1.1 Jul 21, 2020

#447 in Concurrency

Download history 6/week @ 2024-08-16 130/week @ 2024-08-23 110/week @ 2024-08-30 54/week @ 2024-09-06 282/week @ 2024-09-13 158/week @ 2024-09-20 161/week @ 2024-09-27 166/week @ 2024-10-04 128/week @ 2024-10-11 89/week @ 2024-10-18 99/week @ 2024-10-25 129/week @ 2024-11-01 258/week @ 2024-11-08 39/week @ 2024-11-15 9/week @ 2024-11-22 254/week @ 2024-11-29

578 downloads per month

MIT license

26KB
414 lines

CronTab

Build codecov

A cron job library for Rust.

Features

  • Sync and Async Support: Manage cron jobs in both synchronous and asynchronous contexts.
  • Flexible Cron Expressions: Use standard cron expressions for job scheduling.

Usage

Please see the Documentation for more details.

Add to your Cargo.toml:

[dependencies]
cron_tab = {version = "0.2", features = ["sync", "async"]}

The cron expression format:

sec   min   hour   day of month   month   day of week   year
*     *     *      *              *       *             *

Example:

extern crate cron_tab;  
  
use chrono::{FixedOffset, Local, TimeZone, Utc};  
  
fn main() {  
 let local_tz = Local::from_offset(&FixedOffset::east(7));  
 let utc_tz = Utc;  
 
 // create new cron with timezone
 let mut cron = cron_tab::Cron::new(utc_tz);  
  
 // add test fn to cron
 let job_test_id = cron.add_fn("* * * * * * *", test).unwrap();  
  
 // start cron
 cron.start();  

 // sleep 2 second
 std::thread::sleep(std::time::Duration::from_secs(2));
 
 // add one more function
 let anonymous_job_id = cron.add_fn("* * * * * *", || {  
            println!("anonymous fn");  
 }).unwrap();  
  
 // remove job_test  
 cron.remove(job_test_id);  
  
 // sleep 2 second
 std::thread::sleep(std::time::Duration::from_secs(2));
  
 // stop cron  
 cron.stop();  
}  
  
fn test() {  
    println!("now: {}", Local::now().to_string());  
}

Async Example:

use std::sync::Arc;

use chrono::{FixedOffset, Local, TimeZone};
use cron_tab::AsyncCron;
use tokio::sync::Mutex;

#[tokio::main]
async fn main() {
    let local_tz = Local::from_offset(&FixedOffset::east(7));
    let mut cron = AsyncCron::new(local_tz);

    let first_job_id = cron.add_fn("* * * * * *", print_now).await;

    cron.start().await;

    let counter = Arc::new(Mutex::new(1));
    cron.add_fn("* * * * * *", move || {
        let counter = counter.clone();
        async move {
            let mut counter = counter.lock().await;
            *counter += 1;
            let now = Local::now().to_string();
            println!("{} counter value: {}", now, counter);
        }
    })
    .await;

    std::thread::sleep(std::time::Duration::from_secs(10));

    // stop cron
    cron.stop();
}

async fn print_now() {
    println!("now: {}", Local::now().to_string());
}

License

Dependencies

~2.6–9MB
~89K SLoC