From 9abdb75d46abd8346510f71f23b546b62ec58e4b Mon Sep 17 00:00:00 2001 From: Stefan Karpinski Date: Sat, 12 Oct 2019 17:58:59 -0400 Subject: [PATCH] use Pkg protocol to get artifacts --- src/Artifacts.jl | 18 ++++++++++++++++-- src/Operations.jl | 9 ++------- src/Pkg.jl | 5 +++++ src/PlatformEngines.jl | 14 +++++++------- 4 files changed, 30 insertions(+), 16 deletions(-) diff --git a/src/Artifacts.jl b/src/Artifacts.jl index 4d6a15899f..3ca9a6ac27 100644 --- a/src/Artifacts.jl +++ b/src/Artifacts.jl @@ -6,6 +6,7 @@ import ..GitTools using ..BinaryPlatforms import ..TOML import ..Types: parse_toml, write_env_usage +import ...Pkg: pkg_server using ..PlatformEngines using SHA @@ -667,8 +668,12 @@ end Download/install an artifact into the artifact store. Returns `true` on success. """ -function download_artifact(tree_hash::SHA1, tarball_url::String, tarball_hash::String; - verbose::Bool = false) +function download_artifact( + tree_hash::SHA1, + tarball_url::String, + tarball_hash::Union{String, Nothing} = nothing; + verbose::Bool = false, +) if artifact_exists(tree_hash) return true end @@ -793,6 +798,15 @@ function ensure_artifact_installed(name::String, meta::Dict, artifacts_toml::Str hash = SHA1(meta["git-tree-sha1"]) if !artifact_exists(hash) + # first try downloading from Pkg server + # TODO: only do this if Pkg server knows about this package + if (server = pkg_server()) !== nothing + url = "$server/artifact/$hash" + if download_artifact(hash, url) + return artifact_path(hash) + end + end + # If this artifact does not exist on-disk already, ensure it has download # information, then download it! if !haskey(meta, "download") diff --git a/src/Operations.jl b/src/Operations.jl index 5efaf3f8be..5f31595175 100644 --- a/src/Operations.jl +++ b/src/Operations.jl @@ -12,8 +12,8 @@ using ..Types, ..Resolve, ..PlatformEngines, ..GitTools, ..Display import ..depots, ..depots1, ..devdir, ..set_readonly, ..Types.PackageEntry import ..Artifacts: ensure_all_artifacts_installed, artifact_names, extract_all_hashes, artifact_exists using ..BinaryPlatforms -import ..Pkg - +import ...Pkg +import ...Pkg: pkg_server ######### # Utils # @@ -445,11 +445,6 @@ end # Package installation # ######################## -function pkg_server() - server = get(ENV, "JULIA_PKG_SERVER", "127.0.0.1") - return isempty(server) ? nothing : "http://$server:8000" -end - function get_archive_url_for_version(url::String, ref) if (m = match(r"https://github.com/(.*?)/(.*?).git", url)) != nothing return "https://api.github.com/repos/$(m.captures[1])/$(m.captures[2])/tarball/$(ref)" diff --git a/src/Pkg.jl b/src/Pkg.jl index f0d0f33ff1..72be65f3e8 100644 --- a/src/Pkg.jl +++ b/src/Pkg.jl @@ -19,6 +19,11 @@ function depots1() return d[1] end +function pkg_server() + server = get(ENV, "JULIA_PKG_SERVER", "127.0.0.1") + return isempty(server) ? nothing : "http://$server:8000" +end + logdir(depot = depots1()) = joinpath(depot, "logs") devdir(depot = depots1()) = get(ENV, "JULIA_PKG_DEVDIR", joinpath(depots1(), "dev")) envdir(depot = depots1()) = joinpath(depot, "environments") diff --git a/src/PlatformEngines.jl b/src/PlatformEngines.jl index 2e510e9adb..b4f77f9dda 100644 --- a/src/PlatformEngines.jl +++ b/src/PlatformEngines.jl @@ -593,7 +593,7 @@ function download(url::AbstractString, dest::AbstractString; end """ - download_verify(url::AbstractString, hash::AbstractString, + download_verify(url::AbstractString, hash::Union{AbstractString, Nothing}, dest::AbstractString; verbose::Bool = false, force::Bool = false, quiet_download::Bool = false) @@ -614,7 +614,7 @@ set to `false`) the downloading process will be completely silent. If `verbose` is set to `true`, messages about integrity verification will be printed in addition to messages regarding downloading. """ -function download_verify(url::AbstractString, hash::AbstractString, +function download_verify(url::AbstractString, hash::Union{AbstractString, Nothing}, dest::AbstractString; verbose::Bool = false, force::Bool = false, quiet_download::Bool = true) # Whether the file existed in the first place @@ -628,7 +628,7 @@ function download_verify(url::AbstractString, hash::AbstractString, # verify download, if it passes, return happy. If it fails, (and # `force` is `true`, re-download!) - if verify(dest, hash; verbose=verbose) + if hash !== nothing && verify(dest, hash; verbose=verbose) return true elseif !force error("Verification failed, not overwriting $(dest)") @@ -640,7 +640,7 @@ function download_verify(url::AbstractString, hash::AbstractString, # Download the file, optionally continuing download(url, dest; verbose=verbose || !quiet_download) - if !verify(dest, hash; verbose=verbose) + if hash !== nothing && !verify(dest, hash; verbose=verbose) # If the file already existed, it's possible the initially downloaded chunk # was bad. If verification fails after downloading, auto-delete the file # and start over from scratch. @@ -652,7 +652,7 @@ function download_verify(url::AbstractString, hash::AbstractString, # Download and verify from scratch download(url, dest; verbose=verbose || !quiet_download) - if !verify(dest, hash; verbose=verbose) + if hash !== nothing && !verify(dest, hash; verbose=verbose) error("Verification failed") end else @@ -790,7 +790,7 @@ function package(src_dir::AbstractString, tarball_path::AbstractString) end """ - download_verify_unpack(url::AbstractString, hash::AbstractString, + download_verify_unpack(url::AbstractString, hash::Union{AbstractString, Nothing}, dest::AbstractString; tarball_path = nothing, verbose::Bool = false, ignore_existence::Bool = false, force::Bool = false) @@ -819,7 +819,7 @@ Returns `true` if a tarball was actually unpacked, `false` if nothing was changed in the destination prefix. """ function download_verify_unpack(url::AbstractString, - hash::AbstractString, + hash::Union{AbstractString, Nothing}, dest::AbstractString; tarball_path = nothing, ignore_existence::Bool = false,