Blame lenses/exports.aug

Packit 06dd63
(* Lens for Linux syntax of NFS exports(5) *)
Packit 06dd63
Packit 06dd63
(*
Packit 06dd63
Module: Exports
Packit 06dd63
    Parses /etc/exports
Packit 06dd63
Packit 06dd63
Author: David Lutterkort <lutter@redhat.com>
Packit 06dd63
Packit 06dd63
About: Description
Packit 06dd63
    /etc/exports contains lines associating a directory with one or
Packit 06dd63
    more hosts, and NFS options for each host.
Packit 06dd63
Packit 06dd63
About: Usage Example
Packit 06dd63
Packit 06dd63
(start code)
Packit 06dd63
Packit 06dd63
    $ augtool
Packit 06dd63
    augtool> ls /files/etc/exports/
Packit 06dd63
    comment[1] = /etc/exports: the access control list for filesystems which may be exported
Packit 06dd63
    comment[2] = to NFS clients.  See exports(5).
Packit 06dd63
    comment[3] = sample /etc/exports file
Packit 06dd63
    dir[1]/ = /
Packit 06dd63
    dir[2]/ = /projects
Packit 06dd63
    dir[3]/ = /usr
Packit 06dd63
    dir[4]/ = /home/joe
Packit 06dd63
Packit 06dd63
Packit 06dd63
    augtool> ls /files/etc/exports/dir[1]
Packit 06dd63
    client[1]/ = master
Packit 06dd63
    client[2]/ = trusty
Packit 06dd63
(end code)
Packit 06dd63
Packit 06dd63
The corresponding line in the file is:
Packit 06dd63
Packit 06dd63
(start code)
Packit 06dd63
	/               master(rw) trusty(rw,no_root_squash)
Packit 06dd63
(end code)
Packit 06dd63
Packit 06dd63
    Digging further:
Packit 06dd63
Packit 06dd63
(start code)
Packit 06dd63
    augtool> ls /files/etc/exports/dir[1]/client[1]
Packit 06dd63
    option = rw
Packit 06dd63
Packit 06dd63
    To add a new entry, you'd do something like this:
Packit 06dd63
(end code)
Packit 06dd63
Packit 06dd63
(start code)
Packit 06dd63
    augtool> set /files/etc/exports/dir[10000] /foo
Packit 06dd63
    augtool> set /files/etc/exports/dir[last()]/client[1] weeble
Packit 06dd63
    augtool> set /files/etc/exports/dir[last()]/client[1]/option[1] ro
Packit 06dd63
    augtool> set /files/etc/exports/dir[last()]/client[1]/option[2] all_squash
Packit 06dd63
    augtool> save
Packit 06dd63
    Saved 1 file(s)
Packit 06dd63
(end code)
Packit 06dd63
Packit 06dd63
    Which creates the line:
Packit 06dd63
Packit 06dd63
(start code)
Packit 06dd63
    /foo weeble(ro,all_squash)
Packit 06dd63
(end code)
Packit 06dd63
Packit 06dd63
About: Limitations
Packit 06dd63
    This lens cannot handle options without a host, as with the last
Packit 06dd63
    example line in "man 5 exports":
Packit 06dd63
Packit 06dd63
	/pub            (ro,insecure,all_squash)
Packit 06dd63
Packit 06dd63
    In this case, though, you can just do:
Packit 06dd63
Packit 06dd63
	/pub            *(ro,insecure,all_squash)
Packit 06dd63
Packit 06dd63
    It also can't handle whitespace before the directory name.
Packit 06dd63
*)
Packit 06dd63
Packit 06dd63
module Exports =
Packit 06dd63
  autoload xfm
Packit 06dd63
Packit 06dd63
  let client_re = /[][a-zA-Z0-9.@*?\/:-]+/
Packit 06dd63
Packit 06dd63
  let eol = Util.eol
Packit 06dd63
  let lbracket  = Util.del_str "("
Packit 06dd63
  let rbracket  = Util.del_str ")"
Packit 06dd63
  let sep_com   = Sep.comma
Packit 06dd63
  let sep_spc   = Sep.space
Packit 06dd63
Packit 06dd63
  let option = [ label "option" . store /[^,)]*/ ]
Packit 06dd63
Packit 06dd63
  let client    = [ label "client" . store client_re .
Packit 06dd63
                    ( Build.brackets lbracket rbracket
Packit 06dd63
                         ( Build.opt_list option sep_com ) )? ]
Packit 06dd63
Packit 06dd63
  let entry = [ label "dir" . store /[^ \t\n#]*/
Packit 06dd63
                . sep_spc . Build.opt_list client sep_spc . eol ]
Packit 06dd63
Packit 06dd63
  let lns = (Util.empty | Util.comment | entry)*
Packit 06dd63
Packit 06dd63
  let xfm = transform lns (incl "/etc/exports")