aboutsummaryrefslogtreecommitdiff
path: root/modules/services/misskey/default.nix
diff options
context:
space:
mode:
authorsefidel <contact@sefidel.net>2023-03-29 20:54:19 +0900
committersefidel <contact@sefidel.net>2023-04-03 18:32:29 +0900
commitce06f43476863da90dc60dcee606d2b6c5a89a8e (patch)
tree5d14946330cb09ff0ebd97bee59407fccee4d860 /modules/services/misskey/default.nix
downloadinfra-ce06f43476863da90dc60dcee606d2b6c5a89a8e.zip
project: initial commit
Diffstat (limited to 'modules/services/misskey/default.nix')
-rw-r--r--modules/services/misskey/default.nix88
1 files changed, 88 insertions, 0 deletions
diff --git a/modules/services/misskey/default.nix b/modules/services/misskey/default.nix
new file mode 100644
index 0000000..355e91f
--- /dev/null
+++ b/modules/services/misskey/default.nix
@@ -0,0 +1,88 @@
+{ config, lib, pkgs, ... }:
+
+with lib;
+let
+ cfg = config.modules.services.misskey;
+
+ inherit (lib.my) wrapFile;
+in
+{
+ options.modules.services.misskey = {
+ enable = mkEnableOption "Misskey, an interplanetary microblogging platform [container]";
+ domain = mkOption { type = types.str; };
+ realHost = mkOption { type = types.str; };
+ };
+
+ config = mkIf cfg.enable {
+ # TODO: refactor
+
+ # Misskey sets uid/gid to 991 in container, user is created here to
+ # ensure that misskey files directory is accessible by the container user.
+ users = {
+ users.misskey = {
+ description = "Misskey user";
+ group = "misskey";
+ extraGroups = [ "podman" ];
+ isSystemUser = true;
+ uid = 991;
+ };
+ groups.misskey = { gid = 991; };
+ };
+
+ virtualisation.podman.extraPackages = [ pkgs.zfs ];
+
+ # Packaging misskey is too much of a hassle, so we're using containers for now.
+ virtualisation.oci-containers.containers.misskey = {
+ volumes = [
+ "/var/lib/misskey-files:/misskey/files"
+ # TODO: manage this with nix
+ "${wrapFile ".config" ./config}:/misskey/.config:ro"
+ ];
+ image = "misskey/misskey:13.10.3";
+ ports = [ "3000:3000" ];
+ extraOptions = [
+ "--network=host"
+ ];
+ };
+
+ environment.persistence."/persist".directories = [
+ "/var/lib/containers"
+ "/var/lib/misskey-files"
+ ];
+
+ systemd.tmpfiles.rules = [
+ "d /var/lib/misskey-files 0755 misskey misskey -"
+ ];
+
+ services.postgresql.enable = true;
+ services.postgresql.ensureDatabases = [ "misskey" ];
+ services.postgresql.ensureUsers = [
+ {
+ name = "misskey";
+ ensurePermissions."DATABASE misskey" = "ALL PRIVILEGES";
+ }
+ ];
+
+ services.redis.servers.misskey = {
+ enable = true;
+ bind = "127.0.0.1";
+ port = 16434;
+ };
+
+ services.nginx.virtualHosts.${cfg.realHost} = {
+ forceSSL = true;
+ useACMEHost = cfg.domain;
+ locations."/" = {
+ proxyPass = "http://127.0.0.1:3000";
+ proxyWebsockets = true;
+ };
+
+ extraConfig = ''
+ proxy_set_header Host $host;
+ proxy_set_header X-Real-IP $remote_addr;
+ proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
+ proxy_set_header X-Forwarded-Proto https;
+ '';
+ };
+ };
+}