diff --git a/nixos/doc/manual/release-notes/rl-2009.xml b/nixos/doc/manual/release-notes/rl-2009.xml
index a0a0b2cb40e4..d830d5eff035 100644
--- a/nixos/doc/manual/release-notes/rl-2009.xml
+++ b/nixos/doc/manual/release-notes/rl-2009.xml
@@ -495,6 +495,16 @@ systemd.services.nginx.serviceConfig.ReadWritePaths = [ "/var/www" ];
In the resilio module, has been changed to listen to [::1] instead of 0.0.0.0.
+
+
+ Radicale's default package has changed from 2.x to 3.x. An upgrade
+ checklist can be found
+ here.
+ You can use the newer version in the NixOS service by setting the
+ package to radicale3, which is done
+ automatically if stateVersion is 20.09 or higher.
+
+
diff --git a/nixos/modules/services/networking/radicale.nix b/nixos/modules/services/networking/radicale.nix
index 30bf22586f86..5af035fd59e0 100644
--- a/nixos/modules/services/networking/radicale.nix
+++ b/nixos/modules/services/networking/radicale.nix
@@ -8,8 +8,10 @@ let
confFile = pkgs.writeText "radicale.conf" cfg.config;
- # This enables us to default to version 2 while still not breaking configurations of people with version 1
- defaultPackage = if versionAtLeast config.system.stateVersion "17.09" then {
+ defaultPackage = if versionAtLeast config.system.stateVersion "20.09" then {
+ pkg = pkgs.radicale3;
+ text = "pkgs.radicale3";
+ } else if versionAtLeast config.system.stateVersion "17.09" then {
pkg = pkgs.radicale2;
text = "pkgs.radicale2";
} else {
@@ -35,8 +37,9 @@ in
defaultText = defaultPackage.text;
description = ''
Radicale package to use. This defaults to version 1.x if
- system.stateVersion < 17.09 and version 2.x
- otherwise.
+ system.stateVersion < 17.09, version 2.x if
+ 17.09 ≤ system.stateVersion < 20.09, and
+ version 3.x otherwise.
'';
};
diff --git a/nixos/tests/radicale.nix b/nixos/tests/radicale.nix
index c81e78a8f994..1d3679c82a20 100644
--- a/nixos/tests/radicale.nix
+++ b/nixos/tests/radicale.nix
@@ -14,9 +14,6 @@ let
[storage]
filesystem_folder = /tmp/collections
-
- [logging]
- debug = True
'';
};
# WARNING: DON'T DO THIS IN PRODUCTION!
@@ -49,13 +46,18 @@ in
services.radicale.extraArgs = [
"--export-storage" "/tmp/collections-new"
];
+ system.stateVersion = "17.03";
};
radicale2_verify = lib.recursiveUpdate radicale2 {
- services.radicale.extraArgs = [ "--verify-storage" ];
+ services.radicale.extraArgs = [ "--debug" "--verify-storage" ];
+ system.stateVersion = "17.09";
};
radicale2 = lib.recursiveUpdate (common args) {
system.stateVersion = "17.09";
};
+ radicale3 = lib.recursiveUpdate (common args) {
+ system.stateVersion = "20.09";
+ };
};
# This tests whether the web interface is accessible to an authenticated user
@@ -117,6 +119,22 @@ in
retcode == 0 and "VCALENDAR" in output
), "Could not read calendar from Radicale 2"
- radicale.succeed("curl --fail http://${user}:${password}@localhost:${port}/.web/")
+ radicale.succeed("curl --fail http://${user}:${password}@localhost:${port}/.web/")
+
+ with subtest("Check Radicale 3 functionality"):
+ radicale.succeed(
+ "${switchToConfig "radicale3"} >&2"
+ )
+ radicale.wait_for_unit("radicale.service")
+ radicale.wait_for_open_port(${port})
+
+ (retcode, output) = radicale.execute(
+ "curl --fail http://${user}:${password}@localhost:${port}/someuser/calendar.ics/"
+ )
+ assert (
+ retcode == 0 and "VCALENDAR" in output
+ ), "Could not read calendar from Radicale 3"
+
+ radicale.succeed("curl --fail http://${user}:${password}@localhost:${port}/.web/")
'';
})