Source file runtime_arg.ml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
open Functoria
include Runtime_arg
(** {2 OCaml runtime} *)
let runtime_arg ~pos name =
Runtime_arg.create ~pos
~packages:[ package "mirage-runtime" ]
(Fmt.str "Mirage_runtime.%s" name)
let runtime_network_key ~pos fmt =
Fmt.kstr
(Runtime_arg.create ~pos
~packages:[ package "mirage-runtime" ~sublibs:[ "network" ] ])
("Mirage_runtime_network." ^^ fmt)
let delay = runtime_arg ~pos:__POS__ "delay"
let pp_group ppf = function
| None | Some "" -> ()
| Some g -> Fmt.pf ppf "~group:%S " g
let pp_docs ppf = function
| None | Some "" -> ()
| Some g -> Fmt.pf ppf "~docs:%S " g
let pp_option pp ppf = function
| None -> Fmt.pf ppf "None"
| Some d -> Fmt.pf ppf "(Some %a)" pp d
let escape pp ppf = Fmt.kstr (fun str -> Fmt.Dump.string ppf str) "%a" pp
(** {3 Network keys} *)
let interface ?group ?docs default =
runtime_network_key ~pos:__POS__ "interface %a%a%S" pp_group group pp_docs
docs default
module V4 = struct
open Ipaddr.V4
let pp_prefix ppf p =
Fmt.pf ppf "(Ipaddr.V4.Prefix.of_string_exn %a)" (escape Prefix.pp) p
let pp ppf p = Fmt.pf ppf "(Ipaddr.V4.of_string_exn %a)" (escape pp) p
let network ?group ?docs default =
runtime_network_key ~pos:__POS__ "V4.network %a%a%a" pp_group group pp_docs
docs pp_prefix default
let gateway ?group ?docs default =
runtime_network_key ~pos:__POS__ "V4.gateway %a%a%a" pp_group group pp_docs
docs (pp_option pp) default
end
module V6 = struct
open Ipaddr.V6
let pp_prefix ppf p =
Fmt.pf ppf "(Ipaddr.V6.Prefix.of_string_exn %a)" (escape Prefix.pp) p
let pp ppf p = Fmt.pf ppf "(Ipaddr.V6.of_string_exn %a)" (escape pp) p
let network ?group ?docs default =
runtime_network_key ~pos:__POS__ "V6.network %a%a%a" pp_group group pp_docs
docs (pp_option pp_prefix) default
let gateway ?group ?docs default =
runtime_network_key ~pos:__POS__ "V6.gateway %a%a%a" pp_group group pp_docs
docs (pp_option pp) default
let accept_router_advertisements ?group ?docs () =
runtime_network_key ~pos:__POS__ "V6.accept_router_advertisements %a%a()"
pp_group group pp_docs docs
end
let ipv4_only ?group ?docs () =
runtime_network_key ~pos:__POS__ "ipv4_only %a%a()" pp_group group pp_docs
docs
let ipv6_only ?group ?docs () =
runtime_network_key ~pos:__POS__ "ipv6_only %a%a()" pp_group group pp_docs
docs
let resolver ?group ?docs ?(default = []) () =
let pp_default ppf = function
| [] -> ()
| l -> Fmt.pf ppf "~default:%a " Fmt.Dump.(list string) l
in
runtime_network_key ~pos:__POS__ "resolver %a%a%a()" pp_group group pp_docs
docs pp_default default
let dns_servers ?group ?docs default =
runtime_network_key ~pos:__POS__ "dns_servers %a%a%a" pp_group group pp_docs
docs
(pp_option Fmt.Dump.(list string))
default
let dns_timeout ?group ?docs default =
runtime_network_key ~pos:__POS__ "dns_timeout %a%a%a" pp_group group pp_docs
docs (pp_option Fmt.int64) default
let dns_cache_size ?group ?docs default =
runtime_network_key ~pos:__POS__ "dns_cache_size %a%a%a" pp_group group
pp_docs docs (pp_option Fmt.int) default
let he_aaaa_timeout ?group ?docs default =
runtime_network_key ~pos:__POS__ "he_aaaa_timeout %a%a%a" pp_group group
pp_docs docs (pp_option Fmt.int64) default
let he_connect_delay ?group ?docs default =
runtime_network_key ~pos:__POS__ "he_connect_delay %a%a%a" pp_group group
pp_docs docs (pp_option Fmt.int64) default
let he_connect_timeout ?group ?docs default =
runtime_network_key ~pos:__POS__ "he_connect_timeout %a%a%a" pp_group group
pp_docs docs (pp_option Fmt.int64) default
let he_resolve_timeout ?group ?docs default =
runtime_network_key ~pos:__POS__ "he_resolve_timeout %a%a%a" pp_group group
pp_docs docs (pp_option Fmt.int64) default
let he_resolve_retries ?group ?docs default =
runtime_network_key ~pos:__POS__ "he_resolve_retries %a%a%a" pp_group group
pp_docs docs (pp_option Fmt.int) default
let he_timer_interval ?group ?docs default =
runtime_network_key ~pos:__POS__ "he_timer_interval %a%a%a" pp_group group
pp_docs docs (pp_option Fmt.int64) default
let ssh_key ?group ?docs default =
runtime_network_key ~pos:__POS__ "ssh_key %a%a%a" pp_group group pp_docs docs
(pp_option Fmt.Dump.string)
default
let ssh_password ?group ?docs default =
runtime_network_key ~pos:__POS__ "ssh_password %a%a%a" pp_group group pp_docs
docs
(pp_option Fmt.Dump.string)
default
let ssh_authenticator ?group ?docs default =
runtime_network_key ~pos:__POS__ "ssh_authenticator %a%a%a" pp_group group
pp_docs docs
(pp_option Fmt.Dump.string)
default
let tls_authenticator ?group ?docs default =
runtime_network_key ~pos:__POS__ "tls_authenticator %a%a%a" pp_group group
pp_docs docs
(pp_option Fmt.Dump.string)
default
let ?group ?docs default =
runtime_network_key ~pos:__POS__ "http_headers %a%a%a" pp_group group pp_docs
docs
(pp_option Fmt.Dump.(list (pair string string)))
default
let pp_ipaddr ppf p = Fmt.pf ppf "Ipaddr.of_string %a" (escape Ipaddr.pp) p
let syslog ?group ?docs default =
runtime_network_key ~pos:__POS__ "syslog %a%a%a" pp_group group pp_docs docs
(pp_option pp_ipaddr) default
let syslog_port ?group ?docs default =
runtime_network_key ~pos:__POS__ "syslog_port %a%a%a" pp_group group pp_docs
docs (pp_option Fmt.int) default
let syslog_truncate ?group ?docs default =
runtime_network_key ~pos:__POS__ "syslog_truncate %a%a%a" pp_group group
pp_docs docs (pp_option Fmt.int) default
let syslog_keyname ?group ?docs default =
runtime_network_key ~pos:__POS__ "syslog_keyname %a%a%a" pp_group group
pp_docs docs (pp_option Fmt.string) default
let monitor ?group ?docs default =
runtime_network_key ~pos:__POS__ "monitor %a%a%a" pp_group group pp_docs docs
(pp_option pp_ipaddr) default
type log_threshold = [ `All | `Src of string ] * Logs.level option
let logs = runtime_arg ~pos:__POS__ "logs"