2024-09-28 20:39:57 +00:00
|
|
|
{
|
|
|
|
pkgs,
|
|
|
|
config,
|
|
|
|
lib,
|
|
|
|
...
|
|
|
|
}:
|
|
|
|
let
|
|
|
|
cfg = config.aux.system.services.languagetool;
|
|
|
|
in
|
|
|
|
{
|
|
|
|
options = {
|
|
|
|
aux.system.services.languagetool = {
|
|
|
|
enable = lib.mkEnableOption (lib.mdDoc "Enables LanguageTool server.");
|
|
|
|
auth = {
|
|
|
|
password = lib.mkOption {
|
|
|
|
default = "";
|
|
|
|
type = lib.types.str;
|
|
|
|
description = "The password to use for basic authentication for LanguageTool.";
|
|
|
|
example = "MySuperSecurePassword123";
|
|
|
|
};
|
|
|
|
user = lib.mkOption {
|
|
|
|
default = "ltuser";
|
|
|
|
type = lib.types.str;
|
|
|
|
description = "The username to use for basic auth.";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
ngrams.enable = lib.mkEnableOption (
|
|
|
|
lib.mdDoc "Enables n-gram data set. See https://dev.languagetool.org/finding-errors-using-n-gram-data.html"
|
|
|
|
);
|
|
|
|
port = lib.mkOption {
|
|
|
|
default = 8080;
|
|
|
|
type = lib.types.int;
|
|
|
|
description = "The port to run LanguageTool on.";
|
|
|
|
example = 8080;
|
|
|
|
};
|
|
|
|
url = lib.mkOption {
|
|
|
|
default = "";
|
|
|
|
type = lib.types.str;
|
|
|
|
description = "The complete URL where LanguageTool is hosted.";
|
|
|
|
example = "https://languagetool.example.com";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
|
|
services = {
|
|
|
|
languagetool = lib.mkIf cfg.enable {
|
|
|
|
enable = true;
|
2024-09-28 21:15:39 +00:00
|
|
|
port = cfg.port;
|
2024-09-28 20:39:57 +00:00
|
|
|
public = true;
|
|
|
|
allowOrigin = "*";
|
|
|
|
# Enable Ngrams
|
|
|
|
settings.languageModel = lib.mkIf cfg.ngrams.enable "${
|
|
|
|
(pkgs.callPackage ../../packages/languagetool-ngrams.nix { inherit pkgs lib; })
|
2024-09-28 21:15:39 +00:00
|
|
|
}/share/languagetool/ngrams";
|
2024-09-28 20:39:57 +00:00
|
|
|
};
|
|
|
|
# Create Nginx virtualhost
|
|
|
|
nginx.virtualHosts."${cfg.url}" = {
|
|
|
|
useACMEHost = pkgs.util.getDomainFromURL cfg.url;
|
|
|
|
forceSSL = true;
|
|
|
|
basicAuth = {
|
|
|
|
"${cfg.auth.user}" = cfg.auth.password;
|
|
|
|
};
|
|
|
|
locations."/" = {
|
2024-09-28 21:15:39 +00:00
|
|
|
proxyPass = "http://127.0.0.1:${builtins.toString cfg.port}";
|
2024-09-28 20:39:57 +00:00
|
|
|
extraConfig = "proxy_ssl_server_name on;";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
systemd.services.nginx.wants = [ config.systemd.services.languagetool.name ];
|
|
|
|
};
|
|
|
|
}
|