Skip to content

Commit

Permalink
Merge pull request #47 from ngi-nix/moss/flarum-module
Browse files Browse the repository at this point in the history
flarum: init module at 1.8.0
  • Loading branch information
jasonodoom authored Sep 15, 2023
2 parents 8788d97 + de3595c commit 0d1d22b
Show file tree
Hide file tree
Showing 6 changed files with 241 additions and 6 deletions.
4 changes: 3 additions & 1 deletion configs/all-configurations.nix
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,9 @@
# LiberaForms is intentionally disabled.
# Refer to <https://github.com/ngi-nix/ngipkgs/issues/40>.
#liberaforms-container = import ./liberaforms/container.nix;

flarum = {
imports = [./flarum];
};
pretalx-postgresql = {
imports = [
./pretalx/pretalx.nix
Expand Down
14 changes: 14 additions & 0 deletions configs/flarum/default.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
{
boot.isContainer = true;
networking.hostName = "test-flarum";

# Allow nginx through the firewall
networking.firewall.allowedTCPPorts = [80];

services.nginx.enable = true;
nixpkgs.hostPlatform = "x86_64-linux";
services.flarum = {
enable = true;
domain = "10.233.2.2";
};
}
7 changes: 4 additions & 3 deletions flake.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 2 additions & 2 deletions flake.nix
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
description = "NgiPkgs";

inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable";
inputs.nix-php-composer-builder.url = "github:loophp/nix-php-composer-builder";
inputs.nix-php-composer-builder.url = "github:loophp/nix-php-composer-builder?ref=0caf5a60753397cfa959a74fc9ea0562556573c1";
inputs.flake-utils.url = "github:numtide/flake-utils";
# Set default system to `x86_64-linux`,
# as we currently only support Linux.
Expand Down Expand Up @@ -112,7 +112,7 @@
// {
# The default module adds the default overlay on top of nixpkgs.
# This is so that `ngipkgs` can be used alongside `nixpkgs` in a configuration.
default.nixpkgs.overlays = [self.overlays.default];
default.nixpkgs.overlays = [self.overlays.default nix-php-composer-builder.overlays.default];
};

# Overlays a package set (e.g. nixpkgs) with the packages defined in this flake.
Expand Down
1 change: 1 addition & 0 deletions modules/all-modules.nix
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,5 @@
# Refer to <https://github.com/ngi-nix/ngipkgs/issues/40>.
#liberaforms = import ./liberaforms.nix;
pretalx = import ./pretalx.nix;
flarum = import ./flarum.nix;
}
217 changes: 217 additions & 0 deletions modules/flarum.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,217 @@
{
config,
lib,
pkgs,
self,
utils,
...
}:
with builtins;
with lib; let
cfg = config.services.flarum;
opt = options.services.flarum;

