about summary refs log tree commit diff
path: root/pkgs/sternenseemann
diff options
context:
space:
mode:
authorsternenseemann <0rpkxez4ksa01gb3typccl0i@systemli.org>2021-02-05 11:59:11 +0100
committersternenseemann <0rpkxez4ksa01gb3typccl0i@systemli.org>2021-02-06 20:19:48 +0100
commita36ebdfef3f4f61846f219ff323ed9736d5f6ba9 (patch)
treee96835f553f9253f46fae0f7e67feefdef2514bf /pkgs/sternenseemann
parente7dbc2b089f7f7a3822e4e9548007bd6b21a05b8 (diff)
pkgs/sternenseemann/pass: init
sterni's patched pass with passmenu
Diffstat (limited to 'pkgs/sternenseemann')
-rw-r--r--pkgs/sternenseemann/default.nix24
-rw-r--r--pkgs/sternenseemann/patches/passmenu-wayland.patch50
2 files changed, 73 insertions, 1 deletions
diff --git a/pkgs/sternenseemann/default.nix b/pkgs/sternenseemann/default.nix
index 706c924b..8eebe82d 100644
--- a/pkgs/sternenseemann/default.nix
+++ b/pkgs/sternenseemann/default.nix
@@ -1,4 +1,4 @@
-{ pkgs, lib }:
+{ pkgs, lib, profpatsch }:
 
 let
   inherit (pkgs)
@@ -11,6 +11,12 @@ let
     haskell
     ;
 
+  inherit (profpatsch)
+    getBins
+    ;
+
+  bins = getBins pkgs.bemenu [ "bemenu" ];
+
   haskellPackages = pkgs.haskellPackages.override {
     overrides = self: super: {
       emoji-generic = haskell.lib.overrideSrc
@@ -33,6 +39,22 @@ in
 
   logbook = ocamlPackages.callPackage ./logbook { };
 
+  pass = (pkgs.pass.override {
+    waylandSupport = true;
+    x11Support = false;
+  }).overrideAttrs (old: {
+    patches = old.patches ++ [ ./patches/passmenu-wayland.patch ];
+    postPatch = ''
+      ${old.postPatch}
+      substituteInPlace "contrib/dmenu/passmenu" \
+        --replace "bemenu" "'${bins.bemenu} -l10'"
+    '';
+    postInstall = ''
+      ${old.postInstall}
+      cp "contrib/dmenu/passmenu" "$out/bin/"
+    '';
+  });
+
   shakti = callPackage ./shakti { };
 
   t = python3Packages.callPackage ./t { };
diff --git a/pkgs/sternenseemann/patches/passmenu-wayland.patch b/pkgs/sternenseemann/patches/passmenu-wayland.patch
new file mode 100644
index 00000000..ef2f3a10
--- /dev/null
+++ b/pkgs/sternenseemann/patches/passmenu-wayland.patch
@@ -0,0 +1,50 @@
+diff --git a/contrib/dmenu/README.md b/contrib/dmenu/README.md
+index 9d54fb4..c5d0191 100644
+--- a/contrib/dmenu/README.md
++++ b/contrib/dmenu/README.md
+@@ -4,6 +4,8 @@ clipboard without having to open up a terminal window if you don't already have
+ one open. If `--type` is specified, the password is typed using [xdotool][]
+ instead of copied to the clipboard.
+ 
++On wayland [bemenu][] is used to replace dmenu.
++
+ # Usage
+ 
+     passmenu [--type] [dmenu arguments...]
+@@ -11,3 +13,4 @@ instead of copied to the clipboard.
+ [dmenu]: http://tools.suckless.org/dmenu/
+ [xdotool]: http://www.semicomplete.com/projects/xdotool/
+ [pass]: http://www.zx2c4.com/projects/password-store/
++[bemenu]: https://github.com/Cloudef/bemenu
+diff --git a/contrib/dmenu/passmenu b/contrib/dmenu/passmenu
+index 83268bc..0eee575 100755
+--- a/contrib/dmenu/passmenu
++++ b/contrib/dmenu/passmenu
+@@ -8,12 +8,26 @@ if [[ $1 == "--type" ]]; then
+ 	shift
+ fi
+ 
++if [[ -n $WAYLAND_DISPLAY ]]; then
++	if [[ $typeit -eq 0 ]]; then
++		dmenu=bemenu
++	else
++		echo "Error: --type is not supported on wayland" >&2
++		exit 1
++	fi
++elif [[ -n $DISPLAY ]]; then
++	dmenu=dmenu
++else
++	echo "Error: No Wayland or X11 display detected" >&2
++	exit 1
++fi
++
+ prefix=${PASSWORD_STORE_DIR-~/.password-store}
+ password_files=( "$prefix"/**/*.gpg )
+ password_files=( "${password_files[@]#"$prefix"/}" )
+ password_files=( "${password_files[@]%.gpg}" )
+ 
+-password=$(printf '%s\n' "${password_files[@]}" | dmenu "$@")
++password=$(printf '%s\n' "${password_files[@]}" | $dmenu "$@")
+ 
+ [[ -n $password ]] || exit
+