Blame lenses/cron.aug

Packit Service a2ae7a
(*
Packit Service a2ae7a
Module: Cron
Packit Service a2ae7a
 Parses /etc/cron.d/*, /etc/crontab
Packit Service a2ae7a
Packit Service a2ae7a
Author: Raphael Pinson <raphink@gmail.com>
Packit Service a2ae7a
Packit Service a2ae7a
About: Reference
Packit Service a2ae7a
 This lens tries to keep as close as possible to `man 5 crontab` where
Packit Service a2ae7a
 possible.
Packit Service a2ae7a
Packit Service a2ae7a
About: License
Packit Service a2ae7a
  This file is licensed under the LGPL v2+, like the rest of Augeas.
Packit Service a2ae7a
Packit Service a2ae7a
About: Lens Usage
Packit Service a2ae7a
  Sample usage of this lens in augtool
Packit Service a2ae7a
Packit Service a2ae7a
    * Get the entry that launches '/usr/bin/ls'
Packit Service a2ae7a
      >  match '/files/etc/crontab/entry[. = "/usr/bin/ls"]'
Packit Service a2ae7a
Packit Service a2ae7a
About: Configuration files
Packit Service a2ae7a
  This lens applies to /etc/cron.d/* and /etc/crontab. See <filter>.
Packit Service a2ae7a
*)
Packit Service a2ae7a
Packit Service a2ae7a
module Cron =
Packit Service a2ae7a
  autoload xfm
Packit Service a2ae7a
Packit Service a2ae7a
(************************************************************************
Packit Service a2ae7a
 * Group:                 USEFUL PRIMITIVES
Packit Service a2ae7a
 *************************************************************************)
Packit Service a2ae7a
Packit Service a2ae7a
(* Group: Generic primitives *)
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: eol *)
Packit Service a2ae7a
let eol     = Util.eol
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: indent *)
Packit Service a2ae7a
let indent  = Util.indent
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: comment *)
Packit Service a2ae7a
let comment = Util.comment
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: empty *)
Packit Service a2ae7a
let empty   = Util.empty
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: num *)
Packit Service a2ae7a
let num        = /[0-9*][0-9\/,*-]*/
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: alpha *)
Packit Service a2ae7a
let alpha      = /[A-Za-z]{3}/
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: alphanum *)
Packit Service a2ae7a
let alphanum   = (num|alpha) . ("-" . (num|alpha))?
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: entry_prefix *)
Packit Service a2ae7a
let entry_prefix = /-/
Packit Service a2ae7a
Packit Service a2ae7a
(* Group: Separators *)
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: sep_spc *)
Packit Service a2ae7a
let sep_spc = Util.del_ws_spc
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: sep_eq *)
Packit Service a2ae7a
let sep_eq  = Util.del_str "="
Packit Service a2ae7a
Packit Service a2ae7a
Packit Service a2ae7a
Packit Service a2ae7a
(************************************************************************
Packit Service a2ae7a
 * Group:                       ENTRIES
Packit Service a2ae7a
 *************************************************************************)
Packit Service a2ae7a
Packit Service a2ae7a
Packit Service a2ae7a
(************************************************************************
Packit Service a2ae7a
 * View: shellvar
Packit Service a2ae7a
 *   A shell variable in crontab
Packit Service a2ae7a
 *************************************************************************)
Packit Service a2ae7a
Packit Service a2ae7a
let shellvar =
Packit Service a2ae7a
  let key_re = /[A-Za-z1-9_-]+(\[[0-9]+\])?/ - "entry" in
Packit Service a2ae7a
  let sto_to_eol = store /[^\n]*[^ \t\n]/ in
Packit Service a2ae7a
  [ key key_re . sep_eq . sto_to_eol . eol ]
