diff options
Diffstat (limited to 'nixpkgs/pkgs/servers/http/unit/default.nix')
-rw-r--r-- | nixpkgs/pkgs/servers/http/unit/default.nix | 85 |
1 files changed, 85 insertions, 0 deletions
diff --git a/nixpkgs/pkgs/servers/http/unit/default.nix b/nixpkgs/pkgs/servers/http/unit/default.nix new file mode 100644 index 000000000000..c77428688da5 --- /dev/null +++ b/nixpkgs/pkgs/servers/http/unit/default.nix @@ -0,0 +1,85 @@ +{ lib, stdenv, fetchFromGitHub, nixosTests, which +, pcre2 +, withPython3 ? true, python3, ncurses +, withPHP81 ? true, php81 +, withPHP82 ? false, php82 +, withPerl536 ? false, perl536 +, withPerl538 ? true, perl538 +, withRuby_3_1 ? true, ruby_3_1 +, withRuby_3_2 ? false, ruby_3_2 +, withSSL ? true, openssl ? null +, withIPv6 ? true +, withDebug ? false +}: + +with lib; + +let + phpConfig = { + embedSupport = true; + apxs2Support = false; + systemdSupport = false; + phpdbgSupport = false; + cgiSupport = false; + fpmSupport = false; + }; + + php81-unit = php81.override phpConfig; + php82-unit = php82.override phpConfig; + +in stdenv.mkDerivation rec { + version = "1.32.0"; + pname = "unit"; + + src = fetchFromGitHub { + owner = "nginx"; + repo = pname; + rev = version; + sha256 = "sha256-u693Q6Gp8lFm3DX1q5i6W021bxD962NGBGDRxUtvGrk="; + }; + + nativeBuildInputs = [ which ]; + + buildInputs = [ pcre2.dev ] + ++ optionals withPython3 [ python3 ncurses ] + ++ optional withPHP81 php81-unit + ++ optional withPHP82 php82-unit + ++ optional withPerl536 perl536 + ++ optional withPerl538 perl538 + ++ optional withRuby_3_1 ruby_3_1 + ++ optional withRuby_3_2 ruby_3_2 + ++ optional withSSL openssl; + + configureFlags = [ + "--control=unix:/run/unit/control.unit.sock" + "--pid=/run/unit/unit.pid" + "--user=unit" + "--group=unit" + ] ++ optional withSSL "--openssl" + ++ optional (!withIPv6) "--no-ipv6" + ++ optional withDebug "--debug"; + + # Optionally add the PHP derivations used so they can be addressed in the configs + usedPhp81 = optionals withPHP81 php81-unit; + + postConfigure = '' + ${optionalString withPython3 "./configure python --module=python3 --config=python3-config --lib-path=${python3}/lib"} + ${optionalString withPHP81 "./configure php --module=php81 --config=${php81-unit.unwrapped.dev}/bin/php-config --lib-path=${php81-unit}/lib"} + ${optionalString withPHP82 "./configure php --module=php81 --config=${php82-unit.unwrapped.dev}/bin/php-config --lib-path=${php82-unit}/lib"} + ${optionalString withPerl536 "./configure perl --module=perl536 --perl=${perl536}/bin/perl"} + ${optionalString withPerl538 "./configure perl --module=perl538 --perl=${perl538}/bin/perl"} + ${optionalString withRuby_3_1 "./configure ruby --module=ruby31 --ruby=${ruby_3_1}/bin/ruby"} + ${optionalString withRuby_3_2 "./configure ruby --module=ruby32 --ruby=${ruby_3_2}/bin/ruby"} + ''; + + passthru.tests.unit-php = nixosTests.unit-php; + + meta = { + description = "Dynamic web and application server, designed to run applications in multiple languages"; + mainProgram = "unitd"; + homepage = "https://unit.nginx.org/"; + license = licenses.asl20; + platforms = platforms.linux; + maintainers = with maintainers; [ izorkin ]; + }; +} |