mirror of
https://github.com/nmasur/dotfiles
synced 2024-11-23 04:35:38 +00:00
64 lines
1.7 KiB
Nix
64 lines
1.7 KiB
Nix
{ config, pkgs, lib, ... }: {
|
|
|
|
options = {
|
|
bookServer = lib.mkOption {
|
|
type = lib.types.nullOr lib.types.str;
|
|
description = "Hostname for Calibre library";
|
|
default = null;
|
|
};
|
|
};
|
|
|
|
config = lib.mkIf (config.bookServer != null) {
|
|
|
|
services.calibre-web = {
|
|
enable = true;
|
|
openFirewall = true;
|
|
options = {
|
|
reverseProxyAuth.enable = false;
|
|
enableBookConversion = true;
|
|
enableBookUploading = true;
|
|
};
|
|
};
|
|
|
|
caddy.routes = [{
|
|
match = [{ host = [ config.bookServer ]; }];
|
|
handle = [{
|
|
handler = "reverse_proxy";
|
|
upstreams = [{ dial = "localhost:8083"; }];
|
|
headers.request.add."X-Script-Name" = [ "/calibre-web" ];
|
|
}];
|
|
}];
|
|
|
|
# Run a backup on a schedule
|
|
systemd.timers.calibre-backup = {
|
|
timerConfig = {
|
|
OnCalendar = "*-*-* 00:00:00"; # Once per day
|
|
Unit = "calibre-backup.service";
|
|
};
|
|
wantedBy = [ "timers.target" ];
|
|
};
|
|
|
|
# Backup Calibre data to object storage
|
|
systemd.services.calibre-backup =
|
|
let libraryPath = "/var/lib/calibre-web"; # Default location
|
|
in {
|
|
description = "Backup Calibre data";
|
|
environment.AWS_ACCESS_KEY_ID = config.backup.s3.accessKeyId;
|
|
serviceConfig = {
|
|
Type = "oneshot";
|
|
User = "calibre-web";
|
|
Group = "backup";
|
|
EnvironmentFile = config.secrets.backup.dest;
|
|
};
|
|
script = ''
|
|
${pkgs.awscli2}/bin/aws s3 sync \
|
|
${libraryPath}/ \
|
|
s3://${config.backup.s3.bucket}/calibre/ \
|
|
--endpoint-url=https://${config.backup.s3.endpoint}
|
|
'';
|
|
};
|
|
|
|
};
|
|
|
|
}
|