159 lines
5.7 KiB
Nix
159 lines
5.7 KiB
Nix
# SPDX-FileCopyrightText: 2022-2023 Gregor Kleen <gregor@kleen.consulting>, Sarah Vaupel <sarah.vaupel@uniworx.de>
|
|
#
|
|
# SPDX-License-Identifier: AGPL-3.0-or-later
|
|
|
|
{
|
|
inputs = {
|
|
haskell-nix = {
|
|
url = "github:input-output-hk/haskell.nix";
|
|
};
|
|
|
|
nixpkgs = {
|
|
type = "github";
|
|
owner = "NixOS";
|
|
repo = "nixpkgs";
|
|
# ref = "master";
|
|
ref = "283d622397539f196416657da9dc804a4ca89846";
|
|
};
|
|
flake-utils = {
|
|
type = "github";
|
|
owner = "numtide";
|
|
repo = "flake-utils";
|
|
ref = "main";
|
|
};
|
|
|
|
docker-nixpkgs = {
|
|
url = "github:nix-community/docker-nixpkgs";
|
|
flake = false;
|
|
};
|
|
|
|
encoding = {
|
|
url = "git+https://gitlab.ifi.lmu.de/uni2work/haskell/encoding.git?ref=uni2work";
|
|
flake = false;
|
|
};
|
|
memcached-binary = {
|
|
url = "git+https://gitlab.ifi.lmu.de/uni2work/haskell/memcached-binary.git?ref=uni2work";
|
|
flake = false;
|
|
};
|
|
conduit-resumablesink = {
|
|
url = "git+https://gitlab.ifi.lmu.de/uni2work/haskell/conduit-resumablesink.git?ref=uni2work";
|
|
flake = false;
|
|
};
|
|
HaskellNet-SSL = {
|
|
url = "git+https://gitlab.ifi.lmu.de/uni2work/haskell/HaskellNet-SSL.git?ref=uni2work";
|
|
flake = false;
|
|
};
|
|
ldap-client = {
|
|
url = "git+https://gitlab.ifi.lmu.de/uni2work/haskell/ldap-client.git?ref=uni2work";
|
|
flake = false;
|
|
};
|
|
serversession = {
|
|
url = "git+https://gitlab.ifi.lmu.de/uni2work/haskell/serversession.git?ref=uni2work";
|
|
flake = false;
|
|
};
|
|
xss-sanitize = {
|
|
url = "git+https://gitlab.ifi.lmu.de/uni2work/haskell/xss-sanitize.git?ref=uni2work";
|
|
flake = false;
|
|
};
|
|
colonnade = {
|
|
url = "git+https://gitlab.ifi.lmu.de/uni2work/haskell/colonnade.git?ref=uni2work";
|
|
flake = false;
|
|
};
|
|
minio-hs = {
|
|
url = "git+https://gitlab.ifi.lmu.de/uni2work/haskell/minio-hs.git?ref=uni2work";
|
|
flake = false;
|
|
};
|
|
cryptoids = {
|
|
url = "git+https://gitlab.ifi.lmu.de/uni2work/haskell/cryptoids.git?ref=uni2work";
|
|
flake = false;
|
|
};
|
|
zip-stream = {
|
|
url = "git+https://gitlab.ifi.lmu.de/uni2work/haskell/zip-stream.git?ref=uni2work";
|
|
flake = false;
|
|
};
|
|
yesod = {
|
|
url = "git+https://gitlab.ifi.lmu.de/uni2work/haskell/yesod.git?ref=uni2work";
|
|
flake = false;
|
|
};
|
|
cryptonite = {
|
|
url = "git+https://gitlab.ifi.lmu.de/uni2work/haskell/cryptonite.git?ref=uni2work";
|
|
flake = false;
|
|
};
|
|
esqueleto = {
|
|
url = "git+https://gitlab.ifi.lmu.de/uni2work/haskell/esqueleto.git?ref=uni2work";
|
|
flake = false;
|
|
};
|
|
};
|
|
|
|
outputs = inputs@{ self, nixpkgs, docker-nixpkgs, flake-utils, haskell-nix, ... }: flake-utils.lib.eachSystem ["x86_64-linux"]
|
|
(system:
|
|
let frontendSource = pkgs.lib.sourceByRegex ./. [
|
|
"^(assets|frontend)(/.*)?$"
|
|
"^config(/(favicon\.json|robots\.txt))?$"
|
|
"^(webpack|postcss)\.config\.js$"
|
|
"^karma\.conf\.js$"
|
|
"^(package|jsconfig|\.eslintrc)\.json$"
|
|
"^\.babelrc$"
|
|
];
|
|
|
|
backendSource = pkgs.lib.sourceByRegex ./. [
|
|
"^(\.hlint|package|stack-flake)\.yaml$"
|
|
"^stack\.yaml\.lock$"
|
|
"^config(/(archive-types|mimetypes|personalised-sheet-files-collate|settings\.yml|submission-blacklist|test-settings\.yml|video-types|wordlist\.txt))?$"
|
|
"^routes$"
|
|
"^(assets|app|hlint|load|messages|models|src|templates|test|testdata)(/.*)?$"
|
|
];
|
|
|
|
pkgs = import nixpkgs {
|
|
inherit system overlays;
|
|
config.allowUnfree = true;
|
|
};
|
|
|
|
overlays = [
|
|
(import "${docker-nixpkgs}/overlay.nix")
|
|
|
|
(import ./nix/maildev)
|
|
haskell-nix.overlay
|
|
(import ./nix/uniworx { inherit inputs frontendSource backendSource; gitRevision = if self ? rev then self.rev else null; })
|
|
(import ./nix/docker { inherit self; })
|
|
(import ./nix/parse-changelog.nix {})
|
|
];
|
|
|
|
haskellFlake = pkgs.uniworx.flake {};
|
|
|
|
mkPushDocker = imageName: dockerImage: pkgs.writeScriptBin "push-${dockerImage.imageName}" ''
|
|
#!${pkgs.zsh}/bin/zsh -xe
|
|
|
|
target=''${1-docker://registry.gitlab.com/fradrive/fradrive/${imageName}:${dockerImage.imageTag}}
|
|
[[ -n "''${1}" ]] && shift
|
|
${pkgs.skopeo}/bin/skopeo ''${@} --insecure-policy copy docker-archive://${dockerImage} ''${target}
|
|
'';
|
|
|
|
inherit (pkgs.lib) recursiveUpdate;
|
|
in {
|
|
packages = haskellFlake.packages // {
|
|
inherit (pkgs) uniworxNodeDependencies uniworxWellKnown uniworxFrontend uniworxDemoDocker uniworxDocker ciDocker changelogJson;
|
|
};
|
|
|
|
apps = haskellFlake.apps // {
|
|
pushUniworxDemoDocker = flake-utils.lib.mkApp { drv = mkPushDocker "uniworx-demo" pkgs.uniworxDemoDocker; };
|
|
pushUniworxDocker = flake-utils.lib.mkApp { drv = mkPushDocker "uniworx" pkgs.uniworxDocker; };
|
|
pushCIDocker = flake-utils.lib.mkApp { drv = mkPushDocker "nix-unstable" pkgs.ciDocker; };
|
|
calculateMaterializedSha = flake-utils.lib.mkApp { drv = pkgs.uniworx.stack-nix.passthru.calculateMaterializedSha; execPath = ""; };
|
|
jqChangelogJson = flake-utils.lib.mkApp { drv = pkgs.jqChangelogJson; };
|
|
};
|
|
|
|
checks = haskellFlake.checks // {
|
|
uniworxFrontend = pkgs.uniworxFrontend.check;
|
|
};
|
|
|
|
devShell = import ./shell.nix { pkgs = self.legacyPackages.${system}; nixpkgsPath = nixpkgs; };
|
|
|
|
legacyPackages = pkgs.lib.foldr (overlay: acc: acc // recursiveUpdate (overlay self.legacyPackages.${system} pkgs) pkgs) {} overlays;
|
|
|
|
defaultPackage = self.packages.${system}."uniworx:exe:uniworx";
|
|
defaultApp = self.apps.${system}."uniworx:exe:uniworx";
|
|
}
|
|
);
|
|
}
|