Package is now 'invoiceninja', modified code to reflect name change, changed nixos module definition for caddy to allow local development
This commit is contained in:
parent
14976fdae9
commit
4cb4a1c05d
@ -1,7 +1,7 @@
|
|||||||
{ overlays }:
|
{ overlays }:
|
||||||
|
|
||||||
{
|
{
|
||||||
invoice-ninja = import ./invoice-ninja.nix;
|
invoiceninja = import ./invoiceninja.nix;
|
||||||
overlayNixpkgsForThisInstance =
|
overlayNixpkgsForThisInstance =
|
||||||
{ pkgs, ... }: {
|
{ pkgs, ... }: {
|
||||||
nixpkgs = {
|
nixpkgs = {
|
||||||
|
|||||||
@ -8,14 +8,14 @@
|
|||||||
}:
|
}:
|
||||||
|
|
||||||
let
|
let
|
||||||
cfg = config.services.invoice-ninja;
|
cfg = config.services.invoiceninja;
|
||||||
user = cfg.user;
|
user = cfg.user;
|
||||||
group = cfg.group;
|
group = cfg.group;
|
||||||
invoice-ninja = pkgs.callPackage ../package.nix {
|
invoiceninja = pkgs.callPackage ../package.nix {
|
||||||
inherit (cfg) dataDir runtimeDir;
|
inherit (cfg) dataDir runtimeDir;
|
||||||
};
|
};
|
||||||
configFormat = pkgs.formats.keyValue { };
|
configFormat = pkgs.formats.keyValue { };
|
||||||
configFile = pkgs.writeText "invoice-ninja-env" (lib.generators.toKeyValue { } cfg.settings);
|
configFile = pkgs.writeText "invoiceninja-env" (lib.generators.toKeyValue { } cfg.settings);
|
||||||
|
|
||||||
# PHP environment
|
# PHP environment
|
||||||
phpPackage = cfg.phpPackage.buildEnv {
|
phpPackage = cfg.phpPackage.buildEnv {
|
||||||
@ -53,8 +53,8 @@ let
|
|||||||
extraPrograms = [ chromium ];
|
extraPrograms = [ chromium ];
|
||||||
|
|
||||||
# Management script
|
# Management script
|
||||||
invoice-ninja-manage = pkgs.writeShellScriptBin "invoice-ninja-manage" ''
|
invoiceninja-manage = pkgs.writeShellScriptBin "invoiceninja-manage" ''
|
||||||
cd ${invoice-ninja}
|
cd ${invoiceninja}
|
||||||
sudo=exec
|
sudo=exec
|
||||||
if [[ "$USER" != ${user} ]]; then
|
if [[ "$USER" != ${user} ]]; then
|
||||||
sudo='exec /run/wrappers/bin/sudo -u ${user}'
|
sudo='exec /run/wrappers/bin/sudo -u ${user}'
|
||||||
@ -63,10 +63,10 @@ let
|
|||||||
'';
|
'';
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
options.services.invoice-ninja = {
|
options.services.invoiceninja = {
|
||||||
enable = lib.mkEnableOption "invoice-ninja";
|
enable = lib.mkEnableOption "invoiceninja";
|
||||||
|
|
||||||
package = lib.mkPackageOption pkgs "invoice-ninja" { };
|
package = lib.mkPackageOption pkgs "invoiceninja" { };
|
||||||
|
|
||||||
phpPackage = lib.mkPackageOption pkgs "php82" { };
|
phpPackage = lib.mkPackageOption pkgs "php82" { };
|
||||||
|
|
||||||
@ -94,7 +94,7 @@ in
|
|||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
msmtp.accounts.invoice-ninja = lib.mkOption {
|
msmtp.accounts.invoiceninja = lib.mkOption {
|
||||||
type = lib.types.attrs;
|
type = lib.types.attrs;
|
||||||
default = { };
|
default = { };
|
||||||
example = {
|
example = {
|
||||||
@ -107,9 +107,9 @@ in
|
|||||||
passwordeval = "cat /secrets/password.txt";
|
passwordeval = "cat /secrets/password.txt";
|
||||||
};
|
};
|
||||||
description = ''
|
description = ''
|
||||||
Define the msmtp configuration for an invoice-ninja account which
|
Define the msmtp configuration for an invoiceninja account which
|
||||||
will be used by Invoice Ninja to send email message when
|
will be used by Invoice Ninja to send email message when
|
||||||
`config.services.invoice-ninja.settings.MAIL_MAILER` is `sendmail`.
|
`config.services.invoiceninja.settings.MAIL_MAILER` is `sendmail`.
|
||||||
|
|
||||||
It is advised to use the `passwordeval` setting to read the password
|
It is advised to use the `passwordeval` setting to read the password
|
||||||
from a secret file to avoid having it written in the world-readable
|
from a secret file to avoid having it written in the world-readable
|
||||||
@ -125,18 +125,18 @@ in
|
|||||||
|
|
||||||
dataDir = lib.mkOption {
|
dataDir = lib.mkOption {
|
||||||
type = lib.types.str;
|
type = lib.types.str;
|
||||||
default = "/var/lib/invoice-ninja";
|
default = "/var/lib/invoiceninja";
|
||||||
description = ''
|
description = ''
|
||||||
State directory of the `invoice-ninja` user which holds
|
State directory of the `invoiceninja` user which holds
|
||||||
the application's state and data.
|
the application's state and data.
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
runtimeDir = lib.mkOption {
|
runtimeDir = lib.mkOption {
|
||||||
type = lib.types.str;
|
type = lib.types.str;
|
||||||
default = "/run/invoice-ninja";
|
default = "/run/invoiceninja";
|
||||||
description = ''
|
description = ''
|
||||||
Rutime directory of the `invoice-ninja` user which holds
|
Rutime directory of the `invoiceninja` user which holds
|
||||||
the application's caches and temporary files.
|
the application's caches and temporary files.
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
@ -207,7 +207,7 @@ in
|
|||||||
options = {
|
options = {
|
||||||
APP_NAME = lib.mkOption {
|
APP_NAME = lib.mkOption {
|
||||||
type = lib.types.str;
|
type = lib.types.str;
|
||||||
default = "Invoice Ninja";
|
default = ''"Invoice Ninja"'';
|
||||||
description = "Your application name - used in client portal title banner";
|
description = "Your application name - used in client portal title banner";
|
||||||
};
|
};
|
||||||
APP_DEBUG = lib.mkOption {
|
APP_DEBUG = lib.mkOption {
|
||||||
@ -256,13 +256,13 @@ in
|
|||||||
};
|
};
|
||||||
MAIL_SENDMAIL_PATH = lib.mkOption {
|
MAIL_SENDMAIL_PATH = lib.mkOption {
|
||||||
type = lib.types.str;
|
type = lib.types.str;
|
||||||
default = ''"/run/wrappers/bin/sendmail -t -a invoice-ninja"'';
|
default = ''"/run/wrappers/bin/sendmail -t -a invoiceninja"'';
|
||||||
description = ''
|
description = ''
|
||||||
Path to sendmail along with arguments for Invoice Ninja to use when using sendmail
|
Path to sendmail along with arguments for Invoice Ninja to use when using sendmail
|
||||||
as mail transport agent.
|
as mail transport agent.
|
||||||
|
|
||||||
:: note
|
:: note
|
||||||
The default value will work with the `msmtp.accounts.invoice-ninja` setting. Only
|
The default value will work with the `msmtp.accounts.invoiceninja` setting. Only
|
||||||
change if you know what your doing.
|
change if you know what your doing.
|
||||||
::
|
::
|
||||||
'';
|
'';
|
||||||
@ -294,7 +294,7 @@ in
|
|||||||
default =
|
default =
|
||||||
if cfg.redis.createLocally then "redis" else (if cfg.database.createLocally then "database" else "file");
|
if cfg.redis.createLocally then "redis" else (if cfg.database.createLocally then "database" else "file");
|
||||||
defaultText = lib.literalExpression ''
|
defaultText = lib.literalExpression ''
|
||||||
if config.services.invoice-ninja.redis.enable
|
if config.services.invoiceninja.redis.enable
|
||||||
then "redis"
|
then "redis"
|
||||||
else (if config.services.invoie-ninja.database.createLocally then "database" else "file")
|
else (if config.services.invoie-ninja.database.createLocally then "database" else "file")
|
||||||
'';
|
'';
|
||||||
@ -317,7 +317,7 @@ in
|
|||||||
default =
|
default =
|
||||||
if cfg.redis.createLocally then "redis" else (if cfg.database.createLocally then "database" else "sync");
|
if cfg.redis.createLocally then "redis" else (if cfg.database.createLocally then "database" else "sync");
|
||||||
defaultText = lib.literalExpression ''
|
defaultText = lib.literalExpression ''
|
||||||
if config.services.invoice-ninja.redis.enable
|
if config.services.invoiceninja.redis.enable
|
||||||
then "redis"
|
then "redis"
|
||||||
else (if config.services.invoie-ninja.database.createLocally then "database" else "sync")
|
else (if config.services.invoie-ninja.database.createLocally then "database" else "sync")
|
||||||
'';
|
'';
|
||||||
@ -329,7 +329,7 @@ in
|
|||||||
"redis"
|
"redis"
|
||||||
];
|
];
|
||||||
default = if cfg.redis.createLocally then "redis" else "file";
|
default = if cfg.redis.createLocally then "redis" else "file";
|
||||||
defaultText = lib.literalExpression ''if config.services.invoice-ninja.redis.enable then "redis" else "file"'';
|
defaultText = lib.literalExpression ''if config.services.invoiceninja.redis.enable then "redis" else "file"'';
|
||||||
description = "Laravel cache driver for Invoice Ninja to use.";
|
description = "Laravel cache driver for Invoice Ninja to use.";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
@ -337,7 +337,7 @@ in
|
|||||||
};
|
};
|
||||||
|
|
||||||
adminAccount = {
|
adminAccount = {
|
||||||
createAdmin = lib.mkOption {
|
enable = lib.mkOption {
|
||||||
type = lib.types.bool;
|
type = lib.types.bool;
|
||||||
default = true;
|
default = true;
|
||||||
description = ''
|
description = ''
|
||||||
@ -347,7 +347,7 @@ in
|
|||||||
};
|
};
|
||||||
email = lib.mkOption {
|
email = lib.mkOption {
|
||||||
type = lib.types.str;
|
type = lib.types.str;
|
||||||
default = "example@email.com";
|
default = "admin@email.com";
|
||||||
description = "Email address of the first (admin) account for this Invoice Ninja installation";
|
description = "Email address of the first (admin) account for this Invoice Ninja installation";
|
||||||
};
|
};
|
||||||
passwordFile = lib.mkOption {
|
passwordFile = lib.mkOption {
|
||||||
@ -423,14 +423,14 @@ in
|
|||||||
|
|
||||||
users.groups.invoiceninja = lib.mkIf (cfg.group == "invoiceninja") { };
|
users.groups.invoiceninja = lib.mkIf (cfg.group == "invoiceninja") { };
|
||||||
|
|
||||||
environment.systemPackages = [ invoice-ninja-manage ] ++ extraPrograms;
|
environment.systemPackages = [ invoiceninja-manage ] ++ extraPrograms;
|
||||||
|
|
||||||
programs.msmtp = lib.mkIf (cfg.settings.MAIL_MAILER == "sendmail") {
|
programs.msmtp = lib.mkIf (cfg.settings.MAIL_MAILER == "sendmail") {
|
||||||
inherit (cfg.msmtp) accounts;
|
inherit (cfg.msmtp) accounts;
|
||||||
enable = true;
|
enable = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
services.invoice-ninja.settings = lib.mkMerge [
|
services.invoiceninja.settings = lib.mkMerge [
|
||||||
({
|
({
|
||||||
APP_URL = lib.mkDefault (
|
APP_URL = lib.mkDefault (
|
||||||
if (cfg.hostname == "localhost") then ("http://" + cfg.hostname) else ("https://" + cfg.hostname)
|
if (cfg.hostname == "localhost") then ("http://" + cfg.hostname) else ("https://" + cfg.hostname)
|
||||||
@ -452,12 +452,12 @@ in
|
|||||||
DB_USERNAME = lib.mkDefault user;
|
DB_USERNAME = lib.mkDefault user;
|
||||||
})
|
})
|
||||||
(lib.mkIf cfg.redis.createLocally {
|
(lib.mkIf cfg.redis.createLocally {
|
||||||
REDIS_HOST = lib.mkDefault config.services.redis.servers.invoice-ninja.bind;
|
REDIS_HOST = lib.mkDefault config.services.redis.servers.invoiceninja.bind;
|
||||||
REDIS_PORT = lib.mkDefault config.services.redis.servers.invoice-ninja.port;
|
REDIS_PORT = lib.mkDefault config.services.redis.servers.invoiceninja.port;
|
||||||
})
|
})
|
||||||
];
|
];
|
||||||
|
|
||||||
services.phpfpm.pools.invoice-ninja = {
|
services.phpfpm.pools.invoiceninja = {
|
||||||
inherit user group phpPackage;
|
inherit user group phpPackage;
|
||||||
|
|
||||||
settings = {
|
settings = {
|
||||||
@ -474,7 +474,7 @@ in
|
|||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
services.redis.servers.invoice-ninja = lib.mkIf cfg.redis.createLocally {
|
services.redis.servers.invoiceninja = lib.mkIf cfg.redis.createLocally {
|
||||||
enable = true;
|
enable = true;
|
||||||
port = 6379;
|
port = 6379;
|
||||||
};
|
};
|
||||||
@ -495,7 +495,7 @@ in
|
|||||||
virtualHosts."${cfg.hostname}" = lib.mkMerge [
|
virtualHosts."${cfg.hostname}" = lib.mkMerge [
|
||||||
cfg.proxy.nginxConfig
|
cfg.proxy.nginxConfig
|
||||||
{
|
{
|
||||||
root = lib.mkForce "${invoice-ninja}/public";
|
root = lib.mkForce "${invoiceninja}/public";
|
||||||
addSSL = lib.mkForce true;
|
addSSL = lib.mkForce true;
|
||||||
enableACME = lib.mkForce true;
|
enableACME = lib.mkForce true;
|
||||||
locations = {
|
locations = {
|
||||||
@ -514,7 +514,7 @@ in
|
|||||||
'';
|
'';
|
||||||
"~ \\.php$".extraConfig = "return 403;";
|
"~ \\.php$".extraConfig = "return 403;";
|
||||||
"= /index.php".extraConfig = ''
|
"= /index.php".extraConfig = ''
|
||||||
fastcgi_pass unix:${config.services.phpfpm.pools.invoice-ninja.socket};
|
fastcgi_pass unix:${config.services.phpfpm.pools.invoiceninja.socket};
|
||||||
'';
|
'';
|
||||||
"~ /\\.ht".extraConfig = "deny all;";
|
"~ /\\.ht".extraConfig = "deny all;";
|
||||||
};
|
};
|
||||||
@ -533,35 +533,43 @@ in
|
|||||||
users.users."${config.services.caddy.user}" = lib.mkIf (cfg.proxy.server == "caddy") {
|
users.users."${config.services.caddy.user}" = lib.mkIf (cfg.proxy.server == "caddy") {
|
||||||
extraGroups = [ cfg.group ];
|
extraGroups = [ cfg.group ];
|
||||||
};
|
};
|
||||||
services.caddy = lib.mkIf (cfg.proxy.server == "caddy") {
|
services.caddy =
|
||||||
enable = true;
|
let
|
||||||
|
proto_hostname = (
|
||||||
|
if (cfg.hostname == "localhost")
|
||||||
|
then (cfg.hostname + ":80")
|
||||||
|
else (cfg.hostname + ":443")
|
||||||
|
);
|
||||||
|
in
|
||||||
|
lib.mkIf (cfg.proxy.server == "caddy") {
|
||||||
|
enable = true;
|
||||||
|
|
||||||
globalConfig = lib.mkIf (cfg.hostname == "localhost") ''
|
globalConfig = lib.mkIf (cfg.hostname == "localhost") ''
|
||||||
auto_https disable_redirects
|
auto_https disable_redirects
|
||||||
'';
|
'';
|
||||||
|
|
||||||
virtualHosts."${cfg.hostname}" = lib.mkMerge [
|
virtualHosts."${proto_hostname}" = lib.mkMerge [
|
||||||
cfg.proxy.caddyConfig
|
cfg.proxy.caddyConfig
|
||||||
{
|
{
|
||||||
hostName = lib.mkForce cfg.hostname;
|
hostName = lib.mkForce proto_hostname;
|
||||||
extraConfig = ''
|
extraConfig = ''
|
||||||
encode zstd gzip
|
encode zstd gzip
|
||||||
root * ${invoice-ninja}/public
|
root * ${invoiceninja}/public
|
||||||
php_fastcgi unix/${config.services.phpfpm.pools.invoice-ninja.socket}
|
php_fastcgi unix/${config.services.phpfpm.pools.invoiceninja.socket}
|
||||||
try_files {path} /index.html
|
try_files {path} /index.html
|
||||||
header {
|
header {
|
||||||
Access-Control-Allow-Origin "*"
|
Access-Control-Allow-Origin "*"
|
||||||
Access-Control-Allow-Methods "*"
|
Access-Control-Allow-Methods "*"
|
||||||
Access-Control-Max-Age "0"
|
Access-Control-Max-Age "0"
|
||||||
Access-Control-Allow-Headers "X-API-COMPANY-KEY,X-API-SECRET,X-API-TOKEN,X-API-PASSWORD,DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Disposition,Content-Type,Range,X-CSRF-TOKEN,X-XSRF-TOKEN,X-LIVEWIRE"
|
Access-Control-Allow-Headers "X-API-COMPANY-KEY,X-API-SECRET,X-API-TOKEN,X-API-PASSWORD,DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Disposition,Content-Type,Range,X-CSRF-TOKEN,X-XSRF-TOKEN,X-LIVEWIRE"
|
||||||
Access-Control-Expose-Headers "X-APP-VERSION,X-MINIMUM-CLIENT-VERSION,X-CSRF-TOKEN,X-XSRF-TOKEN,X-LIVEWIRE"
|
Access-Control-Expose-Headers "X-APP-VERSION,X-MINIMUM-CLIENT-VERSION,X-CSRF-TOKEN,X-XSRF-TOKEN,X-LIVEWIRE"
|
||||||
Access-Control-Allow-Credentials false
|
Access-Control-Allow-Credentials false
|
||||||
}
|
}
|
||||||
file_server
|
file_server
|
||||||
'';
|
'';
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
services.mysql = lib.mkIf (cfg.database.createLocally) {
|
services.mysql = lib.mkIf (cfg.database.createLocally) {
|
||||||
enable = lib.mkDefault true;
|
enable = lib.mkDefault true;
|
||||||
@ -577,33 +585,33 @@ in
|
|||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
systemd.services.phpfpm-invoice-ninja.after = [ "invoice-ninja-data-setup.service" ];
|
systemd.services.phpfpm-invoiceninja.after = [ "invoiceninja-data-setup.service" ];
|
||||||
systemd.services.phpfpm-invoice-ninja.requires = [
|
systemd.services.phpfpm-invoiceninja.requires = [
|
||||||
"invoice-ninja-data-setup.service"
|
"invoiceninja-data-setup.service"
|
||||||
] ++ lib.optional cfg.database.createLocally "mysql.service";
|
] ++ lib.optional cfg.database.createLocally "mysql.service";
|
||||||
# Ensure chromium is available
|
# Ensure chromium is available
|
||||||
systemd.services.phpfpm-invoice-ninja.path = extraPrograms;
|
systemd.services.phpfpm-invoiceninja.path = extraPrograms;
|
||||||
|
|
||||||
systemd.services.invoice-ninja-queue-worker = {
|
systemd.services.invoiceninja-queue-worker = {
|
||||||
description = "Invoice Ninja periodic tasks";
|
description = "Invoice Ninja periodic tasks";
|
||||||
after = [ "invoice-ninja-data-setup.service" ];
|
after = [ "invoiceninja-data-setup.service" ];
|
||||||
requires = [ "phpfpm-invoice-ninja.service" ];
|
requires = [ "phpfpm-invoiceninja.service" ];
|
||||||
wantedBy = [ "multi-user.target" ];
|
wantedBy = [ "multi-user.target" ];
|
||||||
reloadTriggers = [ invoice-ninja ];
|
reloadTriggers = [ invoiceninja ];
|
||||||
reload = "${invoice-ninja-manage}/bin/invoice-ninja-manage queue:restart";
|
reload = "${invoiceninja-manage}/bin/invoiceninja-manage queue:restart";
|
||||||
|
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
ExecStart = "${invoice-ninja-manage}/bin/invoice-ninja-manage queue:work ${
|
ExecStart = "${invoiceninja-manage}/bin/invoiceninja-manage queue:work ${
|
||||||
lib.strings.optionalString (cfg.settings.QUEUE_CONNECTION == "redis") "redis"
|
lib.strings.optionalString (cfg.settings.QUEUE_CONNECTION == "redis") "redis"
|
||||||
}";
|
}";
|
||||||
User = user;
|
User = user;
|
||||||
Group = group;
|
Group = group;
|
||||||
StateDirectory = lib.mkIf (cfg.dataDir == "/var/lib/invoice-ninja") "invoice-ninja";
|
StateDirectory = lib.mkIf (cfg.dataDir == "/var/lib/invoiceninja") "invoiceninja";
|
||||||
Restart = "always";
|
Restart = "always";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
systemd.services.invoice-ninja-data-setup = {
|
systemd.services.invoiceninja-data-setup = {
|
||||||
description = "Invoice Ninja setup: migrations, environment file update, cache reload, data changes";
|
description = "Invoice Ninja setup: migrations, environment file update, cache reload, data changes";
|
||||||
wantedBy = [ "multi-user.target" ];
|
wantedBy = [ "multi-user.target" ];
|
||||||
after = lib.optional cfg.database.createLocally "mysql.service";
|
after = lib.optional cfg.database.createLocally "mysql.service";
|
||||||
@ -612,7 +620,7 @@ in
|
|||||||
with pkgs;
|
with pkgs;
|
||||||
[
|
[
|
||||||
bash
|
bash
|
||||||
invoice-ninja-manage
|
invoiceninja-manage
|
||||||
rsync
|
rsync
|
||||||
config.services.mysql.package
|
config.services.mysql.package
|
||||||
]
|
]
|
||||||
@ -622,7 +630,7 @@ in
|
|||||||
Type = "oneshot";
|
Type = "oneshot";
|
||||||
User = user;
|
User = user;
|
||||||
Group = group;
|
Group = group;
|
||||||
StateDirectory = lib.mkIf (cfg.dataDir == "/var/lib/invoice-ninja") "invoice-ninja";
|
StateDirectory = lib.mkIf (cfg.dataDir == "/var/lib/invoiceninja") "invoiceninja";
|
||||||
StateDirectoryMode = "0750";
|
StateDirectoryMode = "0750";
|
||||||
LoadCredential = [
|
LoadCredential = [
|
||||||
"env-secrets:${cfg.secretFile}"
|
"env-secrets:${cfg.secretFile}"
|
||||||
@ -645,38 +653,36 @@ in
|
|||||||
cat "$CREDENTIALS_DIRECTORY/env-secrets" >> ${cfg.dataDir}/.env
|
cat "$CREDENTIALS_DIRECTORY/env-secrets" >> ${cfg.dataDir}/.env
|
||||||
|
|
||||||
# Link the static storage (package provided) to the runtime storage
|
# Link the static storage (package provided) to the runtime storage
|
||||||
# Necessary for cities.json and static images.
|
rsync -av --no-perms ${invoiceninja}/storage-static/ ${cfg.dataDir}/storage
|
||||||
rsync -av --no-perms ${invoice-ninja}/storage-static/ ${cfg.dataDir}/storage
|
|
||||||
|
|
||||||
# Link the static vendor/bin (package provided) to the runtime vendor/bin
|
# Link the static vendor/bin (package provided) to the runtime vendor/bin
|
||||||
# Necessary for cities.json and static images.
|
rsync -av --no-perms ${invoiceninja}/vendor/bin-static/ ${cfg.dataDir}/vendor/bin
|
||||||
rsync -av --no-perms ${invoice-ninja}/vendor/bin-static/ ${cfg.dataDir}/vendor/bin
|
|
||||||
|
|
||||||
# Link the app.php in the runtime folder.
|
# Link the app.php in the runtime folder.
|
||||||
# We cannot link the cache folder only because bootstrap folder needs to be writeable.
|
# We cannot link the cache folder only because bootstrap folder needs to be writeable.
|
||||||
ln -sf ${invoice-ninja}/bootstrap-static/app.php ${cfg.runtimeDir}/app.php
|
ln -sf ${invoiceninja}/bootstrap-static/app.php ${cfg.runtimeDir}/app.php
|
||||||
|
|
||||||
# Perform the first migration
|
# Perform the first migration
|
||||||
[[ ! -f ${cfg.dataDir}/.initial-migration ]] && invoice-ninja-manage migrate --force && touch ${cfg.dataDir}/.initial-migration
|
[[ ! -f ${cfg.dataDir}/.initial-migration ]] && invoiceninja-manage migrate --force && touch ${cfg.dataDir}/.initial-migration
|
||||||
|
|
||||||
# Seed database with records
|
# Seed database with records
|
||||||
# Necessary for languages, currencies, countries, etc.
|
# Necessary for languages, currencies, countries, etc.
|
||||||
[[ ! -f ${cfg.dataDir}/.db-seeded ]] && invoice-ninja-manage db:seed --force && touch ${cfg.dataDir}/.db-seeded
|
[[ ! -f ${cfg.dataDir}/.db-seeded ]] && invoiceninja-manage db:seed --force && touch ${cfg.dataDir}/.db-seeded
|
||||||
|
|
||||||
# Create Invoice Ninja admin account
|
# Create Invoice Ninja admin account
|
||||||
[[ (! -f ${cfg.dataDir}/.admin-created) && (${
|
[[ (! -f ${cfg.dataDir}/.admin-created) && (${
|
||||||
if cfg.adminAccount.createAdmin then "true" else "false"
|
if cfg.adminAccount.enable then "true" else "false"
|
||||||
} == "true") ]] \
|
} == "true") ]] \
|
||||||
&& invoice-ninja-manage ninja:create-account --email=${cfg.adminAccount.email} --password=$(cat $CREDENTIALS_DIRECTORY/admin-pass) \
|
&& invoiceninja-manage ninja:create-account --email=${cfg.adminAccount.email} --password=$(cat $CREDENTIALS_DIRECTORY/admin-pass) \
|
||||||
&& touch ${cfg.dataDir}/.admin-created
|
&& touch ${cfg.dataDir}/.admin-created
|
||||||
|
|
||||||
invoice-ninja-manage route:cache
|
invoiceninja-manage route:cache
|
||||||
invoice-ninja-manage view:cache
|
invoiceninja-manage view:cache
|
||||||
invoice-ninja-manage config:cache
|
invoiceninja-manage config:cache
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
systemd.tmpfiles.settings."10-invoice-ninja" =
|
systemd.tmpfiles.settings."10-invoiceninja" =
|
||||||
lib.attrsets.genAttrs
|
lib.attrsets.genAttrs
|
||||||
[
|
[
|
||||||
cfg.dataDir
|
cfg.dataDir
|
||||||
@ -3,12 +3,12 @@
|
|||||||
, openssl
|
, openssl
|
||||||
, writers
|
, writers
|
||||||
, fetchFromGitHub
|
, fetchFromGitHub
|
||||||
, dataDir ? "/var/lib/invoice-ninja"
|
, dataDir ? "/var/lib/invoiceninja"
|
||||||
, runtimeDir ? "/run/invoice-ninja"
|
, runtimeDir ? "/run/invoiceninja"
|
||||||
}:
|
}:
|
||||||
|
|
||||||
php.buildComposerProject (finalAttrs: {
|
php.buildComposerProject (finalAttrs: {
|
||||||
pname = "invoice-ninja";
|
pname = "invoiceninja";
|
||||||
version = "5.11.7";
|
version = "5.11.7";
|
||||||
|
|
||||||
src = fetchFromGitHub {
|
src = fetchFromGitHub {
|
||||||
@ -20,7 +20,6 @@ php.buildComposerProject (finalAttrs: {
|
|||||||
|
|
||||||
vendorHash = "sha256-RA7IkPXz1HdqQAyB/VIbYg3BmCnlJKLxIVtODIRmZxg=";
|
vendorHash = "sha256-RA7IkPXz1HdqQAyB/VIbYg3BmCnlJKLxIVtODIRmZxg=";
|
||||||
|
|
||||||
# Patch sources for more restrictive permissions
|
|
||||||
patches = [
|
patches = [
|
||||||
./disable-react-for-admin.patch
|
./disable-react-for-admin.patch
|
||||||
];
|
];
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user