Packit Service a2ae7a
Packit Service a2ae7a
(* View: - prefix of an entry *)
Packit Service a2ae7a
let prefix     = [ label "prefix"       . store entry_prefix ]
Packit Service a2ae7a
Packit Service a2ae7a
(* View: minute *)
Packit Service a2ae7a
let minute     = [ label "minute"       . store num ]
Packit Service a2ae7a
Packit Service a2ae7a
(* View: hour *)
Packit Service a2ae7a
let hour       = [ label "hour"         . store num ]
Packit Service a2ae7a
Packit Service a2ae7a
(* View: dayofmonth *)
Packit Service a2ae7a
let dayofmonth = [ label "dayofmonth" . store num ]
Packit Service a2ae7a
Packit Service a2ae7a
(* View: month *)
Packit Service a2ae7a
let month      = [ label "month"        . store alphanum ]
Packit Service a2ae7a
Packit Service a2ae7a
(* View: dayofweek *)
Packit Service a2ae7a
let dayofweek  = [ label "dayofweek"  . store alphanum ]
Packit Service a2ae7a
Packit Service a2ae7a
Packit Service a2ae7a
(* View: user *)
Packit Service a2ae7a
let user       = [ label "user"         . store Rx.word ]
Packit Service a2ae7a
Packit Service a2ae7a
Packit Service a2ae7a
(************************************************************************
Packit Service a2ae7a
 * View: time
Packit Service a2ae7a
 *   Time in the format "minute hour dayofmonth month dayofweek"
Packit Service a2ae7a
 *************************************************************************)
Packit Service a2ae7a
let time        = [ label "time" .
Packit Service a2ae7a
                  minute . sep_spc . hour  . sep_spc . dayofmonth
Packit Service a2ae7a
                         . sep_spc . month . sep_spc . dayofweek ]
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: the valid values for schedules *)
Packit Service a2ae7a
let schedule_re = "reboot" | "yearly" | "annually" | "monthly"
Packit Service a2ae7a
                | "weekly" | "daily"  | "midnight" | "hourly"
Packit Service a2ae7a
Packit Service a2ae7a
(************************************************************************
Packit Service a2ae7a
 * View: schedule
Packit Service a2ae7a
 *   Time in the format "@keyword"
Packit Service a2ae7a
 *************************************************************************)
Packit Service a2ae7a
let schedule    = [ label "schedule" . Util.del_str "@"
Packit Service a2ae7a
                   . store schedule_re ]
Packit Service a2ae7a
Packit Service a2ae7a
Packit Service a2ae7a
(************************************************************************
Packit Service a2ae7a
 * View: entry
Packit Service a2ae7a
 *   A crontab entry
Packit Service a2ae7a
 *************************************************************************)
Packit Service a2ae7a
Packit Service a2ae7a
let entry       = [ label "entry" . indent
Packit Service a2ae7a
                   . prefix?
Packit Service a2ae7a
                   . ( time | schedule )
Packit Service a2ae7a
                   . sep_spc . user
Packit Service a2ae7a
                   . sep_spc . store Rx.space_in . eol ]
Packit Service a2ae7a
Packit Service a2ae7a
Packit Service a2ae7a
(*
Packit Service a2ae7a
 * View: lns
Packit Service a2ae7a
 *   The cron lens
Packit Service a2ae7a
 *)
Packit Service a2ae7a
let lns = ( empty | comment | shellvar | entry )*
Packit Service a2ae7a
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: filter *)
Packit Service a2ae7a
let filter =
Packit Service a2ae7a
  incl "/etc/cron.d/*" .
Packit Service a2ae7a
  incl "/etc/crontab" .
Packit Service a2ae7a
  incl "/etc/crontabs/*" .
Packit Service a2ae7a
  excl "/etc/cron.d/at.allow" .
Packit Service a2ae7a
  excl "/etc/cron.d/at.deny" .
Packit Service a2ae7a
  excl "/etc/cron.d/cron.allow" .
Packit Service a2ae7a
  excl "/etc/cron.d/cron.deny" .
Packit Service a2ae7a
  Util.stdexcl
Packit Service a2ae7a
Packit Service a2ae7a
let xfm = transform lns filter