forked from lix-project/hydra
Proxy local binary caches via hydra-server
This commit is contained in:
parent
b9afaadfb3
commit
9de336de7c
1 changed files with 68 additions and 26 deletions
|
@ -257,48 +257,90 @@ sub serialize : ActionClass('Serialize') { }
|
||||||
sub nar :Local :Args(1) {
|
sub nar :Local :Args(1) {
|
||||||
my ($self, $c, $path) = @_;
|
my ($self, $c, $path) = @_;
|
||||||
|
|
||||||
$path = ($ENV{NIX_STORE_DIR} || "/nix/store")."/$path";
|
die if $path =~ /\//;
|
||||||
|
|
||||||
gone($c, "Path " . $path . " is no longer available.") unless isValidPath($path);
|
my $storeMode = $c->config->{store_mode} // "direct";
|
||||||
|
|
||||||
$c->stash->{current_view} = 'NixNAR';
|
if ($storeMode eq "s3-binary-cache") {
|
||||||
$c->stash->{storePath} = $path;
|
notFound($c, "There is no binary cache here.");
|
||||||
|
}
|
||||||
|
|
||||||
|
elsif ($storeMode eq "local-binary-cache") {
|
||||||
|
my $dir = $c->config->{binary_cache_dir};
|
||||||
|
$c->serve_static_file($dir . "/nar/" . $path);
|
||||||
|
}
|
||||||
|
|
||||||
|
else {
|
||||||
|
$path = $Nix::Config::storeDir . "/$path";
|
||||||
|
|
||||||
|
gone($c, "Path " . $path . " is no longer available.") unless isValidPath($path);
|
||||||
|
|
||||||
|
$c->stash->{current_view} = 'NixNAR';
|
||||||
|
$c->stash->{storePath} = $path;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
sub nix_cache_info :Path('nix-cache-info') :Args(0) {
|
sub nix_cache_info :Path('nix-cache-info') :Args(0) {
|
||||||
my ($self, $c) = @_;
|
my ($self, $c) = @_;
|
||||||
$c->response->content_type('text/plain');
|
|
||||||
$c->stash->{plain}->{data} =
|
my $storeMode = $c->config->{store_mode} // "direct";
|
||||||
#"StoreDir: $Nix::Config::storeDir\n" . # FIXME
|
|
||||||
"StoreDir: " . ($ENV{NIX_STORE_DIR} || "/nix/store") . "\n" .
|
if ($storeMode eq "s3-binary-cache") {
|
||||||
"WantMassQuery: 0\n" .
|
notFound($c, "There is no binary cache here.");
|
||||||
# Give Hydra binary caches a very low priority (lower than the
|
}
|
||||||
# static binary cache http://nixos.org/binary-cache).
|
|
||||||
"Priority: 100\n";
|
elsif ($storeMode eq "local-binary-cache") {
|
||||||
setCacheHeaders($c, 24 * 60 * 60);
|
my $dir = $c->config->{binary_cache_dir};
|
||||||
$c->forward('Hydra::View::Plain');
|
$c->serve_static_file($dir . "/nix-cache-info");
|
||||||
|
}
|
||||||
|
|
||||||
|
else {
|
||||||
|
$c->response->content_type('text/plain');
|
||||||
|
$c->stash->{plain}->{data} =
|
||||||
|
"StoreDir: $Nix::Config::storeDir\n" .
|
||||||
|
"WantMassQuery: 0\n" .
|
||||||
|
# Give Hydra binary caches a very low priority (lower than the
|
||||||
|
# static binary cache http://nixos.org/binary-cache).
|
||||||
|
"Priority: 100\n";
|
||||||
|
setCacheHeaders($c, 24 * 60 * 60);
|
||||||
|
$c->forward('Hydra::View::Plain');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
sub narinfo :LocalRegex('^([a-z0-9]+).narinfo$') :Args(0) {
|
sub narinfo :LocalRegex('^([a-z0-9]+).narinfo$') :Args(0) {
|
||||||
my ($self, $c) = @_;
|
my ($self, $c) = @_;
|
||||||
my $hash = $c->req->captures->[0];
|
|
||||||
|
|
||||||
die if length($hash) != 32;
|
my $storeMode = $c->config->{store_mode} // "direct";
|
||||||
my $path = queryPathFromHashPart($hash);
|
|
||||||
|
|
||||||
if (!$path) {
|
if ($storeMode eq "s3-binary-cache") {
|
||||||
$c->response->status(404);
|
notFound($c, "There is no binary cache here.");
|
||||||
$c->response->content_type('text/plain');
|
|
||||||
$c->stash->{plain}->{data} = "does not exist\n";
|
|
||||||
$c->forward('Hydra::View::Plain');
|
|
||||||
setCacheHeaders($c, 60 * 60);
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$c->stash->{storePath} = $path;
|
elsif ($storeMode eq "local-binary-cache") {
|
||||||
$c->forward('Hydra::View::NARInfo');
|
my $dir = $c->config->{binary_cache_dir};
|
||||||
|
$c->serve_static_file($dir . "/" . $c->req->captures->[0] . ".narinfo");
|
||||||
|
}
|
||||||
|
|
||||||
|
else {
|
||||||
|
my $hash = $c->req->captures->[0];
|
||||||
|
|
||||||
|
die if length($hash) != 32;
|
||||||
|
my $path = queryPathFromHashPart($hash);
|
||||||
|
|
||||||
|
if (!$path) {
|
||||||
|
$c->response->status(404);
|
||||||
|
$c->response->content_type('text/plain');
|
||||||
|
$c->stash->{plain}->{data} = "does not exist\n";
|
||||||
|
$c->forward('Hydra::View::Plain');
|
||||||
|
setCacheHeaders($c, 60 * 60);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$c->stash->{storePath} = $path;
|
||||||
|
$c->forward('Hydra::View::NARInfo');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue