summaryrefslogtreecommitdiffstats
path: root/lass/2configs/br.nix
diff options
context:
space:
mode:
authornin <nineinchnade@gmail.com>2017-11-07 20:49:48 +0100
committernin <nineinchnade@gmail.com>2017-11-07 20:49:48 +0100
commitd2551a2268e54fede53d982e0173424735f94680 (patch)
treed65ad5523a650de810f6733e02e5471eed83f57e /lass/2configs/br.nix
parentfa78b6615444e6db21045f93c2b3ae763e23aff9 (diff)
parent111c94fe61e5c47f3af04e38b6d804ee43ca8e98 (diff)
Merge remote-tracking branch 'prism/master'
Diffstat (limited to 'lass/2configs/br.nix')
-rw-r--r--lass/2configs/br.nix48
1 files changed, 48 insertions, 0 deletions
diff --git a/lass/2configs/br.nix b/lass/2configs/br.nix
new file mode 100644
index 000000000..35bac8fee
--- /dev/null
+++ b/lass/2configs/br.nix
@@ -0,0 +1,48 @@
+with import <stockholm/lib>;
+{ config, pkgs, ... }: {
+
+ imports = [
+ <nixpkgs/nixos/modules/services/hardware/sane_extra_backends/brscan4.nix>
+ ];
+
+ krebs.nixpkgs.allowUnfreePredicate = pkg: any (flip hasPrefix pkg.name) [
+ "brother-udev-rule-type1-"
+ "brscan4-"
+ "mfcl2700dnlpr-"
+ ];
+
+ hardware.sane = {
+ enable = true;
+ brscan4 = {
+ enable = true;
+ netDevices = {
+ bra = {
+ model = "MFCL2700DN";
+ ip = "10.23.42.221";
+ };
+ };
+ };
+ };
+
+ services.saned.enable = true;
+
+ # usage: scanimage -d "$(find-scanner bra)" --batch --format=tiff --resolution 150 -x 211 -y 298
+ environment.systemPackages = [
+ (pkgs.writeDashBin "find-scanner" ''
+ set -efu
+ name=$1
+ ${pkgs.sane-backends}/bin/scanimage -f '%m %d
+ ' \
+ | ${pkgs.gawk}/bin/awk -v dev="*$name" '$1 == dev { print $2; exit }' \
+ | ${pkgs.gnugrep}/bin/grep .
+ '')
+ ];
+
+ services.printing = {
+ enable = true;
+ drivers = [
+ pkgs.mfcl2700dncupswrapper
+ ];
+ };
+
+}