mirror of
https://github.com/Gerg-L/nixos.git
synced 2025-12-10 00:43:56 -05:00
miniflux: use nixpkgs module
This commit is contained in:
parent
899738705e
commit
ab19656c96
2 changed files with 16 additions and 85 deletions
|
|
@ -1,88 +1,22 @@
|
||||||
{
|
{
|
||||||
config,
|
config,
|
||||||
lib,
|
lib,
|
||||||
pkgs,
|
|
||||||
}:
|
}:
|
||||||
{
|
{
|
||||||
sops.secrets.minifluxenv = { };
|
sops.secrets.minifluxenv = { };
|
||||||
|
|
||||||
systemd.services = {
|
services.miniflux = {
|
||||||
miniflux = {
|
enable = true;
|
||||||
enable = true;
|
config = {
|
||||||
|
BASE_URL = "https://flux.gerg-l.com";
|
||||||
description = "Miniflux service";
|
LISTEN_ADDR = "/run/miniflux/miniflux.sock";
|
||||||
wantedBy = [ "multi-user.target" ];
|
|
||||||
requires = [ "miniflux-dbsetup.service" ];
|
|
||||||
after = [
|
|
||||||
"network.target"
|
|
||||||
"postgresql.service"
|
|
||||||
"miniflux-dbsetup.service"
|
|
||||||
];
|
|
||||||
|
|
||||||
serviceConfig = {
|
|
||||||
ExecStart = lib.getExe pkgs.miniflux;
|
|
||||||
User = "miniflux";
|
|
||||||
RuntimeDirectory = "miniflux";
|
|
||||||
RuntimeDirectoryMode = "0770";
|
|
||||||
EnvironmentFile = config.sops.secrets.minifluxenv.path;
|
|
||||||
# Hardening
|
|
||||||
CapabilityBoundingSet = [ "" ];
|
|
||||||
DeviceAllow = [ "" ];
|
|
||||||
LockPersonality = true;
|
|
||||||
MemoryDenyWriteExecute = true;
|
|
||||||
PrivateDevices = true;
|
|
||||||
PrivateUsers = true;
|
|
||||||
ProcSubset = "pid";
|
|
||||||
ProtectClock = true;
|
|
||||||
ProtectControlGroups = true;
|
|
||||||
ProtectHome = true;
|
|
||||||
ProtectHostname = true;
|
|
||||||
ProtectKernelLogs = true;
|
|
||||||
ProtectKernelModules = true;
|
|
||||||
ProtectKernelTunables = true;
|
|
||||||
ProtectProc = "invisible";
|
|
||||||
RestrictAddressFamilies = [
|
|
||||||
"AF_INET"
|
|
||||||
"AF_INET6"
|
|
||||||
"AF_UNIX"
|
|
||||||
];
|
|
||||||
RestrictNamespaces = true;
|
|
||||||
RestrictRealtime = true;
|
|
||||||
RestrictSUIDSGID = true;
|
|
||||||
SystemCallArchitectures = "native";
|
|
||||||
SystemCallFilter = [
|
|
||||||
"@system-service"
|
|
||||||
"~@privileged"
|
|
||||||
];
|
|
||||||
UMask = "0077";
|
|
||||||
};
|
|
||||||
|
|
||||||
environment = {
|
|
||||||
BASE_URL = "https://flux.gerg-l.com";
|
|
||||||
LISTEN_ADDR = "/run/miniflux/miniflux.sock";
|
|
||||||
DATABASE_URL = "user=miniflux host=/run/postgresql dbname=miniflux";
|
|
||||||
RUN_MIGRATIONS = "1";
|
|
||||||
CREATE_ADMIN = "1";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
miniflux-dbsetup = {
|
|
||||||
description = "Miniflux database setup";
|
|
||||||
requires = [ "postgresql.service" ];
|
|
||||||
after = [
|
|
||||||
"network.target"
|
|
||||||
"postgresql.service"
|
|
||||||
];
|
|
||||||
serviceConfig = {
|
|
||||||
ExecStart = "${lib.getExe' config.services.postgresql.package "psql"} 'miniflux' -c 'CREATE EXTENSION IF NOT EXISTS hstore'";
|
|
||||||
Type = "oneshot";
|
|
||||||
User = config.services.postgresql.superUser;
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
adminCredentialsFile = config.sops.secrets.minifluxenv.path;
|
||||||
|
createDatabaseLocally = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
users = {
|
users = {
|
||||||
groups.miniflux = {
|
groups.miniflux.gid = 377;
|
||||||
gid = 377;
|
|
||||||
};
|
|
||||||
users = {
|
users = {
|
||||||
miniflux = {
|
miniflux = {
|
||||||
group = "miniflux";
|
group = "miniflux";
|
||||||
|
|
@ -94,5 +28,11 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
local.nginx.proxyVhosts."flux.gerg-l.com" = "http://unix:/run/miniflux/miniflux.sock";
|
systemd.services.miniflux.serviceConfig = {
|
||||||
|
RuntimeDirectoryMode = lib.mkForce "0770";
|
||||||
|
DynamicUser = lib.mkForce false;
|
||||||
|
};
|
||||||
|
|
||||||
|
local.nginx.proxyVhosts."flux.gerg-l.com" =
|
||||||
|
"http://unix:${config.services.miniflux.config.LISTEN_ADDR}";
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -4,15 +4,6 @@
|
||||||
enable = true;
|
enable = true;
|
||||||
package = pkgs.postgresql_16;
|
package = pkgs.postgresql_16;
|
||||||
dataDir = "/persist/services/postgresql";
|
dataDir = "/persist/services/postgresql";
|
||||||
|
|
||||||
ensureDatabases = [ "miniflux" ];
|
|
||||||
ensureUsers = [
|
|
||||||
{
|
|
||||||
name = "miniflux";
|
|
||||||
ensureDBOwnership = true;
|
|
||||||
}
|
|
||||||
];
|
|
||||||
|
|
||||||
settings.unix_socket_permissions = "0770";
|
settings.unix_socket_permissions = "0770";
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue