mirror of
https://github.com/NixOS/nixpkgs.git
synced 2024-12-15 18:23:09 +00:00
61 lines
1.4 KiB
Nix
61 lines
1.4 KiB
Nix
{ lib, stdenv, fetchurl, perl
|
|
# Update the enabled crypt scheme ids in passthru when the enabled hashes change
|
|
, enableHashes ? "strong"
|
|
, nixosTests
|
|
}:
|
|
|
|
stdenv.mkDerivation rec {
|
|
pname = "libxcrypt";
|
|
version = "4.4.33";
|
|
|
|
src = fetchurl {
|
|
url = "https://github.com/besser82/libxcrypt/releases/download/v${version}/libxcrypt-${version}.tar.xz";
|
|
hash = "sha256-6HrPnGUsVzpHE9VYIVn5jzBdVu1fdUzmT1fUGU1rOm8=";
|
|
};
|
|
|
|
outputs = [
|
|
"out"
|
|
"man"
|
|
];
|
|
|
|
configureFlags = [
|
|
"--enable-hashes=${enableHashes}"
|
|
"--enable-obsolete-api=glibc"
|
|
"--disable-failure-tokens"
|
|
] ++ lib.optionals (stdenv.hostPlatform.isMusl || stdenv.hostPlatform.libc == "bionic") [
|
|
"--disable-werror"
|
|
];
|
|
|
|
nativeBuildInputs = [
|
|
perl
|
|
];
|
|
|
|
enableParallelBuilding = true;
|
|
|
|
doCheck = true;
|
|
|
|
passthru = {
|
|
tests = {
|
|
inherit (nixosTests) login shadow;
|
|
};
|
|
enabledCryptSchemeIds = [
|
|
# https://github.com/besser82/libxcrypt/blob/v4.4.33/lib/hashes.conf
|
|
"y" # yescrypt
|
|
"gy" # gost_yescrypt
|
|
"7" # scrypt
|
|
"2b" # bcrypt
|
|
"2y" # bcrypt_y
|
|
"2a" # bcrypt_a
|
|
"6" # sha512crypt
|
|
];
|
|
};
|
|
|
|
meta = with lib; {
|
|
description = "Extended crypt library for descrypt, md5crypt, bcrypt, and others";
|
|
homepage = "https://github.com/besser82/libxcrypt/";
|
|
platforms = platforms.all;
|
|
maintainers = with maintainers; [ dottedmag hexa ];
|
|
license = licenses.lgpl21Plus;
|
|
};
|
|
}
|