1
0
Fork 0
mirror of https://github.com/nix-community/home-manager.git synced 2024-12-14 11:57:55 +00:00
home-manager/modules/services/pbgopy.nix

74 lines
1.7 KiB
Nix
Raw Normal View History

2020-12-03 02:55:37 +00:00
{ config, lib, pkgs, ... }:
with lib;
let
2021-04-22 21:46:05 +00:00
2020-12-03 02:55:37 +00:00
cfg = config.services.pbgopy;
package = pkgs.pbgopy;
2021-04-22 21:46:05 +00:00
commandLine = concatStringsSep " " ([
"${package}/bin/pbgopy serve"
"--port ${toString cfg.port}"
"--ttl ${cfg.cache.ttl}"
] ++ optional (cfg.httpAuth != null)
"--basic-auth ${escapeShellArg cfg.httpAuth}");
2020-12-03 02:55:37 +00:00
in {
meta.maintainers = [ maintainers.ivar ];
options.services.pbgopy = {
enable = mkEnableOption (lib.mdDoc "pbgopy");
2020-12-03 02:55:37 +00:00
2021-04-22 21:46:05 +00:00
port = mkOption {
type = types.port;
default = 9090;
example = 8080;
description = lib.mdDoc ''
2021-04-22 21:46:05 +00:00
The port to host the pbgopy server on.
'';
};
2020-12-03 02:55:37 +00:00
cache.ttl = mkOption {
type = types.str;
default = "24h";
example = "10m";
description = lib.mdDoc ''
The TTL for the cache. Use `"0s"` to disable it.
2020-12-03 02:55:37 +00:00
'';
};
2021-04-22 21:46:05 +00:00
httpAuth = mkOption {
type = types.nullOr types.str;
default = null;
example = "user:pass";
description = lib.mdDoc ''
2021-04-22 21:46:05 +00:00
Basic HTTP authentication's username and password. Both the username and
password are escaped.
'';
};
2020-12-03 02:55:37 +00:00
};
config = mkIf cfg.enable {
assertions = [
(lib.hm.assertions.assertPlatform "services.pbgopy" pkgs
lib.platforms.linux)
];
2020-12-03 02:55:37 +00:00
home.packages = [ package ];
systemd.user.services.pbgopy = {
Unit = {
Description = "pbgopy server for sharing the clipboard between devices";
After = [ "graphical-session-pre.target" ];
PartOf = [ "graphical-session.target" ];
};
Service = {
2021-04-22 21:46:05 +00:00
ExecStart = commandLine;
2020-12-03 02:55:37 +00:00
Restart = "on-abort";
};
Install = { WantedBy = [ "graphical-session.target" ]; };
};
};
}