Compare commits
38 Commits
nixos-24.1
...
main
Author | SHA1 | Date |
---|---|---|
|
5f8c733db3 | |
|
6978c9e38d | |
|
5e2bfd4065 | |
|
0e8de3ebd5 | |
|
bd3d9212a4 | |
|
53cd3de729 | |
|
641c0cc2a3 | |
|
e3036e3ea7 | |
|
e06597d7db | |
|
97922bfd96 | |
|
907f2b4f79 | |
|
7ba8c01ca7 | |
|
3ac643fd34 | |
|
71a6dd181f | |
|
56ff602212 | |
|
b6248a7c20 | |
|
c0162ee0ab | |
|
2ff9f229bf | |
|
9f18b6fa2b | |
|
b93a04fdeb | |
|
2b9f33af31 | |
|
c7dba4d40c | |
|
0983d7e40c | |
|
4de2918dac | |
|
52c2bf19cf | |
|
e489b5e0c0 | |
|
38e92db645 | |
|
e677a8a19d | |
|
605365998b | |
|
8a7b9ed927 | |
|
fdcb5d11f8 | |
|
00b235cc12 | |
|
99f6c563b9 | |
|
556fe1ae58 | |
|
41acad611e | |
|
77b601780b | |
|
1089645144 | |
|
d0cbcd927c |
|
@ -30,16 +30,16 @@
|
|||
},
|
||||
"nixpkgs": {
|
||||
"locked": {
|
||||
"lastModified": 1734083684,
|
||||
"narHash": "sha256-5fNndbndxSx5d+C/D0p/VF32xDiJCJzyOqorOYW4JEo=",
|
||||
"lastModified": 1734119587,
|
||||
"narHash": "sha256-AKU6qqskl0yf2+JdRdD0cfxX4b9x3KKV5RqA6wijmPM=",
|
||||
"owner": "NixOS",
|
||||
"repo": "nixpkgs",
|
||||
"rev": "314e12ba369ccdb9b352a4db26ff419f7c49fa84",
|
||||
"rev": "3566ab7246670a43abd2ffa913cc62dad9cdf7d5",
|
||||
"type": "github"
|
||||
},
|
||||
"original": {
|
||||
"owner": "NixOS",
|
||||
"ref": "nixos-24.11",
|
||||
"ref": "nixos-unstable",
|
||||
"repo": "nixpkgs",
|
||||
"type": "github"
|
||||
}
|
||||
|
|
14
flake.nix
14
flake.nix
|
@ -2,7 +2,7 @@
|
|||
description = "dragnpkgs together with nixpkgs and lix";
|
||||
|
||||
inputs = {
|
||||
nixpkgs.url = "github:NixOS/nixpkgs/nixos-24.11";
|
||||
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
||||
|
||||
lix-module = {
|
||||
url = "https://git.lix.systems/lix-project/nixos-module/archive/2.91.1-2.tar.gz";
|
||||
|
@ -29,18 +29,18 @@
|
|||
# self reference in the registry to be downloadable by URL in case it makes it into a
|
||||
# flake.lock
|
||||
meta.registry-entry = {
|
||||
from = { id = "dragnpkgs"; type = "indirect"; };
|
||||
from = { id = "dragnpkgs-unstable"; type = "indirect"; };
|
||||
to = {
|
||||
type = "git";
|
||||
url = "https://git.lain.faith/haskal/dragnpkgs.git";
|
||||
ref = "nixos-24.11";
|
||||
ref = "main";
|
||||
} // self.lib.filterAttrs
|
||||
(n: _: n == "lastModified" || n == "rev" || n == "revCount" || n == "narHash")
|
||||
self;
|
||||
};
|
||||
|
||||
# the nix path entry for self
|
||||
meta.path-entry = "dragnpkgs=flake:dragnpkgs";
|
||||
meta.path-entry = "dragnpkgs-unstable=flake:dragnpkgs-unstable";
|
||||
|
||||
lib = nixpkgs.lib.extend (final: prev: {
|
||||
licenses = prev.licenses // { fyptl = import ./lib/licenses/fyptl.nix; };
|
||||
|
@ -122,17 +122,17 @@
|
|||
};
|
||||
};
|
||||
|
||||
config.nix.registry.dragnpkgs =
|
||||
config.nix.registry.dragnpkgs-unstable =
|
||||
lib.mkIf config.dragnpkgs.setFlakeRegistry self.meta.registry-entry;
|
||||
|
||||
config.nix.registry.nixpkgs = lib.mkIf config.dragnpkgs.setNixpkgsFlakeAlias {
|
||||
from = { id = "nixpkgs"; type = "indirect"; };
|
||||
to = { id = "dragnpkgs"; type = "indirect"; };
|
||||
to = { id = "dragnpkgs-unstable"; type = "indirect"; };
|
||||
};
|
||||
|
||||
config.nix.registry.templates = lib.mkIf config.dragnpkgs.setTemplatesFlakeAlias {
|
||||
from = { id = "templates"; type = "indirect"; };
|
||||
to = { id = "dragnpkgs"; type = "indirect"; };
|
||||
to = { id = "dragnpkgs-unstable"; type = "indirect"; };
|
||||
};
|
||||
|
||||
config.nix.nixPath = lib.mkIf config.dragnpkgs.setNixPath [
|
||||
|
|
|
@ -48,8 +48,4 @@ final: prev: {
|
|||
|
||||
lix-plugins = prev.callPackage ./pkgs/lix/lix-plugins {};
|
||||
nix-plugins = builtins.throw "nix-plugins is not supported. see pkgs.lix-plugins";
|
||||
|
||||
zfs_2_2 = prev.zfs_2_2.overrideAttrs {
|
||||
patches = [ ./pkgs/zfs/0001-ZED-add-support-for-desktop-notifications-D-Bus.patch ];
|
||||
};
|
||||
}
|
||||
|
|
|
@ -1,5 +1,4 @@
|
|||
{
|
||||
lib,
|
||||
fetchFromGitHub,
|
||||
stdenv,
|
||||
meson,
|
||||
|
|
|
@ -1,131 +0,0 @@
|
|||
From 4ec38cf16ad4cc5f7bb00b93c32cd8f1d313c14c Mon Sep 17 00:00:00 2001
|
||||
From: xenia <xenia@awoo.systems>
|
||||
Date: Mon, 3 Feb 2025 21:36:29 -0500
|
||||
Subject: [PATCH] ZED: add support for desktop notifications (D-Bus)
|
||||
|
||||
---
|
||||
cmd/zed/zed.d/zed-functions.sh | 85 ++++++++++++++++++++++++++++++++++
|
||||
cmd/zed/zed.d/zed.rc | 7 +++
|
||||
2 files changed, 92 insertions(+)
|
||||
|
||||
diff --git a/cmd/zed/zed.d/zed-functions.sh b/cmd/zed/zed.d/zed-functions.sh
|
||||
index 3a2519633..d47ef070b 100644
|
||||
--- a/cmd/zed/zed.d/zed-functions.sh
|
||||
+++ b/cmd/zed/zed.d/zed-functions.sh
|
||||
@@ -209,6 +209,10 @@ zed_notify()
|
||||
[ "${rv}" -eq 0 ] && num_success=$((num_success + 1))
|
||||
[ "${rv}" -eq 1 ] && num_failure=$((num_failure + 1))
|
||||
|
||||
+ zed_notify_dbus "${subject}" "${pathname}"; rv=$?
|
||||
+ [ "${rv}" -eq 0 ] && num_success=$((num_success + 1))
|
||||
+ [ "${rv}" -eq 1 ] && num_failure=$((num_failure + 1))
|
||||
+
|
||||
[ "${num_success}" -gt 0 ] && return 0
|
||||
[ "${num_failure}" -gt 0 ] && return 1
|
||||
return 2
|
||||
@@ -624,6 +628,87 @@ zed_notify_ntfy()
|
||||
}
|
||||
|
||||
|
||||
+# zed_notify_dbus (subject, pathname)
|
||||
+#
|
||||
+# Send a notification via D-Bus ...
|
||||
+# The variable (ZED_USE_DBUS) defines whether to use D-Bus.
|
||||
+#
|
||||
+# Requires systemd (busctl) executables to be installed in the standard PATH.
|
||||
+#
|
||||
+# References
|
||||
+# ...
|
||||
+#
|
||||
+# Arguments
|
||||
+# subject: notification subject
|
||||
+# pathname: pathname containing the notification message (OPTIONAL)
|
||||
+#
|
||||
+# Globals
|
||||
+# ZED_USE_DBUS
|
||||
+#
|
||||
+# Return
|
||||
+# 0: notification sent
|
||||
+# 1: notification failed
|
||||
+# 2: not configured
|
||||
+#
|
||||
+zed_notify_dbus()
|
||||
+{
|
||||
+ local subject="$1"
|
||||
+ local pathname="${2:-"/dev/null"}"
|
||||
+ local msg_body
|
||||
+ local msg_out
|
||||
+ local msg_err
|
||||
+ local exit_status=0
|
||||
+ local dir
|
||||
+ local userid
|
||||
+
|
||||
+ [ -n "${ZED_USE_DBUS}" ] || return 2
|
||||
+
|
||||
+ if [ ! -r "${pathname}" ]; then
|
||||
+ zed_log_err "dbus cannot read \"${pathname}\""
|
||||
+ return 1
|
||||
+ fi
|
||||
+
|
||||
+ zed_check_cmd "busctl" || return 1
|
||||
+
|
||||
+ # Read the message body in.
|
||||
+ #
|
||||
+ msg_body="$(cat "${pathname}")"
|
||||
+
|
||||
+ if [ -z "${msg_body}" ]
|
||||
+ then
|
||||
+ msg_body=$subject
|
||||
+ subject=""
|
||||
+ fi
|
||||
+
|
||||
+ # Send the notification to all users with a dbus session and check for
|
||||
+ # errors.
|
||||
+ # We use busctl(1) manually rather than eg notify-send(1) due to its
|
||||
+ # ability to send D-Bus messages from root to a non-root user with the
|
||||
+ # "--machine=<user>@.host" flag.
|
||||
+ for dir in /run/user/*; do
|
||||
+ if [ -S "$dir/bus" ]; then
|
||||
+ userid="$(basename "$dir")"
|
||||
+ msg_out="$( \
|
||||
+ busctl --user --machine "$userid@.host" -- \
|
||||
+ call org.freedesktop.Notifications \
|
||||
+ /org/freedesktop/Notifications \
|
||||
+ org.freedesktop.Notifications Notify \
|
||||
+ "susssasa{sv}i" \
|
||||
+ "ZFS" 0 "drive-harddisk-symbolic" \
|
||||
+ "$subject" "$msg_body"
|
||||
+ 0 2 urgency y 2 sender-pid x "$$" "-1" \
|
||||
+ 2>/dev/null
|
||||
+ )"; rv=$?
|
||||
+
|
||||
+ if [ "${rv}" -ne 0 ]; then
|
||||
+ zed_log_err "busctl exit=${rv}"
|
||||
+ exit_status=1
|
||||
+ fi
|
||||
+ fi
|
||||
+ done
|
||||
+ return $exit_status
|
||||
+}
|
||||
+
|
||||
|
||||
# zed_rate_limit (tag, [interval])
|
||||
#
|
||||
diff --git a/cmd/zed/zed.d/zed.rc b/cmd/zed/zed.d/zed.rc
|
||||
index 859c6f9cb..567cd556a 100644
|
||||
--- a/cmd/zed/zed.d/zed.rc
|
||||
+++ b/cmd/zed/zed.d/zed.rc
|
||||
@@ -176,3 +176,10 @@ ZED_SYSLOG_SUBCLASS_EXCLUDE="history_event"
|
||||
# <https://docs.ntfy.sh/install/>
|
||||
# https://ntfy.sh by default; uncomment to enable an alternative service url.
|
||||
#ZED_NTFY_URL="https://ntfy.sh"
|
||||
+
|
||||
+##
|
||||
+# Whether to send desktop notifications via D-Bus
|
||||
+# If defined, busctl(1) will be used to send desktop notifications via
|
||||
+# the org.freedesktop.Notifications D-Bus interface
|
||||
+# Disabled by default; uncomment to enable.
|
||||
+#ZED_USE_DBUS=1
|
||||
--
|
||||
2.47.0
|
||||
|
Loading…
Reference in New Issue