libvirtd.aug 3.8 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
(* /etc/libvirt/libvirtd.conf *)

module Libvirtd =
   autoload xfm

   let eol   = del /[ \t]*\n/ "\n"
   let value_sep   = del /[ \t]*=[ \t]*/  " = "
   let indent = del /[ \t]*/ ""

   let array_sep  = del /,[ \t\n]*/ ", "
   let array_start = del /\[[ \t\n]*/ "[ "
   let array_end = del /\]/ "]"

   let str_val = del /\"/ "\"" . store /[^\"]*/ . del /\"/ "\""
   let bool_val = store /0|1/
16
   let int_val = store /[0-9]+/
17 18 19 20 21
   let str_array_element = [ seq "el" . str_val ] . del /[ \t\n]*/ ""
   let str_array_val = counter "el" . array_start . ( str_array_element . ( array_sep . str_array_element ) * ) ? . array_end

   let str_entry       (kw:string) = [ key kw . value_sep . str_val ]
   let bool_entry      (kw:string) = [ key kw . value_sep . bool_val ]
22
   let int_entry      (kw:string) = [ key kw . value_sep . int_val ]
23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
   let str_array_entry (kw:string) = [ key kw . value_sep . str_array_val ]


   (* Config entry grouped by function - same order as example config *)
   let network_entry = bool_entry "listen_tls"
                     | bool_entry "listen_tcp"
                     | str_entry "tls_port"
                     | str_entry "tcp_port"
                     | str_entry "listen_addr"
                     | bool_entry "mdns_adv"
                     | str_entry "mdns_name"

   let sock_acl_entry = str_entry "unix_sock_group"
                      | str_entry "unix_sock_ro_perms"
                      | str_entry "unix_sock_rw_perms"
38
                      | str_entry "unix_sock_dir"
39 40 41 42 43 44 45 46 47 48 49 50

   let authentication_entry = str_entry "auth_unix_ro"
                            | str_entry "auth_unix_rw"
                            | str_entry "auth_tcp"
                            | str_entry "auth_tls"

   let certificate_entry = str_entry "key_file"
                         | str_entry "cert_file"
                         | str_entry "ca_file"
                         | str_entry "crl_file"

   let authorization_entry = bool_entry "tls_no_verify_certificate"
51
                           | bool_entry "tls_no_sanity_certificate"
52 53
                           | str_array_entry "tls_allowed_dn_list"
                           | str_array_entry "sasl_allowed_username_list"
54
                           | str_array_entry "access_drivers"
55

56 57 58
   let processing_entry = int_entry "min_workers"
                        | int_entry "max_workers"
                        | int_entry "max_clients"
M
Michal Privoznik 已提交
59
                        | int_entry "max_queued_clients"
60
                        | int_entry "max_anonymous_clients"
61 62
                        | int_entry "max_requests"
                        | int_entry "max_client_requests"
63
                        | int_entry "prio_workers"
64

D
Daniel Veillard 已提交
65 66 67
   let logging_entry = int_entry "log_level"
                     | str_entry "log_filters"
                     | str_entry "log_outputs"
D
Daniel P. Berrange 已提交
68
                     | int_entry "log_buffer_size"
D
Daniel Veillard 已提交
69

70 71 72
   let auditing_entry = int_entry "audit_level"
                      | bool_entry "audit_logging"

73 74 75 76
   let keepalive_entry = int_entry "keepalive_interval"
                       | int_entry "keepalive_count"
                       | bool_entry "keepalive_required"

D
Daniel P. Berrange 已提交
77 78
   let misc_entry = str_entry "host_uuid"

79 80 81 82 83 84
   (* Each enty in the config is one of the following three ... *)
   let entry = network_entry
             | sock_acl_entry
             | authentication_entry
             | certificate_entry
             | authorization_entry
85
             | processing_entry
D
Daniel Veillard 已提交
86
             | logging_entry
87
             | auditing_entry
88
             | keepalive_entry
D
Daniel P. Berrange 已提交
89
             | misc_entry
90 91 92 93 94 95 96 97 98 99 100
   let comment = [ label "#comment" . del /#[ \t]*/ "# " .  store /([^ \t\n][^\n]*)?/ . del /\n/ "\n" ]
   let empty = [ label "#empty" . eol ]

   let record = indent . entry . eol

   let lns = ( record | comment | empty ) *

   let filter = incl "/etc/libvirt/libvirtd.conf"
              . Util.stdexcl

   let xfm = transform lns filter