Skip to content

Instantly share code, notes, and snippets.

@htuscher
Created April 25, 2023 08:24
Show Gist options
  • Save htuscher/6f85e053a2a8b128d427d81ee9e4617f to your computer and use it in GitHub Desktop.
Save htuscher/6f85e053a2a8b128d427d81ee9e4617f to your computer and use it in GitHub Desktop.
Devenv Permission issues
{ pkgs, lib, config, ... }:
{
certificates = [
"shopware.dev"
];
hosts."shopware.dev" = "127.0.0.1";
packages = [
pkgs.gnupatch
pkgs.nodePackages_latest.yalc
pkgs.gnused
pkgs.symfony-cli
pkgs.deno
];
languages.javascript = {
enable = lib.mkDefault true;
package = lib.mkDefault pkgs.nodejs-18_x;
};
languages.php = {
enable = lib.mkDefault true;
version = lib.mkDefault "8.1";
extensions = [ "grpc" "amqp" "xsl" ];
ini = ''
memory_limit = 2G
realpath_cache_ttl = 3600
session.gc_probability = 0
${lib.optionalString config.services.redis.enable ''
session.save_handler = redis
session.save_path = "tcp://127.0.0.1:6379/0"
''}
display_errors = On
error_reporting = E_ALL
assert.active = 0
opcache.memory_consumption = 256M
opcache.interned_strings_buffer = 20
zend.assertions = 0
short_open_tag = 0
zend.detect_unicode = 0
realpath_cache_ttl = 3600
'';
fpm.pools.web = lib.mkDefault {
settings = {
"clear_env" = "no";
"pm" = "dynamic";
"pm.max_children" = 10;
"pm.start_servers" = 2;
"pm.min_spare_servers" = 1;
"pm.max_spare_servers" = 10;
};
};
};
services.caddy = {
enable = lib.mkDefault true;
virtualHosts."shopware.dev" = lib.mkDefault {
extraConfig = lib.mkDefault ''
tls ${config.env.DEVENV_STATE}/mkcert/shopware.dev.pem ${config.env.DEVENV_STATE}/mkcert/shopware.dev-key.pem
@default {
not path /theme/* /media/* /thumbnail/* /bundles/* /css/* /fonts/* /js/* /sitemap/*
}
root * public
php_fastcgi @default unix/${config.languages.php.fpm.pools.web.socket} {
trusted_proxies private_ranges
}
file_server
'';
};
};
services.mysql = {
enable = true;
initialDatabases = lib.mkDefault [{ name = "shopware"; }];
ensureUsers = lib.mkDefault [
{
name = "shopware";
password = "shopware";
ensurePermissions = {
"shopware.*" = "ALL PRIVILEGES";
"shopware_test.*" = "ALL PRIVILEGES";
"*.*" = "ALL PRIVILEGES"; # FIXME workaround to be able to manually remove ONLY_FULL_GROUP_BY from sql_mode
};
}
];
settings = {
mysqld = {
log_bin_trust_function_creators = 1;
sql_mode = "STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION";
};
};
};
services.redis.enable = lib.mkDefault true;
services.adminer.enable = lib.mkDefault false;
services.adminer.listen = lib.mkDefault "127.0.0.1:9080";
services.mailhog.enable = lib.mkDefault true;
services.elasticsearch.enable = true;
services.rabbitmq.enable = false;
services.rabbitmq.managementPlugin.enable = true;
# Environment variables
env.APP_URL = lib.mkDefault "https://shopware.dev";
env.APP_SECRET = lib.mkDefault "devsecret";
env.DATABASE_URL = lib.mkDefault "mysql://root@localhost:3306/shopware";
env.MAILER_DSN = lib.mkDefault "smtp://localhost:1025";
# General cypress
env.CYPRESS_baseUrl = lib.mkDefault "https://shopware.dev";
# Installer/Updater testing
env.INSTALL_URL = lib.mkDefault "http://localhost:8050";
env.CYPRESS_dbHost = lib.mkDefault "localhost";
env.CYPRESS_dbUser = lib.mkDefault "shopware";
env.CYPRESS_dbPassword = lib.mkDefault "shopware";
env.CYPRESS_dbName = lib.mkDefault "shopware";
scripts.build-updater.exec = ''
${pkgs.phpPackages.box}/bin/box compile -d src/WebInstaller
mv src/WebInstaller/shopware-installer.phar.php shop/public/shopware-installer.phar.php
'';
# Try to solve permission issue
scripts.caddy-setcap.exec = ''
sudo setcap 'cap_net_bind_service=+ep' ${pkgs.caddy}/bin/caddy
'';
scripts.watch-updater.exec = "${pkgs.watchexec}/bin/watchexec -i src/WebInstaller/shopware-installer.phar.php -eyaml,php,js build-updater";
}
allowUnfree: true
inputs:
nixpkgs:
url: github:NixOS/nixpkgs/staging-next
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment