71 lines
2.1 KiB
Plaintext
71 lines
2.1 KiB
Plaintext
|
(* 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
|