Blame lenses/hosts_access.aug

Packit Service a2ae7a
(*
Packit Service a2ae7a
Module: Hosts_Access
Packit Service a2ae7a
  Parses /etc/hosts.{allow,deny}
Packit Service a2ae7a
Packit Service a2ae7a
Author: Raphael Pinson <raphink@gmail.com>
Packit Service a2ae7a
Packit Service a2ae7a
About: Reference
Packit Service a2ae7a
  This lens tries to keep as close as possible to `man 5 hosts_access` and `man 5 hosts_options` where possible.
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/hosts.{allow,deny}. See <filter>.
Packit Service a2ae7a
*)
Packit Service a2ae7a
Packit Service a2ae7a
module Hosts_Access =
Packit Service a2ae7a
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: colon *)
Packit Service a2ae7a
let colon = del /[ \t]*(\\\\[ \t]*\n[ \t]+)?:[ \t]*(\\\\[ \t]*\n[ \t]+)?/ ": "
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: comma_sep *)
Packit Service a2ae7a
let comma_sep = /([ \t]|(\\\\\n))*,([ \t]|(\\\\\n))*/
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: ws_sep *)
Packit Service a2ae7a
let ws_sep = / +/
Packit Service a2ae7a
Packit Service a2ae7a
(* View: list_sep *)
Packit Service a2ae7a
let list_sep = del ( comma_sep | ws_sep ) ", "
Packit Service a2ae7a
Packit Service a2ae7a
(* View: list_item *)
Packit Service a2ae7a
let list_item = store ( Rx.word - /EXCEPT/i )
Packit Service a2ae7a
Packit Service a2ae7a
(* View: client_host_item
Packit Service a2ae7a
   Allows @ for netgroups, supports [ipv6] syntax *)
Packit Service a2ae7a
let client_host_item =
Packit Service a2ae7a
  let client_hostname_rx = /[A-Za-z0-9_.@?*-][A-Za-z0-9_.?*-]*/ in
Packit Service a2ae7a
  let client_ipv6_rx = "[" . /[A-Za-z0-9:?*%]+/ . "]" in
Packit Service a2ae7a
    let client_host_rx = client_hostname_rx | client_ipv6_rx in
Packit Service a2ae7a
    let netmask = [ Util.del_str "/" . label "netmask" . store Rx.word ] in
Packit Service a2ae7a
      store ( client_host_rx - /EXCEPT/i ) . netmask?
Packit Service a2ae7a
Packit Service a2ae7a
(* View: client_file_item *)
Packit Service a2ae7a
let client_file_item =
Packit Service a2ae7a
  let client_file_rx = /\/[^ \t\n,:]+/ in
Packit Service a2ae7a
    store ( client_file_rx - /EXCEPT/i )
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: option_kw
Packit Service a2ae7a
   Since either an option or a shell command can be given, use an explicit list
Packit Service a2ae7a
   of known options to avoid misinterpreting a command as an option *)
Packit Service a2ae7a
let option_kw = "severity"
Packit Service a2ae7a
              | "spawn"
Packit Service a2ae7a
              | "twist"
Packit Service a2ae7a
              | "keepalive"
Packit Service a2ae7a
              | "linger"
Packit Service a2ae7a
              | "rfc931"
Packit Service a2ae7a
              | "banners"
Packit Service a2ae7a
              | "nice"
Packit Service a2ae7a
              | "setenv"
Packit Service a2ae7a
              | "umask"
Packit Service a2ae7a
              | "user"
Packit Service a2ae7a
              | /allow/i
Packit Service a2ae7a
              | /deny/i
Packit Service a2ae7a
Packit Service a2ae7a
(* Variable: shell_command_rx *)
Packit Service a2ae7a
let shell_command_rx = /[^ \t\n:][^\n]*[^ \t\n]|[^ \t\n:\\\\]/
Packit Service a2ae7a
                         - ( option_kw . /.*/ )
Packit Service a2ae7a
Packit Service a2ae7a
(* View: sto_to_colon
Packit Service a2ae7a
   Allows escaped colon sequences *)
