Blame lenses/automaster.aug

Packit Service a2ae7a
(*
Packit Service a2ae7a
Module: Automaster
Packit Service a2ae7a
  Parses autofs' auto.master files
Packit Service a2ae7a
Packit Service a2ae7a
Author: Dominic Cleal <dcleal@redhat.com>
Packit Service a2ae7a
Packit Service a2ae7a
About: Reference
Packit Service a2ae7a
  See auto.master(5)
Packit Service a2ae7a
Packit Service a2ae7a
About: License
Packit Service a2ae7a
   This file is licenced under the LGPL v2+, like the rest of Augeas.
Packit Service a2ae7a
Packit Service a2ae7a
About: Lens Usage
Packit Service a2ae7a
   To be documented
Packit Service a2ae7a
Packit Service a2ae7a
About: Configuration files
Packit Service a2ae7a
   This lens applies to /etc/auto.master, auto_master and /etc/auto.master.d/*
Packit Service a2ae7a
   files.
Packit Service a2ae7a
Packit Service a2ae7a
About: Examples
Packit Service a2ae7a
   The <Test_Automaster> file contains various examples and tests.
Packit Service a2ae7a
*)
Packit Service a2ae7a
Packit Service a2ae7a
module Automaster =
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
(* View: eol *)
Packit Service a2ae7a
let eol = Util.eol
Packit Service a2ae7a
Packit Service a2ae7a
(* View: empty *)
Packit Service a2ae7a
let empty   = Util.empty
Packit Service a2ae7a
Packit Service a2ae7a
(* View: comment *)
Packit Service a2ae7a
let comment = Util.comment
Packit Service a2ae7a
Packit Service a2ae7a
(* View mount *)
Packit Service a2ae7a
let mount = /[^+ \t\n#]+/
Packit Service a2ae7a
Packit Service a2ae7a
(* View: type
Packit Service a2ae7a
   yp, file, dir etc but not ldap *)
Packit Service a2ae7a
let type = Rx.word - /ldap/
Packit Service a2ae7a
Packit Service a2ae7a
(* View: format
Packit Service a2ae7a
   sun, hesoid *)
Packit Service a2ae7a
let format = Rx.word
Packit Service a2ae7a
Packit Service a2ae7a
(* View: name *)
Packit Service a2ae7a
let name = /[^: \t\n]+/
Packit Service a2ae7a
Packit Service a2ae7a
(* View: host *)
Packit Service a2ae7a
let host = /[^:# \n\t]+/
Packit Service a2ae7a
Packit Service a2ae7a
(* View: dn *)
Packit Service a2ae7a
let dn = /[^:# \n\t]+/
Packit Service a2ae7a
Packit Service a2ae7a
(* An option label can't contain comma, comment, equals, or space *)
Packit Service a2ae7a
let optlabel = /[^,#= \n\t]+/
Packit Service a2ae7a
let spec    = /[^,# \n\t][^ \n\t]*/
Packit Service a2ae7a
Packit Service a2ae7a
(* View: optsep *)
Packit Service a2ae7a
let optsep = del /[ \t,]+/ ","
Packit Service a2ae7a
Packit Service a2ae7a
(************************************************************************
Packit Service a2ae7a
 * Group:                 ENTRIES
Packit Service a2ae7a
 *************************************************************************)
Packit Service a2ae7a
Packit Service a2ae7a
(* View: map_format *)
Packit Service a2ae7a
let map_format = [ label "format" . store format ]
Packit Service a2ae7a
Packit Service a2ae7a
(* View: map_type *)
Packit Service a2ae7a
let map_type = [ label "type" . store type ]
Packit Service a2ae7a
Packit Service a2ae7a
(* View: map_name *)
Packit Service a2ae7a
let map_name = [ label "map" . store name ]
Packit Service a2ae7a
Packit Service a2ae7a
(* View: map_generic
Packit Service a2ae7a
   Used for all except LDAP maps which are parsed further *)
Packit Service a2ae7a
let map_generic = ( map_type . ( Sep.comma . map_format )?  . Sep.colon )?
Packit Service a2ae7a
                    . map_name
Packit Service a2ae7a
Packit Service a2ae7a
(* View: map_ldap_name
Packit Service a2ae7a
   Split up host:dc=foo into host/map nodes *)
Packit Service a2ae7a
let map_ldap_name = ( [ label "host" . store host ] . Sep.colon )?
Packit Service a2ae7a
                      . [ label "map" . store dn ]
Packit Service a2ae7a
Packit Service a2ae7a
(* View: map_ldap *)
Packit Service a2ae7a
let map_ldap      = [ label "type" . store "ldap" ]
Packit Service a2ae7a
                      . ( Sep.comma . map_format )? . Sep.colon
Packit Service a2ae7a
                      . map_ldap_name
Packit Service a2ae7a
Packit Service a2ae7a
(* View: comma_spc_sep_list
Packit Service a2ae7a
   Parses options either for filesystems or autofs *)
Packit Service a2ae7a
let comma_spc_sep_list (l:string) =
Packit Service a2ae7a
  let value = [ label "value" . Util.del_str "=" . store Rx.neg1 ] in
Packit Service a2ae7a
    let lns = [ label l . store optlabel . value? ] in
Packit Service a2ae7a
       Build.opt_list lns optsep
Packit Service a2ae7a
Packit Service a2ae7a
(* View: map_mount 
Packit Service a2ae7a
   Mountpoint and whitespace, followed by the map info *)
Packit Service a2ae7a
let map_mount  = [ seq "map" . store mount . Util.del_ws_tab
Packit Service a2ae7a
                   . ( map_generic | map_ldap )
Packit Service a2ae7a
                   . ( Util.del_ws_spc . comma_spc_sep_list "opt" )?
Packit Service a2ae7a
                   . Util.eol ]
Packit Service a2ae7a
Packit Service a2ae7a
(* map_master
Packit Service a2ae7a
   "+" to include more master entries and optional whitespace *)
Packit Service a2ae7a
let map_master = [ seq "map" . store "+" . Util.del_opt_ws ""
Packit Service a2ae7a
                   . ( map_generic | map_ldap )
Packit Service a2ae7a
                   . ( Util.del_ws_spc . comma_spc_sep_list "opt" )?
Packit Service a2ae7a
                   . Util.eol ]
Packit Service a2ae7a
Packit Service a2ae7a
(* View: lns *)
Packit Service a2ae7a
let lns = ( empty | comment | map_mount | map_master ) *
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: filter *)
Packit Service a2ae7a
let filter = incl "/etc/auto.master"
Packit Service a2ae7a
           . incl "/etc/auto_master"
Packit Service a2ae7a
           . incl "/etc/auto.master.d/*"
Packit Service a2ae7a
           . Util.stdexcl
Packit Service a2ae7a
Packit Service a2ae7a
let xfm = transform lns filter