forked from the-distro/channel-scripts
* Generate a NixOS channel (http://nixos.org/releases/nixos/channels/nixos-unstable/).
git-svn-id: https://nixos.org/repos/nix/release/trunk/channels@33728 70bd8c7a-acb8-0310-9f0d-9cc1c95dcdbb
This commit is contained in:
parent
d73ddef07c
commit
daab27d850
1 changed files with 23 additions and 20 deletions
|
@ -1,48 +1,51 @@
|
||||||
#! /bin/sh -e
|
#! /bin/sh -e
|
||||||
|
|
||||||
# This script downloads the latest NixOS ISO images from the "tested"
|
viewUrl=http://hydra.nixos.org/view/nixos/tested/latest-finished
|
||||||
# view in Hydra to $mirrorDir (http://nixos.org/releases/nixos).
|
releasesDir=/data/releases/nixos
|
||||||
|
channelLink=/data/releases/nixos/channels/nixos-unstable
|
||||||
curl="curl --silent --show-error --fail"
|
curl="curl --silent --show-error --fail"
|
||||||
wget="wget --no-verbose --content-disposition"
|
wget="wget --no-verbose --content-disposition"
|
||||||
|
|
||||||
mirrorDir=/data/releases/nixos
|
url=$($curl --head $viewUrl | sed 's/Location: \(.*\)\r/\1/; t; d')
|
||||||
|
|
||||||
url=$($curl --head http://hydra.nixos.org/view/nixos/tested/latest | sed 's/Location: \(.*\)\r/\1/; t; d')
|
|
||||||
|
|
||||||
if [ -z "$url" ]; then exit 1; fi
|
if [ -z "$url" ]; then exit 1; fi
|
||||||
|
|
||||||
echo "View page is $url"
|
echo "View page is $url"
|
||||||
|
|
||||||
release=$($curl $url | sed 's|<h1>View.*(<tt>\(.*\)</tt>.*|\1|; t; d')
|
release=$($curl $url | sed 's|<h1>View.*(<tt>\(.*\)</tt>.*|\1|; t; d')
|
||||||
|
|
||||||
if [ -z "$release" ]; then echo "Failed to get release"; exit 1; fi
|
if [ -z "$release" ]; then echo "Failed to get release"; exit 1; fi
|
||||||
|
|
||||||
echo "Release is $release"
|
echo "Release is $release"
|
||||||
|
|
||||||
releaseDir=$mirrorDir/$release
|
releaseDir=$releasesDir/$release
|
||||||
|
echo $releaseDir
|
||||||
|
|
||||||
if [ -d $releaseDir ]; then
|
if [ -d $releaseDir ]; then
|
||||||
echo "Release already exists"
|
echo "Release already exists"
|
||||||
else
|
else
|
||||||
|
tmpDir=$releasesDir/.tmp-$release-$$
|
||||||
tmpDir=$mirrorDir/.tmp-$release-$$
|
|
||||||
mkdir -p $tmpDir
|
mkdir -p $tmpDir
|
||||||
|
|
||||||
$wget --directory=$tmpDir $url/tarball/download
|
echo $url > $tmpDir/src-url
|
||||||
$wget --directory=$tmpDir $url/iso_minimal-i686-linux/download
|
|
||||||
$wget --directory=$tmpDir $url/iso_minimal-x86_64-linux/download
|
$wget --directory=$tmpDir $url/nixos.iso_minimal-i686-linux/download
|
||||||
$wget --directory=$tmpDir $url/iso_graphical-i686-linux/download
|
$wget --directory=$tmpDir $url/nixos.iso_minimal-x86_64-linux/download
|
||||||
$wget --directory=$tmpDir $url/iso_graphical-x86_64-linux/download
|
$wget --directory=$tmpDir $url/nixos.iso_graphical-i686-linux/download
|
||||||
|
$wget --directory=$tmpDir $url/nixos.iso_graphical-x86_64-linux/download
|
||||||
|
|
||||||
|
perl -w ./mirror-channel.pl "$url/eval/channel" "$tmpDir" \
|
||||||
|
/data/releases/nars http://nixos.org/releases/nars \
|
||||||
|
/data/releases/patches/all-patches "$url/nixos.channel/download/1"
|
||||||
|
|
||||||
mv $tmpDir $releaseDir
|
mv $tmpDir $releaseDir
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
#ln -sfn $release $mirrorDir/latest
|
htaccess=$(dirname $channelLink)/.htaccess
|
||||||
|
echo "Redirect /releases/nixos/channels/nixos-unstable http://nixos.org/releases/nixos/$release" > $htaccess.tmp
|
||||||
|
ln -sfn $releaseDir $channelLink # dummy symlink
|
||||||
|
mv $htaccess.tmp $htaccess
|
||||||
|
|
||||||
# Generate a .htaccess with some symbolic redirects to the latest version.
|
# Generate a .htaccess with some symbolic redirects to the latest ISOs.
|
||||||
htaccess=$mirrorDir/.htaccess
|
htaccess=$releasesDir/.htaccess
|
||||||
|
|
||||||
echo "Redirect /releases/nixos/latest http://nixos.org/releases/nixos/$release" > $htaccess.tmp
|
echo "Redirect /releases/nixos/latest http://nixos.org/releases/nixos/$release" > $htaccess.tmp
|
||||||
fn=$(cd $releaseDir && echo nixos-minimal-*-i686-linux.iso)
|
fn=$(cd $releaseDir && echo nixos-minimal-*-i686-linux.iso)
|
Loading…
Reference in a new issue