Packit Service a2ae7a
let sto_to_colon = store /[^ \t\n:=][^\n:]*((\\\\:|\\\\[ \t]*\n[ \t]+)[^\n:]*)*[^ \\\t\n:]|[^ \t\n:\\\\]/
Packit Service a2ae7a
Packit Service a2ae7a
(* View: except
Packit Service a2ae7a
 * The except operator makes it possible to write very compact rules.
Packit Service a2ae7a
 *)
Packit Service a2ae7a
let except (lns:lens) = [ label "except" . Sep.space
Packit Service a2ae7a
                        . del /except/i "EXCEPT"
Packit Service a2ae7a
                        . Sep.space . lns ]
Packit Service a2ae7a
Packit Service a2ae7a
(************************************************************************
Packit Service a2ae7a
 * Group:                 ENTRY TYPES
Packit Service a2ae7a
 *************************************************************************)
Packit Service a2ae7a
Packit Service a2ae7a
(* View: daemon *)
Packit Service a2ae7a
let daemon =
Packit Service a2ae7a
  let host = [ label "host"
Packit Service a2ae7a
             . Util.del_str "@"
Packit Service a2ae7a
             . list_item ] in
Packit Service a2ae7a
   [ label "process"
Packit Service a2ae7a
   . list_item
Packit Service a2ae7a
   . host? ]
Packit Service a2ae7a
Packit Service a2ae7a
(* View: daemon_list
Packit Service a2ae7a
    A list of <daemon>s *)
Packit Service a2ae7a
let daemon_list = Build.opt_list daemon list_sep
Packit Service a2ae7a
Packit Service a2ae7a
(* View: client *)
Packit Service a2ae7a
let client =
Packit Service a2ae7a
  let user = [ label "user"
Packit Service a2ae7a
             . list_item
Packit Service a2ae7a
             . Util.del_str "@" ] in
Packit Service a2ae7a
    [ label "client"
Packit Service a2ae7a
    . user?
Packit Service a2ae7a
    . client_host_item ]
Packit Service a2ae7a
Packit Service a2ae7a
(* View: client_file *)
Packit Service a2ae7a
let client_file = [ label "file" . client_file_item ]
Packit Service a2ae7a
Packit Service a2ae7a
(* View: client_list
Packit Service a2ae7a
    A list of <client>s *)
Packit Service a2ae7a
let client_list = Build.opt_list ( client | client_file ) list_sep
Packit Service a2ae7a
Packit Service a2ae7a
(* View: option
Packit Service a2ae7a
   Optional extensions defined in hosts_options(5) *)
Packit Service a2ae7a
let option = [ key option_kw
Packit Service a2ae7a
             . ( del /([ \t]*=[ \t]*|[ \t]+)/ " " . sto_to_colon )? ]
Packit Service a2ae7a
Packit Service a2ae7a
(* View: shell_command *)
Packit Service a2ae7a
let shell_command = [ label "shell_command"
Packit Service a2ae7a
                    . store shell_command_rx ]
Packit Service a2ae7a
Packit Service a2ae7a
(* View: entry *)
Packit Service a2ae7a
let entry = [ seq "line"
Packit Service a2ae7a
            . daemon_list
Packit Service a2ae7a
            . (except daemon_list)?
Packit Service a2ae7a
            . colon
Packit Service a2ae7a
            . client_list
Packit Service a2ae7a
            . (except client_list)?
Packit Service a2ae7a
            . ( (colon . option)+ | (colon . shell_command)? )
Packit Service a2ae7a
            . Util.eol ]
Packit Service a2ae7a
Packit Service a2ae7a
(************************************************************************
Packit Service a2ae7a
 * Group:                 LENS AND FILTER
Packit Service a2ae7a
 *************************************************************************)
Packit Service a2ae7a
Packit Service a2ae7a
(* View: lns *)
Packit Service a2ae7a
let lns = (Util.empty | Util.comment | entry)*
Packit Service a2ae7a
Packit Service a2ae7a
(* View: filter *)
Packit Service a2ae7a
let filter = incl "/etc/hosts.allow"
Packit Service a2ae7a
           . incl "/etc/hosts.deny"
Packit Service a2ae7a
Packit Service a2ae7a
let xfm = transform lns filter