148 lines
4.5 KiB
Nix
148 lines
4.5 KiB
Nix
## PPP
|
|
## ===
|
|
##
|
|
## ``ppoe`` (PPP over Ethernet) provides a service to address the case
|
|
## where your Liminix device is connected to an upstream network using
|
|
## PPPoE. This is typical for UK broadband connections where the
|
|
## physical connection is made by OpenReach ("Fibre To The X") and
|
|
## common in some other localities as well: check with your ISP if this is
|
|
## you.
|
|
##
|
|
## ``l2tp`` (Layer 2 Tunelling Protocol) provides a service that
|
|
## tunnels PPP over the Internet. This may be used by some ISPs in
|
|
## conjunction with a DHCP uplink, or other more creative forms of
|
|
## network connection
|
|
|
|
{
|
|
lib,
|
|
pkgs,
|
|
config,
|
|
...
|
|
}:
|
|
let
|
|
inherit (lib) mkOption types;
|
|
inherit (pkgs) liminix;
|
|
mkStringOption =
|
|
description:
|
|
mkOption {
|
|
type = types.nullOr types.str;
|
|
default = null;
|
|
inherit description;
|
|
};
|
|
in
|
|
{
|
|
imports = [ ../secrets ];
|
|
options = {
|
|
system.service.pppoe = mkOption {
|
|
type = liminix.lib.types.serviceDefn;
|
|
};
|
|
system.service.l2tp = mkOption {
|
|
type = liminix.lib.types.serviceDefn;
|
|
};
|
|
};
|
|
config = {
|
|
system.service.pppoe = config.system.callService ./pppoe.nix {
|
|
interface = mkOption {
|
|
type = liminix.lib.types.service;
|
|
description = "ethernet interface to run PPPoE over";
|
|
};
|
|
username = mkOption {
|
|
type = types.nullOr (liminix.lib.types.replacable types.str);
|
|
default = null;
|
|
description = "username";
|
|
};
|
|
password = mkOption {
|
|
type = types.nullOr (liminix.lib.types.replacable types.str);
|
|
default = null;
|
|
description = "password";
|
|
};
|
|
bandwidth = mkOption {
|
|
type = types.nullOr (types.int);
|
|
default = null;
|
|
description = "approximate bandwidth in bytes/second. Used to calculate rate limits for ICMP";
|
|
};
|
|
lcpEcho = {
|
|
adaptive = mkOption {
|
|
description = "send LCP echo-request frames only if no traffic was received from the peer since the last echo-request was sent";
|
|
type = types.bool;
|
|
default = true;
|
|
};
|
|
interval = mkOption {
|
|
type = types.nullOr types.int;
|
|
default = 3;
|
|
description = "send an LCP echo-request frame to the peer every n seconds";
|
|
};
|
|
failure = mkOption {
|
|
type = types.nullOr types.int;
|
|
default = 3;
|
|
description = "terminate connection if n LCP echo-requests are sent without receiving a valid LCP echo-reply";
|
|
};
|
|
};
|
|
debug = mkOption {
|
|
description = "log the contents of all control packets sent or received";
|
|
default = false;
|
|
type = types.bool;
|
|
};
|
|
ppp-options = mkOption {
|
|
type = types.listOf types.str;
|
|
description = "options supplied on ppp command line";
|
|
default = [ ];
|
|
};
|
|
};
|
|
system.service.l2tp = config.system.callService ./l2tp.nix {
|
|
lns = mkOption {
|
|
type = types.str;
|
|
description = "hostname or address of the L2TP network server";
|
|
};
|
|
username = mkOption {
|
|
type = types.nullOr (liminix.lib.types.replacable types.str);
|
|
default = null;
|
|
description = "username";
|
|
};
|
|
password = mkOption {
|
|
type = types.nullOr (liminix.lib.types.replacable types.str);
|
|
default = null;
|
|
description = "password";
|
|
};
|
|
lcpEcho = {
|
|
adaptive = mkOption {
|
|
description = "send LCP echo-request frames only if no traffic was received from the peer since the last echo-request was sent";
|
|
type = types.bool;
|
|
default = true;
|
|
};
|
|
interval = mkOption {
|
|
type = types.nullOr types.int;
|
|
default = 3;
|
|
description = "send an LCP echo-request frame to the peer every n seconds";
|
|
};
|
|
failure = mkOption {
|
|
type = types.nullOr types.int;
|
|
default = 3;
|
|
description = "terminate connection if n LCP echo-requests are sent without receiving a valid LCP echo-reply";
|
|
};
|
|
};
|
|
debug = mkOption {
|
|
description = "log the contents of all control packets sent or received";
|
|
default = false;
|
|
type = types.bool;
|
|
};
|
|
ppp-options = mkOption {
|
|
type = types.listOf types.str;
|
|
default = [ ];
|
|
description = "options supplied on ppp command line";
|
|
};
|
|
};
|
|
kernel = {
|
|
config = {
|
|
PPP = "y";
|
|
PPP_BSDCOMP = "y";
|
|
PPP_DEFLATE = "y";
|
|
PPP_ASYNC = "y";
|
|
PPP_SYNC_TTY = "y";
|
|
PPPOL2TP = "y";
|
|
L2TP = "y";
|
|
};
|
|
};
|
|
};
|
|
}
|