pkgs/update-from-hydra: Add script that updates paths based on hydra builds
This commit is contained in:
parent
491a4c2632
commit
b0259542e4
@ -106,6 +106,7 @@
|
|||||||
nixfiles-update-ssh-host-keys
|
nixfiles-update-ssh-host-keys
|
||||||
pyexcel-xlsx
|
pyexcel-xlsx
|
||||||
pyexcel-webio
|
pyexcel-webio
|
||||||
|
update-from-hydra
|
||||||
uptimestatus
|
uptimestatus
|
||||||
wetter;
|
wetter;
|
||||||
};
|
};
|
||||||
|
@ -13,6 +13,7 @@
|
|||||||
./monitoring
|
./monitoring
|
||||||
./nginx-port-forward
|
./nginx-port-forward
|
||||||
./nixfiles
|
./nixfiles
|
||||||
|
./update-from-hydra
|
||||||
./wg-clerie
|
./wg-clerie
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
95
modules/update-from-hydra/default.nix
Normal file
95
modules/update-from-hydra/default.nix
Normal file
@ -0,0 +1,95 @@
|
|||||||
|
{ config, lib, pkgs, ... }:
|
||||||
|
|
||||||
|
with lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
|
||||||
|
cfg = config.services.update-from-hydra;
|
||||||
|
|
||||||
|
repositoryOpts = { config, ... }@moduleAttrs: {
|
||||||
|
options = {
|
||||||
|
|
||||||
|
enable = mkEnableOption "Make a hydra build output availiable with a symlink and keep it up to date";
|
||||||
|
|
||||||
|
resultPath = mkOption {
|
||||||
|
type = types.path;
|
||||||
|
description = ''
|
||||||
|
Path to the symlink pointing to the hydra build output store path
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
hydraUrl = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
description = ''
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
hydraProject = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
description = ''
|
||||||
|
Hydra project name
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
hydraJobset = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
description = ''
|
||||||
|
Hydra jobset name
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
hydraJob = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
description = ''
|
||||||
|
Hydra job name
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
nixStoreUri = mkOption {
|
||||||
|
type = types.str;
|
||||||
|
description = ''
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
startAt = mkOption {
|
||||||
|
type = with types; either str (listOf str);
|
||||||
|
default = "hourly";
|
||||||
|
description = ''
|
||||||
|
How often the directory should be updated.
|
||||||
|
Formatspecified by `systemd.time 7`.
|
||||||
|
This value can also be a list of `systemd.time 7` formatted
|
||||||
|
strings, in which case the service will be started on multiple
|
||||||
|
schedules.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
in {
|
||||||
|
options = {
|
||||||
|
services.update-from-hydra = {
|
||||||
|
|
||||||
|
paths = mkOption {
|
||||||
|
type = with types; attrsOf (submodule repositoryOpts);
|
||||||
|
default = {};
|
||||||
|
};
|
||||||
|
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = {
|
||||||
|
systemd.services = (mapAttrs' (name: path: nameValuePair "update-from-hydra-${name}" (mkIf path.enable {
|
||||||
|
inherit (path) startAt;
|
||||||
|
|
||||||
|
wantedBy = [ "multi-user.target" ];
|
||||||
|
|
||||||
|
script = ''
|
||||||
|
${pkgs.update-from-hydra}/bin/update-from-hydra --hydra-url "${path.hydraUrl}" --hydra-project "${path.hydraProject}" --hydra-jobset "${path.hydraJobset}" --hydra-job "${path.hydraJob}" --nix-store-uri "${path.nixStoreUri}" --gcroot-name "${name}" "${path.resultPath}"
|
||||||
|
'';
|
||||||
|
})
|
||||||
|
) cfg.paths);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
|
@ -8,6 +8,7 @@ self: super: {
|
|||||||
nixfiles-update-ssh-host-keys = self.callPackage ./nixfiles/nixfiles-update-ssh-host-keys.nix {};
|
nixfiles-update-ssh-host-keys = self.callPackage ./nixfiles/nixfiles-update-ssh-host-keys.nix {};
|
||||||
pyexcel-xlsx = self.python3.pkgs.callPackage ./pyexcel-xlsx {};
|
pyexcel-xlsx = self.python3.pkgs.callPackage ./pyexcel-xlsx {};
|
||||||
pyexcel-webio = self.python3.pkgs.callPackage ./pyexcel-webio {};
|
pyexcel-webio = self.python3.pkgs.callPackage ./pyexcel-webio {};
|
||||||
|
update-from-hydra = self.callPackage ./update-from-hydra {};
|
||||||
uptimestatus = self.python3.pkgs.callPackage ./uptimestatus {};
|
uptimestatus = self.python3.pkgs.callPackage ./uptimestatus {};
|
||||||
wetter = self.python3.pkgs.callPackage ./wetter {
|
wetter = self.python3.pkgs.callPackage ./wetter {
|
||||||
inherit (self) pkg-config libsass;
|
inherit (self) pkg-config libsass;
|
||||||
|
12
pkgs/update-from-hydra/default.nix
Normal file
12
pkgs/update-from-hydra/default.nix
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
{ pkgs, ... }:
|
||||||
|
|
||||||
|
pkgs.writeShellApplication {
|
||||||
|
name = "update-from-hydra";
|
||||||
|
text = builtins.readFile ./update-from-hydra.sh;
|
||||||
|
runtimeInputs = with pkgs; [
|
||||||
|
curl
|
||||||
|
jq
|
||||||
|
nix
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
74
pkgs/update-from-hydra/update-from-hydra.sh
Normal file
74
pkgs/update-from-hydra/update-from-hydra.sh
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
while [[ $# -gt 0 ]]; do
|
||||||
|
case $1 in
|
||||||
|
--hydra-url)
|
||||||
|
HYDRA_URL="$2"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--hydra-project)
|
||||||
|
HYDRA_PROJECT="$2"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--hydra-jobset)
|
||||||
|
HYDRA_JOBSET="$2"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--hydra-job)
|
||||||
|
HYDRA_JOB="$2"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--nix-store-uri)
|
||||||
|
NIX_STORE_URI="$2"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--gcroot-name)
|
||||||
|
GCROOT_NAME="$2"
|
||||||
|
shift
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
-*)
|
||||||
|
echo "Unknown option $1"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
ARGS+=("$1")
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
set -- "${ARGS[@]}"
|
||||||
|
|
||||||
|
HYDRA_JOB_URL="${HYDRA_URL}/job/${HYDRA_PROJECT}/${HYDRA_JOBSET}/${HYDRA_JOB}/latest-finished"
|
||||||
|
RESULT_PATH="$1"
|
||||||
|
|
||||||
|
echo "Updating ${RESULT_PATH} from ${HYDRA_PROJECT}:${HYDRA_JOBSET}:${HYDRA_JOB}"
|
||||||
|
|
||||||
|
echo "Make sure symlink directory exist"
|
||||||
|
mkdir -p "$(dirname "${RESULT_PATH}")"
|
||||||
|
|
||||||
|
echo "Fetching job output"
|
||||||
|
STORE_PATH="$(curl -s -L -H "Accept: application/json" "${HYDRA_JOB_URL}" | jq -r .buildoutputs.out.path)"
|
||||||
|
|
||||||
|
echo "Copying path"
|
||||||
|
nix copy --from "${NIX_STORE_URI}" "${STORE_PATH}"
|
||||||
|
|
||||||
|
echo "Activate path"
|
||||||
|
ln -fsn "${STORE_PATH}" "${RESULT_PATH}"
|
||||||
|
|
||||||
|
if [[ -n $GCROOT_NAME ]]; then
|
||||||
|
GCROOT_PATH="/nix/var/nix/gcroots/update-from-hydra/${GCROOT_NAME}"
|
||||||
|
echo "Add to gcroot ${GCROOT_PATH}"
|
||||||
|
mkdir -p "$(dirname "${GCROOT_PATH}")"
|
||||||
|
|
||||||
|
ln -fsn "${RESULT_PATH}" "${GCROOT_PATH}"
|
||||||
|
fi
|
||||||
|
|
Loading…
Reference in New Issue
Block a user