qubes-mirage-firewall/router.mli

34 lines
943 B
OCaml
Raw Normal View History

2015-12-30 04:52:24 -05:00
(* Copyright (C) 2015, Thomas Leonard <thomas.leonard@unikernel.com>
See the README file for details. *)
(** Routing packets to the right network interface. *)
2017-03-02 09:52:55 -05:00
open Fw_utils
2015-12-30 04:52:24 -05:00
type t = private {
2023-06-30 09:33:41 -04:00
config : Dao.network_config;
clients : Client_eth.t;
2017-03-02 09:52:55 -05:00
nat : My_nat.t;
uplink : interface;
}
2015-12-30 04:52:24 -05:00
val create :
2023-06-30 09:33:41 -04:00
config : Dao.network_config ->
clients : Client_eth.t ->
uplink : interface ->
nat : My_nat.t ->
2015-12-30 04:52:24 -05:00
t
(** [create ~client_eth ~uplink ~nat] is a new routing table
that routes packets outside of [client_eth] via [uplink]. *)
2015-12-30 04:52:24 -05:00
2017-03-02 09:52:55 -05:00
val target : t -> Ipv4_packet.t -> interface option
(** [target t packet] is the interface to which [packet] should be routed. *)
2015-12-30 04:52:24 -05:00
val add_client : t -> client_link -> unit Lwt.t
(** [add_client t iface] adds a rule for routing packets addressed to [iface]. *)
2015-12-30 04:52:24 -05:00
val remove_client : t -> client_link -> unit
val classify : t -> Ipaddr.t -> Packet.host
val resolve : t -> Packet.host -> Ipaddr.t