80 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
		
		
			
		
	
	
			80 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
| 
								 | 
							
								{ config, lib, pkgs, ... }:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								with lib;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								let
							 | 
						||
| 
								 | 
							
								  cfg = config.services.ankisyncd;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  name = "ankisyncd";
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  stateDir = "/var/lib/${name}";
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  authDbPath = "${stateDir}/auth.db";
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  sessionDbPath = "${stateDir}/session.db";
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  configFile = pkgs.writeText "ankisyncd.conf" (lib.generators.toINI {} {
							 | 
						||
| 
								 | 
							
								    sync_app = {
							 | 
						||
| 
								 | 
							
								      host = cfg.host;
							 | 
						||
| 
								 | 
							
								      port = cfg.port;
							 | 
						||
| 
								 | 
							
								      data_root = stateDir;
							 | 
						||
| 
								 | 
							
								      auth_db_path = authDbPath;
							 | 
						||
| 
								 | 
							
								      session_db_path = sessionDbPath;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      base_url = "/sync/";
							 | 
						||
| 
								 | 
							
								      base_media_url = "/msync/";
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								  });
							 | 
						||
| 
								 | 
							
								in
							 | 
						||
| 
								 | 
							
								  {
							 | 
						||
| 
								 | 
							
								    options.services.ankisyncd = {
							 | 
						||
| 
								 | 
							
								      enable = mkEnableOption "ankisyncd";
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      package = mkOption {
							 | 
						||
| 
								 | 
							
								        type = types.package;
							 | 
						||
| 
								 | 
							
								        default = pkgs.ankisyncd;
							 | 
						||
| 
								 | 
							
								        defaultText = literalExample "pkgs.ankisyncd";
							 | 
						||
| 
								 | 
							
								        description = "The package to use for the ankisyncd command.";
							 | 
						||
| 
								 | 
							
								      };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      host = mkOption {
							 | 
						||
| 
								 | 
							
								        type = types.str;
							 | 
						||
| 
								 | 
							
								        default = "localhost";
							 | 
						||
| 
								 | 
							
								        description = "ankisyncd host";
							 | 
						||
| 
								 | 
							
								      };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      port = mkOption {
							 | 
						||
| 
								 | 
							
								        type = types.int;
							 | 
						||
| 
								 | 
							
								        default = 27701;
							 | 
						||
| 
								 | 
							
								        description = "ankisyncd port";
							 | 
						||
| 
								 | 
							
								      };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      openFirewall = mkOption {
							 | 
						||
| 
								 | 
							
								        default = false;
							 | 
						||
| 
								 | 
							
								        type = types.bool;
							 | 
						||
| 
								 | 
							
								        description = "Whether to open the firewall for the specified port.";
							 | 
						||
| 
								 | 
							
								      };
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    config = mkIf cfg.enable {
							 | 
						||
| 
								 | 
							
								      networking.firewall.allowedTCPPorts = mkIf cfg.openFirewall [ cfg.port ];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      environment.etc."ankisyncd/ankisyncd.conf".source = configFile;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								      systemd.services.ankisyncd = {
							 | 
						||
| 
								 | 
							
								        description = "ankisyncd - Anki sync server";
							 | 
						||
| 
								 | 
							
								        after = [ "network.target" ];
							 | 
						||
| 
								 | 
							
								        wantedBy = [ "multi-user.target" ];
							 | 
						||
| 
								 | 
							
								        path = [ cfg.package ];
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        serviceConfig = {
							 | 
						||
| 
								 | 
							
								          Type = "simple";
							 | 
						||
| 
								 | 
							
								          DynamicUser = true;
							 | 
						||
| 
								 | 
							
								          StateDirectory = name;
							 | 
						||
| 
								 | 
							
								          ExecStart = "${cfg.package}/bin/ankisyncd";
							 | 
						||
| 
								 | 
							
								          Restart = "always";
							 | 
						||
| 
								 | 
							
								        };
							 | 
						||
| 
								 | 
							
								      };
							 | 
						||
| 
								 | 
							
								    };
							 | 
						||
| 
								 | 
							
								  }
							 |