mirror of
https://github.com/nix-community/home-manager
synced 2024-11-30 06:59:45 +01:00
redshift/gammastep: use ini file
Not every option is exposed by redshift/gammastep parameters, for example gamma options are only exposed in configuration file. So this PR refactors this module to generate a configuration file and pass it to the redshift/gammastep using -c parameter. This is a breaking change since there is no support for some of the older options like `extraOptions`, but unless you use `extraOptions` it should work without changes.
This commit is contained in:
parent
ef4370bedc
commit
d8dd2a09b0
10 changed files with 177 additions and 64 deletions
|
@ -72,6 +72,35 @@ programs.rofi.extraConfig = {
|
||||||
};
|
};
|
||||||
----
|
----
|
||||||
|
|
||||||
|
* The `services.redshift.extraOptions` and `services.gammastep.extraOptions`
|
||||||
|
options were removed in favor of <<opt-services.redshift.settings>> and
|
||||||
|
`services.gammastep.settings`, that are now an attribute set rather
|
||||||
|
than a string. They also support new features not available before, for
|
||||||
|
example:
|
||||||
|
+
|
||||||
|
[source,nix]
|
||||||
|
----
|
||||||
|
services.redshift = {
|
||||||
|
dawnTime = "6:00-7:45";
|
||||||
|
duskTime = "18:35-20:15";
|
||||||
|
settings = {
|
||||||
|
redshift = {
|
||||||
|
gamma = 0.8;
|
||||||
|
adjustment-method = "randr";
|
||||||
|
};
|
||||||
|
|
||||||
|
randr = {
|
||||||
|
screen = 0;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
----
|
||||||
|
+
|
||||||
|
It is recommended to check either
|
||||||
|
https://github.com/jonls/redshift/blob/master/redshift.conf.sample[redshift.conf.sample] or
|
||||||
|
https://gitlab.com/chinstrap/gammastep/-/blob/master/gammastep.conf.sample[gammastep.conf.sample]
|
||||||
|
for the available additional options in each program.
|
||||||
|
|
||||||
[[sec-release-21.05-state-version-changes]]
|
[[sec-release-21.05-state-version-changes]]
|
||||||
=== State Version Changes
|
=== State Version Changes
|
||||||
|
|
||||||
|
|
|
@ -4,14 +4,17 @@ with lib;
|
||||||
|
|
||||||
let
|
let
|
||||||
commonOptions = import ./lib/options.nix {
|
commonOptions = import ./lib/options.nix {
|
||||||
inherit config lib;
|
inherit config lib pkgs;
|
||||||
|
|
||||||
moduleName = "gammastep";
|
moduleName = "gammastep";
|
||||||
programName = "Gammastep";
|
programName = "Gammastep";
|
||||||
|
# https://gitlab.com/chinstrap/gammastep/-/commit/1608ed61154cc652b087e85c4ce6125643e76e2f
|
||||||
|
mainSection = "general";
|
||||||
defaultPackage = pkgs.gammastep;
|
defaultPackage = pkgs.gammastep;
|
||||||
examplePackage = "pkgs.gammastep";
|
examplePackage = "pkgs.gammastep";
|
||||||
mainExecutable = "gammastep";
|
mainExecutable = "gammastep";
|
||||||
appletExecutable = "gammastep-indicator";
|
appletExecutable = "gammastep-indicator";
|
||||||
|
xdgConfigFilePath = "gammastep/config.ini";
|
||||||
serviceDocumentation = "https://gitlab.com/chinstrap/gammastep/";
|
serviceDocumentation = "https://gitlab.com/chinstrap/gammastep/";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -1,32 +1,60 @@
|
||||||
# Adapted from Nixpkgs.
|
{ config, lib, pkgs, moduleName, mainSection, programName, defaultPackage
|
||||||
|
, examplePackage, mainExecutable, appletExecutable, xdgConfigFilePath
|
||||||
{ config, lib, moduleName, programName, defaultPackage, examplePackage
|
, serviceDocumentation }:
|
||||||
, mainExecutable, appletExecutable, serviceDocumentation }:
|
|
||||||
|
|
||||||
with lib;
|
with lib;
|
||||||
|
|
||||||
let
|
let
|
||||||
|
|
||||||
cfg = config.services.${moduleName};
|
cfg = config.services.${moduleName};
|
||||||
|
settingsFormat = pkgs.formats.ini { };
|
||||||
|
|
||||||
in {
|
in {
|
||||||
meta = {
|
meta = {
|
||||||
maintainers = with maintainers; [ rycee petabyteboy thiagokokada ];
|
maintainers = with maintainers; [ rycee petabyteboy thiagokokada ];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
imports = let
|
||||||
|
mkRenamed = old: new:
|
||||||
|
mkRenamedOptionModule ([ "services" moduleName ] ++ old) [
|
||||||
|
"services"
|
||||||
|
moduleName
|
||||||
|
"settings"
|
||||||
|
mainSection
|
||||||
|
new
|
||||||
|
];
|
||||||
|
in [
|
||||||
|
(mkRemovedOptionModule [ "services" moduleName "extraOptions" ]
|
||||||
|
"All ${programName} configuration is now available through services.${moduleName}.settings instead.")
|
||||||
|
(mkRenamed [ "brightness" "day" ] "brightness-day")
|
||||||
|
(mkRenamed [ "brightness" "night" ] "brightness-night")
|
||||||
|
];
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
enable = mkOption {
|
enable = mkEnableOption programName;
|
||||||
type = types.bool;
|
|
||||||
default = false;
|
dawnTime = mkOption {
|
||||||
example = true;
|
type = types.nullOr types.str;
|
||||||
|
default = null;
|
||||||
|
example = "6:00-7:45";
|
||||||
description = ''
|
description = ''
|
||||||
Enable ${programName} to change your screen's colour temperature
|
Set the time interval of dawn manually.
|
||||||
depending on the time of day.
|
The times must be specified as HH:MM in 24-hour format.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
duskTime = mkOption {
|
||||||
|
type = types.nullOr types.str;
|
||||||
|
default = null;
|
||||||
|
example = "18:35-20:15";
|
||||||
|
description = ''
|
||||||
|
Set the time interval of dusk manually.
|
||||||
|
The times must be specified as HH:MM in 24-hour format.
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
latitude = mkOption {
|
latitude = mkOption {
|
||||||
type = types.nullOr types.str;
|
type = with types; nullOr (either str float);
|
||||||
default = null;
|
default = null;
|
||||||
description = ''
|
description = ''
|
||||||
Your current latitude, between <literal>-90.0</literal> and
|
Your current latitude, between <literal>-90.0</literal> and
|
||||||
|
@ -36,7 +64,7 @@ in {
|
||||||
};
|
};
|
||||||
|
|
||||||
longitude = mkOption {
|
longitude = mkOption {
|
||||||
type = types.nullOr types.str;
|
type = with types; nullOr (either str float);
|
||||||
default = null;
|
default = null;
|
||||||
description = ''
|
description = ''
|
||||||
Your current longitude, between <literal>-180.0</literal> and
|
Your current longitude, between <literal>-180.0</literal> and
|
||||||
|
@ -75,26 +103,6 @@ in {
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
brightness = {
|
|
||||||
day = mkOption {
|
|
||||||
type = types.str;
|
|
||||||
default = "1";
|
|
||||||
description = ''
|
|
||||||
Screen brightness to apply during the day,
|
|
||||||
between <literal>0.1</literal> and <literal>1.0</literal>.
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
|
|
||||||
night = mkOption {
|
|
||||||
type = types.str;
|
|
||||||
default = "1";
|
|
||||||
description = ''
|
|
||||||
Screen brightness to apply during the night,
|
|
||||||
between <literal>0.1</literal> and <literal>1.0</literal>.
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
package = mkOption {
|
package = mkOption {
|
||||||
type = types.package;
|
type = types.package;
|
||||||
default = defaultPackage;
|
default = defaultPackage;
|
||||||
|
@ -113,26 +121,63 @@ in {
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
extraOptions = mkOption {
|
settings = mkOption {
|
||||||
type = types.listOf types.str;
|
type = types.submodule { freeformType = settingsFormat.type; };
|
||||||
default = [ ];
|
default = { };
|
||||||
example = [ "-v" "-m randr" ];
|
example = literalExample ''
|
||||||
|
{
|
||||||
|
${mainSection} = {
|
||||||
|
adjustment-method = "randr";
|
||||||
|
};
|
||||||
|
randr = {
|
||||||
|
screen = 0;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
'';
|
||||||
description = ''
|
description = ''
|
||||||
Additional command-line arguments to pass to
|
The configuration to pass to ${programName}.
|
||||||
<command>redshift</command>.
|
Available options for ${programName} described in
|
||||||
|
<citerefentry>
|
||||||
|
<refentrytitle>${moduleName}</refentrytitle>
|
||||||
|
<manvolnum>1</manvolnum>
|
||||||
|
</citerefentry>.
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
config = {
|
config = {
|
||||||
assertions = [{
|
assertions = [{
|
||||||
assertion = cfg.provider == "manual" -> cfg.latitude != null
|
assertion = (cfg.settings ? ${mainSection}.dawn-time || cfg.settings
|
||||||
&& cfg.longitude != null;
|
? ${mainSection}.dusk-time)
|
||||||
message = "Must provide services.${moduleName}.latitude and"
|
|| (cfg.settings.${mainSection}.location-provider) == "geoclue2"
|
||||||
+ " services.${moduleName}.latitude when"
|
|| ((cfg.settings.${mainSection}.location-provider) == "manual"
|
||||||
+ " services.${moduleName}.provider is set to \"manual\".";
|
&& (cfg.settings ? manual.lat || cfg.settings ? manual.lon));
|
||||||
|
message = ''
|
||||||
|
In order for ${programName} to know the time of action, you need to set one of
|
||||||
|
- services.${moduleName}.provider = "geoclue2" for automatically inferring your location
|
||||||
|
(you also need to enable Geoclue2 service separately)
|
||||||
|
- services.${moduleName}.longitude and .latitude for specifying your location manually
|
||||||
|
- services.${moduleName}.dawnTime and .duskTime for specifying the times manually
|
||||||
|
'';
|
||||||
}];
|
}];
|
||||||
|
|
||||||
|
services.${moduleName}.settings = {
|
||||||
|
${mainSection} = {
|
||||||
|
temp-day = cfg.temperature.day;
|
||||||
|
temp-night = cfg.temperature.night;
|
||||||
|
location-provider = cfg.provider;
|
||||||
|
dawn-time = mkIf (cfg.dawnTime != null) cfg.dawnTime;
|
||||||
|
dusk-time = mkIf (cfg.duskTime != null) cfg.duskTime;
|
||||||
|
};
|
||||||
|
manual = mkIf (cfg.provider == "manual") {
|
||||||
|
lat = mkIf (cfg.latitude != null) (toString cfg.latitude);
|
||||||
|
lon = mkIf (cfg.longitude != null) (toString cfg.longitude);
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
xdg.configFile.${xdgConfigFilePath}.source =
|
||||||
|
settingsFormat.generate xdgConfigFilePath cfg.settings;
|
||||||
|
|
||||||
systemd.user.services.${moduleName} = {
|
systemd.user.services.${moduleName} = {
|
||||||
Unit = {
|
Unit = {
|
||||||
Description = "${programName} colour temperature adjuster";
|
Description = "${programName} colour temperature adjuster";
|
||||||
|
@ -145,21 +190,9 @@ in {
|
||||||
|
|
||||||
Service = {
|
Service = {
|
||||||
ExecStart = let
|
ExecStart = let
|
||||||
providerString = if cfg.provider == "manual" then
|
|
||||||
"${cfg.latitude}:${cfg.longitude}"
|
|
||||||
else
|
|
||||||
cfg.provider;
|
|
||||||
|
|
||||||
args = [
|
|
||||||
"-l ${providerString}"
|
|
||||||
"-t ${toString cfg.temperature.day}:${
|
|
||||||
toString cfg.temperature.night
|
|
||||||
}"
|
|
||||||
"-b ${toString cfg.brightness.day}:${toString cfg.brightness.night}"
|
|
||||||
] ++ cfg.extraOptions;
|
|
||||||
|
|
||||||
command = if cfg.tray then appletExecutable else mainExecutable;
|
command = if cfg.tray then appletExecutable else mainExecutable;
|
||||||
in "${cfg.package}/bin/${command} ${concatStringsSep " " args}";
|
configFullPath = config.xdg.configHome + "/${xdgConfigFilePath}";
|
||||||
|
in "${cfg.package}/bin/${command} -v -c ${configFullPath}";
|
||||||
RestartSec = 3;
|
RestartSec = 3;
|
||||||
Restart = "on-failure";
|
Restart = "on-failure";
|
||||||
};
|
};
|
||||||
|
|
|
@ -4,14 +4,16 @@ with lib;
|
||||||
|
|
||||||
let
|
let
|
||||||
commonOptions = import ./lib/options.nix {
|
commonOptions = import ./lib/options.nix {
|
||||||
inherit config lib;
|
inherit config lib pkgs;
|
||||||
|
|
||||||
moduleName = "redshift";
|
moduleName = "redshift";
|
||||||
programName = "Redshift";
|
programName = "Redshift";
|
||||||
|
mainSection = "redshift";
|
||||||
defaultPackage = pkgs.redshift;
|
defaultPackage = pkgs.redshift;
|
||||||
examplePackage = "pkgs.redshift";
|
examplePackage = "pkgs.redshift";
|
||||||
mainExecutable = "redshift";
|
mainExecutable = "redshift";
|
||||||
appletExecutable = "redshift-gtk";
|
appletExecutable = "redshift-gtk";
|
||||||
|
xdgConfigFilePath = "redshift/redshift.conf";
|
||||||
serviceDocumentation = "http://jonls.dk/redshift/";
|
serviceDocumentation = "http://jonls.dk/redshift/";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
WantedBy=graphical-session.target
|
WantedBy=graphical-session.target
|
||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
ExecStart=@gammastep@/bin/gammastep -l 0.0:0.0 -t 5500:3700 -b 1:1
|
ExecStart=@gammastep@/bin/gammastep -v -c /home/hm-user/.config/gammastep/config.ini
|
||||||
Restart=on-failure
|
Restart=on-failure
|
||||||
RestartSec=3
|
RestartSec=3
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,13 @@
|
||||||
|
[general]
|
||||||
|
adjustment-method=randr
|
||||||
|
dawn-time=6:00-7:45
|
||||||
|
dusk-time=18:35-20:15
|
||||||
|
gamma=0.800000
|
||||||
|
location-provider=manual
|
||||||
|
temp-day=5500
|
||||||
|
temp-night=3700
|
||||||
|
|
||||||
|
[manual]
|
||||||
|
|
||||||
|
[randr]
|
||||||
|
screen=0
|
|
@ -5,8 +5,15 @@
|
||||||
services.gammastep = {
|
services.gammastep = {
|
||||||
enable = true;
|
enable = true;
|
||||||
provider = "manual";
|
provider = "manual";
|
||||||
latitude = "0.0";
|
dawnTime = "6:00-7:45";
|
||||||
longitude = "0.0";
|
duskTime = "18:35-20:15";
|
||||||
|
settings = {
|
||||||
|
general = {
|
||||||
|
adjustment-method = "randr";
|
||||||
|
gamma = 0.8;
|
||||||
|
};
|
||||||
|
randr = { screen = 0; };
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
nixpkgs.overlays = [
|
nixpkgs.overlays = [
|
||||||
|
@ -18,6 +25,9 @@
|
||||||
];
|
];
|
||||||
|
|
||||||
nmt.script = ''
|
nmt.script = ''
|
||||||
|
assertFileContent \
|
||||||
|
home-files/.config/gammastep/config.ini \
|
||||||
|
${./gammastep-basic-configuration-file-expected.conf}
|
||||||
assertFileContent \
|
assertFileContent \
|
||||||
home-files/.config/systemd/user/gammastep.service \
|
home-files/.config/systemd/user/gammastep.service \
|
||||||
${./gammastep-basic-configuration-expected.service}
|
${./gammastep-basic-configuration-expected.service}
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
WantedBy=graphical-session.target
|
WantedBy=graphical-session.target
|
||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
ExecStart=@redshift@/bin/redshift -l 0.0:0.0 -t 5500:3700 -b 1:1
|
ExecStart=@redshift@/bin/redshift -v -c /home/hm-user/.config/redshift/redshift.conf
|
||||||
Restart=on-failure
|
Restart=on-failure
|
||||||
RestartSec=3
|
RestartSec=3
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,13 @@
|
||||||
|
[manual]
|
||||||
|
lat=0.000000
|
||||||
|
lon=0.0
|
||||||
|
|
||||||
|
[randr]
|
||||||
|
screen=0
|
||||||
|
|
||||||
|
[redshift]
|
||||||
|
adjustment-method=randr
|
||||||
|
gamma=0.800000
|
||||||
|
location-provider=manual
|
||||||
|
temp-day=5500
|
||||||
|
temp-night=3700
|
|
@ -5,8 +5,15 @@
|
||||||
services.redshift = {
|
services.redshift = {
|
||||||
enable = true;
|
enable = true;
|
||||||
provider = "manual";
|
provider = "manual";
|
||||||
latitude = "0.0";
|
latitude = 0.0;
|
||||||
longitude = "0.0";
|
longitude = "0.0";
|
||||||
|
settings = {
|
||||||
|
redshift = {
|
||||||
|
adjustment-method = "randr";
|
||||||
|
gamma = 0.8;
|
||||||
|
};
|
||||||
|
randr = { screen = 0; };
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
nixpkgs.overlays = [
|
nixpkgs.overlays = [
|
||||||
|
@ -18,6 +25,9 @@
|
||||||
];
|
];
|
||||||
|
|
||||||
nmt.script = ''
|
nmt.script = ''
|
||||||
|
assertFileContent \
|
||||||
|
home-files/.config/redshift/redshift.conf \
|
||||||
|
${./redshift-basic-configuration-file-expected.conf}
|
||||||
assertFileContent \
|
assertFileContent \
|
||||||
home-files/.config/systemd/user/redshift.service \
|
home-files/.config/systemd/user/redshift.service \
|
||||||
${./redshift-basic-configuration-expected.service}
|
${./redshift-basic-configuration-expected.service}
|
||||||
|
|
Loading…
Reference in a new issue