(* 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