2024-05-15 15:35:15 +00:00
|
|
|
{
|
|
|
|
callPackage,
|
|
|
|
fetchFromGitHub,
|
|
|
|
nixos,
|
|
|
|
conmon,
|
2023-02-09 11:40:11 +00:00
|
|
|
}:
|
|
|
|
let
|
2024-05-15 15:35:15 +00:00
|
|
|
apptainer =
|
|
|
|
callPackage
|
|
|
|
(import ./generic.nix rec {
|
|
|
|
pname = "apptainer";
|
2024-09-19 14:19:46 +00:00
|
|
|
version = "1.3.4";
|
2024-05-15 15:35:15 +00:00
|
|
|
projectName = "apptainer";
|
2023-02-09 11:40:11 +00:00
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "apptainer";
|
|
|
|
repo = "apptainer";
|
|
|
|
rev = "refs/tags/v${version}";
|
2024-09-19 14:19:46 +00:00
|
|
|
hash = "sha256-eByF0OpL1OKGq0wY7kw8Sv9sZuVE0K3TGIm4Chk9PC4=";
|
2024-05-15 15:35:15 +00:00
|
|
|
};
|
2023-02-09 11:40:11 +00:00
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
# Update by running
|
|
|
|
# nix-prefetch -E "{ sha256 }: ((import ./. { }).apptainer.override { vendorHash = sha256; }).goModules"
|
|
|
|
# at the root directory of the Nixpkgs repository
|
2024-06-05 15:53:02 +00:00
|
|
|
vendorHash = "sha256-W853++SSvkAYYUczbl8vnoBQZnimUdsAEXp4MCkLPBU=";
|
2023-02-09 11:40:11 +00:00
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
extraDescription = " (previously known as Singularity)";
|
|
|
|
extraMeta.homepage = "https://apptainer.org";
|
|
|
|
})
|
|
|
|
{
|
|
|
|
# Apptainer doesn't depend on conmon
|
|
|
|
conmon = null;
|
2023-02-09 11:40:11 +00:00
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
# Apptainer builders require explicit --with-suid / --without-suid flag
|
|
|
|
# when building on a system with disabled unprivileged namespace.
|
|
|
|
# See https://github.com/NixOS/nixpkgs/pull/215690#issuecomment-1426954601
|
|
|
|
defaultToSuid = null;
|
2024-06-05 15:53:02 +00:00
|
|
|
|
|
|
|
sourceFilesWithDefaultPaths = {
|
|
|
|
"cmd/internal/cli/actions.go" = [ "/bin:/usr/bin:/sbin:/usr/sbin:/usr/local/bin:/usr/local/sbin" ];
|
|
|
|
"e2e/env/env.go" = [ "/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin" ];
|
|
|
|
"internal/pkg/util/env/env.go" = [ "/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin" ];
|
|
|
|
};
|
2024-05-15 15:35:15 +00:00
|
|
|
};
|
2023-02-09 11:40:11 +00:00
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
singularity =
|
|
|
|
callPackage
|
|
|
|
(import ./generic.nix rec {
|
|
|
|
pname = "singularity-ce";
|
2024-09-19 14:19:46 +00:00
|
|
|
version = "4.2.1";
|
2024-05-15 15:35:15 +00:00
|
|
|
projectName = "singularity";
|
2023-02-09 11:40:11 +00:00
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "sylabs";
|
|
|
|
repo = "singularity";
|
|
|
|
rev = "refs/tags/v${version}";
|
2024-09-19 14:19:46 +00:00
|
|
|
hash = "sha256-Go4um/bIgq2lCZvjJ2GR81XpA/JvjPholi1PzNG9Hz8=";
|
2024-05-15 15:35:15 +00:00
|
|
|
};
|
2023-02-09 11:40:11 +00:00
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
# Update by running
|
|
|
|
# nix-prefetch -E "{ sha256 }: ((import ./. { }).singularity.override { vendorHash = sha256; }).goModules"
|
|
|
|
# at the root directory of the Nixpkgs repository
|
2024-09-19 14:19:46 +00:00
|
|
|
vendorHash = "sha256-CRZ42NdmJhAkV6bkl5n7rEV4Tu/h65qF5qaQ4W5wQ3w=";
|
2023-02-09 11:40:11 +00:00
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
# Do not build conmon and squashfuse from the Git submodule sources,
|
|
|
|
# Use Nixpkgs provided version
|
|
|
|
extraConfigureFlags = [
|
|
|
|
"--without-conmon"
|
|
|
|
"--without-squashfuse"
|
|
|
|
];
|
2023-02-09 11:40:11 +00:00
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
extraDescription = " (Sylabs Inc's fork of Singularity, a.k.a. SingularityCE)";
|
|
|
|
extraMeta.homepage = "https://sylabs.io/";
|
|
|
|
})
|
|
|
|
{
|
|
|
|
# Sylabs SingularityCE builders defaults to set the SUID flag
|
|
|
|
# on UNIX-like platforms,
|
|
|
|
# and only have --without-suid but not --with-suid.
|
|
|
|
defaultToSuid = true;
|
2024-06-05 15:53:02 +00:00
|
|
|
|
|
|
|
sourceFilesWithDefaultPaths = {
|
|
|
|
"cmd/internal/cli/actions.go" = [ "/bin:/usr/bin:/sbin:/usr/sbin:/usr/local/bin:/usr/local/sbin" ];
|
|
|
|
"e2e/env/env.go" = [ "/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin" ];
|
|
|
|
"internal/pkg/util/env/clean.go" = [
|
|
|
|
"/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
|
|
|
|
];
|
|
|
|
};
|
2024-05-15 15:35:15 +00:00
|
|
|
};
|
2023-02-09 11:40:11 +00:00
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
genOverridenNixos =
|
|
|
|
package: packageName:
|
|
|
|
(nixos {
|
|
|
|
programs.singularity = {
|
|
|
|
enable = true;
|
|
|
|
inherit package;
|
|
|
|
};
|
|
|
|
}).config.programs.singularity.packageOverriden.overrideAttrs
|
|
|
|
(oldAttrs: {
|
|
|
|
meta = oldAttrs.meta // {
|
|
|
|
description = "";
|
|
|
|
longDescription = ''
|
|
|
|
This package produces identical store derivations to `pkgs.${packageName}`
|
|
|
|
overriden and installed by the NixOS module `programs.singularity`
|
|
|
|
with default configuration.
|
2023-02-09 11:40:11 +00:00
|
|
|
|
2024-05-15 15:35:15 +00:00
|
|
|
This is for binary substitutes only. Use pkgs.${packageName} instead.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
});
|
2023-02-09 11:40:11 +00:00
|
|
|
in
|
|
|
|
{
|
|
|
|
inherit apptainer singularity;
|
|
|
|
|
|
|
|
apptainer-overriden-nixos = genOverridenNixos apptainer "apptainer";
|
|
|
|
singularity-overriden-nixos = genOverridenNixos singularity "singularity";
|
|
|
|
}
|