Blob Blame History Raw
(* Monit module for Augeas
 Author: Free Ekanayaka <free@64studio.com>

 Reference: man monit (1), section "HOW TO MONITOR"

 "A monit control file consists of a series of service entries and
  global option statements in a free-format, token-oriented syntax.

  Comments begin with a # and extend through the end of the line. There
  are three kinds of tokens in the control file: grammar keywords, numbers
  and strings. On a semantic level, the control file consists of three
  types of statements:

  1. Global set-statements
      A global set-statement starts with the keyword set and the item to
      configure.

  2. Global include-statement
      The include statement consists of the keyword include and a glob
      string.

  3. One or more service entry statements.
       A service entry starts with the keyword check followed by the
       service type"

*)

module Monit =

   autoload xfm

(************************************************************************
 *                           USEFUL PRIMITIVES
 *************************************************************************)

let spc        = Sep.space
let comment    = Util.comment
let empty      = Util.empty

let sto_to_spc = store Rx.space_in
let sto_no_spc = store Rx.no_spaces

let word       = Rx.word
let value      = Build.key_value_line word spc sto_to_spc

(************************************************************************
 *                               ENTRIES
 *************************************************************************)

(* set statement *)
let set        = Build.key_value "set" spc value

(* include statement *)
let include    = Build.key_value_line "include" spc sto_to_spc

(* service statement *)
let service    = Build.key_value "check" spc (Build.list value spc)

let entry      = (set|include|service)

(************************************************************************
 *                                LENS
 *************************************************************************)

let lns        = (comment|empty|entry) *

let filter     = incl "/etc/monit/monitrc"
               . incl "/etc/monitrc"

let xfm        = transform lns filter