42c6771744
For security reasons, and generally, it is best to create a more fine grained group than plugdev. This way users that wish to tweak razer devices don't have access to the entire plugdev group's permissions. This is of course a breaking change.
48 lines
1.4 KiB
Nix
48 lines
1.4 KiB
Nix
{ coreutils
|
|
, fetchFromGitHub
|
|
, kernel
|
|
, stdenv
|
|
, lib
|
|
, util-linux
|
|
}:
|
|
|
|
let
|
|
common = import ../../../development/python-modules/openrazer/common.nix { inherit lib fetchFromGitHub; };
|
|
in
|
|
stdenv.mkDerivation (common // {
|
|
pname = "openrazer";
|
|
version = "${common.version}-${kernel.version}";
|
|
|
|
nativeBuildInputs = kernel.moduleBuildDependencies;
|
|
|
|
buildFlags = [
|
|
"KERNELDIR=${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"
|
|
];
|
|
|
|
installPhase = ''
|
|
runHook preInstall
|
|
|
|
binDir="$out/lib/modules/${kernel.modDirVersion}/kernel/drivers/hid"
|
|
mkdir -p "$binDir"
|
|
cp -v driver/*.ko "$binDir"
|
|
RAZER_MOUNT_OUT="$out/bin/razer_mount"
|
|
RAZER_RULES_OUT="$out/etc/udev/rules.d/99-razer.rules"
|
|
install -m 644 -v -D install_files/udev/99-razer.rules $RAZER_RULES_OUT
|
|
install -m 755 -v -D install_files/udev/razer_mount $RAZER_MOUNT_OUT
|
|
substituteInPlace $RAZER_RULES_OUT \
|
|
--replace razer_mount $RAZER_MOUNT_OUT \
|
|
--replace plugdev openrazer
|
|
substituteInPlace $RAZER_MOUNT_OUT \
|
|
--replace /usr/bin/logger ${util-linux}/bin/logger \
|
|
--replace chgrp ${coreutils}/bin/chgrp \
|
|
--replace "PATH='/sbin:/bin:/usr/sbin:/usr/bin'" "" \
|
|
--replace plugdev openrazer
|
|
|
|
runHook postInstall
|
|
'';
|
|
|
|
meta = common.meta // {
|
|
description = "An entirely open source Linux driver that allows you to manage your Razer peripherals on GNU/Linux";
|
|
broken = kernel.kernelOlder "4.19";
|
|
};
|
|
})
|