flarumInstallConfig = pkgs.writeText "config.json" (builtins.toJSON {
debug = false;
offline = false;

baseUrl = cfg.baseUrl;
databaseConfiguration = cfg.database;
adminUser = {
username = cfg.adminUser;
password = cfg.initialAdminPassword;
email = cfg.adminEmail;
};
settings = {forum_title = cfg.forumTitle;};
});
in {
options = {
services.flarum = with types; {
enable = mkEnableOption "Flarum discussion platform";

package = mkPackageOption pkgs "flarum" {};

forumTitle = mkOption {
type = types.str;
default = "A Flarum Forum on NixOS";
description = "Title of the forum.";
};

domain = mkOption {
type = types.str;
default = "localhost";
example = "forum.example.com";
description = "Domain to serve on.";
};

baseUrl = mkOption {
type = types.str;
default = "https://${cfg.domain}";
example = "https://forum.example.com";
description = "Change `domain` instead.";
};

adminUser = mkOption {
type = types.str;
default = "flarum";
description = "Username for first web application administrator";
};

adminEmail = mkOption {
type = types.str;
default = "[email protected]";
description = "Email for first web application administrator";
};

initialAdminPassword = mkOption {
type = types.str;
default = "flarum";
description = "Initial password for the adminUser";
};

user = mkOption {
type = types.str;
default = "flarum";
description = "System user to run Flarum";
};

group = mkOption {
type = types.str;
default = "flarum";
description = "System group to run Flarum";
};

stateDir = mkOption {
type = types.path;
default = "/var/lib/flarum";
description = "Home directory for writable storage";
};

database = mkOption rec {
type = with types; attrsOf (oneOf [str bool int]);
description = "MySQL database parameters";
default = {
# the database driver; i.e. MySQL; MariaDB...
driver = "mysql";
# the host of the connection; localhost in most cases unless using an external service
host = "localhost";
# the name of the database in the instance
database = "flarum";
# database username
username = "flarum";
# database password
password = "";
# the prefix for the tables; useful if you are sharing the same database with another service
prefix = "";
# the port of the connection; defaults to 3306 with MySQL
port = 3306;
strict = false;
};
};

createDatabaseLocally = mkOption {
type = types.bool;
default = true;
description = "Create the database and database user locally, and run installation.";
};
};
};

config = mkIf cfg.enable {
users.users.${cfg.user} = {
isSystemUser = true;
home = cfg.stateDir;
createHome = true;
group = cfg.group;
};
users.groups.${cfg.group} = {};

services.phpfpm.pools.flarum = {
user = cfg.user;
settings = {
"listen.owner" = config.services.nginx.user;
"listen.group" = config.services.nginx.group;
"listen.mode" = "0600";
"pm" = mkDefault "dynamic";
"pm.max_children" = mkDefault 10;
"pm.max_requests" = mkDefault 500;
"pm.start_servers" = mkDefault 2;
"pm.min_spare_servers" = mkDefault 1;
"pm.max_spare_servers" = mkDefault 3;
};
phpOptions = ''
error_log = syslog
log_errors = on
'';
};

services.nginx = {
enable = true;
virtualHosts."${cfg.domain}" = {
root = "${cfg.stateDir}/public";
locations."~ \.php$".extraConfig = ''
fastcgi_pass unix:${config.services.phpfpm.pools.flarum.socket};
fastcgi_index site.php;
'';
extraConfig = ''
index index.php
include ${cfg.package}/build/.nginx.conf;
'';
};
};

services.mysql = mkIf cfg.enable {
enable = true;
package = pkgs.mysql;
ensureDatabases = [cfg.database.database];
ensureUsers = [
{
name = cfg.database.username;
ensurePermissions = {
"${cfg.database.database}.*" = "ALL PRIVILEGES";
};
}
];
};

assertions = [
{
assertion = !cfg.createDatabaseLocally || cfg.database.driver == "mysql";
message = "Flarum can only be automatically installed in MySQL/MariaDB.";
}
];

systemd.services.flarum-install = {
description = "Flarum installation";
requiredBy = ["phpfpm-flarum.service"];
before = ["phpfpm-flarum.service"];
requires = ["mysql.service"];
after = ["mysql.service"];
serviceConfig = {
Type = "oneshot";
User = cfg.user;
Group = cfg.group;
};
path = [config.services.phpfpm.phpPackage];
script =
''
mkdir -p ${cfg.stateDir}/{extensions,public/assets/avatars}
mkdir -p ${cfg.stateDir}/storage/{formatter,sessions,views}
cd ${cfg.stateDir}
cp -f ${cfg.package}/build/{extend.php,site.php,flarum} .
ln -sf ${cfg.package}/build/vendor .
ln -sf ${cfg.package}/build/public/index.php public/
chmod a+x . public
chmod +x site.php extend.php flarum
''
+ lib.optionalString
(cfg.createDatabaseLocally && cfg.database.driver == "mysql") ''
if [ ! -f config.php ]; then
php flarum install --file=${flarumInstallConfig}
fi
php flarum migrate
# php flarum cache:clear
'';
};
};
}

0 comments on commit 0d1d22b

Please sign in to comment.