summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--krebs/5pkgs/default.nix9
-rw-r--r--tv/1systems/xu/config.nix9
-rw-r--r--tv/3modules/default.nix1
-rw-r--r--tv/3modules/umts.nix99
-rw-r--r--tv/5pkgs/default.nix8
5 files changed, 118 insertions, 8 deletions
diff --git a/krebs/5pkgs/default.nix b/krebs/5pkgs/default.nix
index af4cbb3ba..84c00e82d 100644
--- a/krebs/5pkgs/default.nix
+++ b/krebs/5pkgs/default.nix
@@ -13,6 +13,15 @@ foldl' mergeAttrs {}
//
{
+ # https://github.com/NixOS/nixpkgs/pull/30065
+ brscan4 = overrideDerivation super.brscan4 (original: rec {
+ name = "brscan4-0.4.4-4";
+ src = super.fetchurl {
+ url = "http://download.brother.com/welcome/dlf006645/${name}.amd64.deb";
+ sha256 = "0xy5px96y1saq9l80vwvfn6anr2q42qlxdhm6ci2a0diwib5q9fd";
+ };
+ });
+
ReaktorPlugins = self.callPackage ./simple/Reaktor/plugins.nix {};
# https://github.com/proot-me/PRoot/issues/106
diff --git a/tv/1systems/xu/config.nix b/tv/1systems/xu/config.nix
index 0363c983d..08bdfa52b 100644
--- a/tv/1systems/xu/config.nix
+++ b/tv/1systems/xu/config.nix
@@ -161,5 +161,14 @@ with import <stockholm/lib>;
tv = "/home/tv/stockholm/tv/5pkgs";
};
+ tv.umts = {
+ enable = true;
+ modem = "/dev/serial/by-id/usb-Lenovo_F5521gw_097EAD658B094860-if09";
+ initstrings = ''
+ Init1 = AT+CFUN=1
+ Init2 = AT+CGDCONT=1,"IP","pinternet.interkom.de","",0,0
+ '';
+ };
+
virtualisation.virtualbox.host.enable = true;
}
diff --git a/tv/3modules/default.nix b/tv/3modules/default.nix
index 493cc8b72..0fcf8cc9d 100644
--- a/tv/3modules/default.nix
+++ b/tv/3modules/default.nix
@@ -5,6 +5,7 @@
./hosts.nix
./iptables.nix
./nixpkgs-overlays.nix
+ ./umts.nix
./x0vncserver.nix
];
}
diff --git a/tv/3modules/umts.nix b/tv/3modules/umts.nix
new file mode 100644
index 000000000..a60627025
--- /dev/null
+++ b/tv/3modules/umts.nix
@@ -0,0 +1,99 @@
+with import <stockholm/lib>;
+{ config, lib, pkgs, ... }: let
+
+ cfg = config.tv.umts;
+
+ umts-dial = pkgs.writeDash "umts-dial" ''
+ set -euf
+ ${pkgs.systemd}/bin/systemctl start umts
+ trap 'cleanup; trap - EXIT INT TERM' EXIT INT TERM
+ cleanup() {
+ ${pkgs.systemd}/bin/systemctl stop umts
+ }
+ echo nameserver 8.8.8.8 >> /etc/resolv.conf
+ ${pkgs.systemd}/bin/journalctl -xfu umts
+ '';
+
+ # https://github.com/NixOS/nixpkgs/issues/16113
+ wvdial = let
+ nixpkgs-1509 = import (pkgs.fetchFromGitHub {
+ owner = "NixOS"; repo = "nixpkgs-channels";
+ rev = "91371c2bb6e20fc0df7a812332d99c38b21a2bda";
+ sha256 = "1as1i0j9d2n3iap9b471y4x01561r2s3vmjc5281qinirlr4al73";
+ }) {};
+ in
+ nixpkgs-1509.wvdial;
+
+in {
+ options.tv.umts = {
+ enable = mkEnableOption "tv.umts";
+ modem = mkOption {
+ type = types.str;
+ default = "/dev/ttyUSB0";
+ };
+ initstrings = mkOption {
+ type = types.str;
+ default = ''
+ Init1 = ATZ
+ Init2 = ATQ0 V1 E1 S0=0 &C1 &D2
+ '';
+ };
+ username = mkOption {
+ type = types.str;
+ default = "default";
+ };
+ password = mkOption {
+ type = types.str;
+ default = "default";
+ };
+ pppDefaults = mkOption {
+ type = types.str;
+ default = ''
+ noipdefault
+ usepeerdns
+ defaultroute
+ persist
+ noauth
+ '';
+ };
+ };
+
+ config = lib.mkIf cfg.enable {
+ environment.etc = {
+ "ppp/peers/wvdial".text = cfg.pppDefaults;
+ "wvdial.conf".text = ''
+ [Dialer Defaults]
+ Modem = ${cfg.modem}
+ ${cfg.initstrings}
+ Modem Type = Analog Modem
+ Baud = 460800
+ phone= *99#
+ Username = ${cfg.username}
+ Password = ${cfg.password}
+ Stupid Mode = 1
+ Idle Seconds = 0
+ PPPD Path = ${pkgs.ppp}/bin/pppd
+ '';
+ };
+
+ krebs.per-user.tv.packages = [
+ (pkgs.writeDashBin "umts" ''
+ exec sudo ${umts-dial}
+ '')
+ ];
+
+ security.sudo.extraConfig = ''
+ tv ALL= (root) NOPASSWD: ${umts-dial}
+ '';
+
+ systemd.services.umts = {
+ description = "UMTS wvdial Service";
+ serviceConfig = {
+ Type = "simple";
+ Restart = "always";
+ RestartSec = "10s";
+ ExecStart = "${wvdial}/bin/wvdial -n";
+ };
+ };
+ };
+}
diff --git a/tv/5pkgs/default.nix b/tv/5pkgs/default.nix
index 9dc7ae7b1..261871e62 100644
--- a/tv/5pkgs/default.nix
+++ b/tv/5pkgs/default.nix
@@ -13,14 +13,6 @@ foldl' mergeAttrs {}
//
{
- brscan4 = overrideDerivation super.brscan4 (original: rec {
- name = "brscan4-0.4.4-4";
- src = super.fetchurl {
- url = "http://download.brother.com/welcome/dlf006645/${name}.amd64.deb";
- sha256 = "0xy5px96y1saq9l80vwvfn6anr2q42qlxdhm6ci2a0diwib5q9fd";
- };
- });
-
# TODO use XDG_RUNTIME_DIR?
cr = self.writeDashBin "cr" ''
set -efu