119
flake.nix
119
flake.nix
@@ -10,41 +10,91 @@
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
outputs =
|
outputs = { self, nixpkgs, flake-utils, fenix, ... }:
|
||||||
{
|
|
||||||
self,
|
|
||||||
nixpkgs,
|
|
||||||
flake-utils,
|
|
||||||
fenix,
|
|
||||||
...
|
|
||||||
}:
|
|
||||||
let
|
let
|
||||||
overlay =
|
overlay = final: prev:
|
||||||
final: prev:
|
|
||||||
let
|
let
|
||||||
fenixPkgs = fenix.packages.${final.stdenv.hostPlatform.system};
|
fenixPkgs = fenix.packages.${final.stdenv.hostPlatform.system};
|
||||||
in
|
|
||||||
{
|
|
||||||
rustToolchain =
|
rustToolchain =
|
||||||
with fenixPkgs;
|
with fenixPkgs;
|
||||||
combine (
|
combine (with stable; [
|
||||||
with stable;
|
|
||||||
[
|
|
||||||
clippy
|
clippy
|
||||||
rustc
|
rustc
|
||||||
cargo
|
cargo
|
||||||
rustfmt
|
rustfmt
|
||||||
rust-src
|
rust-src
|
||||||
]
|
]);
|
||||||
);
|
in
|
||||||
|
{
|
||||||
|
inherit rustToolchain;
|
||||||
|
|
||||||
|
mpd-discord-presence = final.rustPlatform.buildRustPackage {
|
||||||
|
pname = "mpd-discord-presence";
|
||||||
|
version = "0.1.0";
|
||||||
|
|
||||||
|
src = self;
|
||||||
|
|
||||||
|
cargoLock.lockFile = ./Cargo.lock;
|
||||||
|
|
||||||
|
enableParallelBuild = true;
|
||||||
|
|
||||||
|
meta = {
|
||||||
|
description = "MPD Discord daemon";
|
||||||
|
homepage = "https://git.slendi.dev/Slendi/mpd-discord-presence";
|
||||||
|
license = final.lib.licenses.gpl3;
|
||||||
|
mainProgram = "mpd-discord-presence";
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
overlays.default = overlay;
|
overlays.default = overlay;
|
||||||
homeManagerModules.mpd-discord-presence = import ./nix/mpd-discord-presence.nix;
|
|
||||||
|
homeManagerModules.mpd-discord-presence = { config, lib, pkgs, ... }:
|
||||||
|
let
|
||||||
|
cfg = config.services.mpd-discord-presence;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options.services.mpd-discord-presence = {
|
||||||
|
enable = lib.mkEnableOption "mpd-discord-presence (systemd user service)";
|
||||||
|
|
||||||
|
package = lib.mkOption {
|
||||||
|
type = lib.types.package;
|
||||||
|
default = pkgs.mpd-discord-presence;
|
||||||
|
description = "Package providing the mpd-discord-presence binary.";
|
||||||
|
};
|
||||||
|
|
||||||
|
extraArgs = lib.mkOption {
|
||||||
|
type = lib.types.listOf lib.types.str;
|
||||||
|
default = [];
|
||||||
|
description = "Extra CLI args passed to mpd-discord-presence.";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = lib.mkIf cfg.enable {
|
||||||
|
home.packages = [ cfg.package ];
|
||||||
|
|
||||||
|
systemd.user.services.mpd-discord-presence = {
|
||||||
|
Unit = {
|
||||||
|
Description = "MPD Discord Presence";
|
||||||
|
Wants = [ "mpd.service" ];
|
||||||
|
After = [ "mpd.service" "network-online.target" ];
|
||||||
|
};
|
||||||
|
|
||||||
|
Service = {
|
||||||
|
ExecStart = "${cfg.package}/bin/mpd-discord-presence ${lib.escapeShellArgs cfg.extraArgs}";
|
||||||
|
Restart = "on-failure";
|
||||||
|
RestartSec = 2;
|
||||||
|
};
|
||||||
|
|
||||||
|
Install = {
|
||||||
|
WantedBy = [ "default.target" ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
}
|
}
|
||||||
// flake-utils.lib.eachDefaultSystem (
|
// flake-utils.lib.eachDefaultSystem (system:
|
||||||
system:
|
|
||||||
let
|
let
|
||||||
pkgs = import nixpkgs {
|
pkgs = import nixpkgs {
|
||||||
inherit system;
|
inherit system;
|
||||||
@@ -52,6 +102,11 @@
|
|||||||
};
|
};
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
|
packages = {
|
||||||
|
mpd-discord-presence = pkgs.mpd-discord-presence;
|
||||||
|
default = pkgs.mpd-discord-presence;
|
||||||
|
};
|
||||||
|
|
||||||
devShells.default = pkgs.mkShell {
|
devShells.default = pkgs.mkShell {
|
||||||
packages = with pkgs; [
|
packages = with pkgs; [
|
||||||
rustToolchain
|
rustToolchain
|
||||||
@@ -67,27 +122,5 @@
|
|||||||
export RUST_SRC_PATH="${pkgs.rustToolchain}/lib/rustlib/src/rust/library"
|
export RUST_SRC_PATH="${pkgs.rustToolchain}/lib/rustlib/src/rust/library"
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
});
|
||||||
packages = rec {
|
|
||||||
mpd-discord-presence = pkgs.rustPlatform.buildRustPackage {
|
|
||||||
pname = "mpd-discord-presence";
|
|
||||||
version = "0.1.0";
|
|
||||||
|
|
||||||
src = ./.;
|
|
||||||
|
|
||||||
cargoLock.lockFile = ./Cargo.lock;
|
|
||||||
|
|
||||||
enableParallelBuild = true;
|
|
||||||
|
|
||||||
meta = {
|
|
||||||
description = "MPD Discord daemon";
|
|
||||||
homepage = "https://git.slendi.dev/Slendi/mpd-discord-presence";
|
|
||||||
license = pkgs.lib.licenses.gpl3;
|
|
||||||
mainProgrma = "mpd-discord-presence";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
default = mpd-discord-presence;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,45 +0,0 @@
|
|||||||
{ config, lib, pkgs, self, ... }:
|
|
||||||
let
|
|
||||||
cfg = config.services.mpd-discord-presence;
|
|
||||||
defaultPkg =
|
|
||||||
self.packages.${pkgs.stdenv.hostPlatform.system}.mpd-discord-presence;
|
|
||||||
in
|
|
||||||
{
|
|
||||||
options.services.mpd-discord-presence = {
|
|
||||||
enable = lib.mkEnableOption "mpd-discord-presence (systemd user service)";
|
|
||||||
|
|
||||||
package = lib.mkOption {
|
|
||||||
type = lib.types.package;
|
|
||||||
default = defaultPkg;
|
|
||||||
description = "Package providing the mpd-discord-presence binary.";
|
|
||||||
};
|
|
||||||
|
|
||||||
extraArgs = lib.mkOption {
|
|
||||||
type = lib.types.listOf lib.types.str;
|
|
||||||
default = [];
|
|
||||||
description = "Extra CLI args passed to mpd-discord-presence.";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
config = lib.mkIf cfg.enable {
|
|
||||||
home.packages = [ cfg.package ];
|
|
||||||
|
|
||||||
systemd.user.services.mpd-discord-presence = {
|
|
||||||
Unit = {
|
|
||||||
Description = "MPD Discord Presence";
|
|
||||||
Wants = [ "mpd.service" ];
|
|
||||||
After = [ "mpd.service" "network-online.target" ];
|
|
||||||
};
|
|
||||||
|
|
||||||
Service = {
|
|
||||||
ExecStart = "${cfg.package}/bin/mpd-discord-presence ${lib.escapeShellArgs cfg.extraArgs}";
|
|
||||||
Restart = "on-failure";
|
|
||||||
RestartSec = 2;
|
|
||||||
};
|
|
||||||
|
|
||||||
Install = {
|
|
||||||
WantedBy = [ "default.target" ];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user