Skip to content

Latest commit

 

History

History
111 lines (82 loc) · 3.32 KB

README.md

File metadata and controls

111 lines (82 loc) · 3.32 KB

Vcpkg Http Cache

This project provides a minimal PHP script to be used as a server backend for the vcpkg binary caching HTTP module or vcpkg asset caching. The cache is meant to be public, e.g., no authentication to download files is implemented. However, writing to the cache requires a configured secret, e.g., to be used by specific trusted CI Jobs to fill the cache. Cache cleanup still needs to be implemented. Currently, all files are stored infinitely.

Usage with Binary Caching

For full details, refer to the vcpkg binary caching documentation.

Read

Set the environment variable VCPKG_BINARY_SOURCES to clear;http,https://example.com/{triplet}-{name}-{sha},read.

Write

Set the environment variable VCPKG_BINARY_SOURCES to clear;http,https://example.com/{triplet}-{name}-{sha},readwrite,Authorization: Token supersecrettoken.

Usage with Asset Caching

Vcpkg asset caching does currently not directly support an HTTP backend. However, it is possible to use custom asset provider scripts. So, we can implement an HTTP provider using a CMake script. For more details, refer to the vcpkg asset caching documentation.

Classic Mode Example

Preconditions: CMake must be installed and available in PATH. At least version 3.18 is required.

X_VCPKG_ASSET_SOURCES="x-script,cmake -DURL={url} -DSHA512={sha512} -DDST={dst} -P /path/to/vcpkg_asset_cache_http.cmake;x-block-origin" ./vcpkg install zlib

Manifest Mode Example

Add to CMake:

set(ENV{X_VCPKG_ASSET_SOURCES} "x-script,${CMAKE_COMMAND} -DURL={url} -DSHA512={sha512} -DDST={dst} -P /path/to/vcpkg_asset_cache_http.cmake;x-block-origin")

Read and Write

By default, the script is in read-only mode. To enable read and write, additionally set the environment variable ASSET_UPLOAD_TOKEN to the authentication secret.

The CMake Script

Store as vcpkg_asset_cache_http.cmake:

cmake_minimum_required(VERSION 3.18...3.27 FATAL_ERROR)

message("=== Vcpkg HTTP Asset Cache ===")
message("URL: ${URL}")
message("SHA512: ${SHA512}")
message("DST: ${DST}")

set(CACHE_URL "https://example.com/asset_${SHA512}")
message("CACHE_URL: ${CACHE_URL}")

if (NOT DEFINED ENV{ASSET_UPLOAD_TOKEN})
  # Only read asset cache
  file(DOWNLOAD "${CACHE_URL}" "${DST}"
    TLS_VERIFY ON
    EXPECTED_HASH SHA512=${SHA512})

else()
  # Read and write asset cache

  set(has_cache FALSE)

  # Try download
  file(DOWNLOAD "${CACHE_URL}" "${DST}"
     STATUS status
     TLS_VERIFY ON)
  list(GET status 0 status_code)

  if ("${status_code}" EQUAL "0")
    # Manually check hash, because using EXPECTED_HASH above will trigger error
    file(SHA512 "${DST}" hash)
    if ("${hash}" STREQUAL "${SHA512}")
      set(has_cache TRUE)
    endif()
  endif()

  if (has_cache)
    # Asset already cached
    return()
  endif()

  # Download from original source
  file(DOWNLOAD "${URL}" "${DST}"
    TLS_VERIFY ON
    EXPECTED_HASH SHA512=${SHA512})

  # Upload to cache
  file(UPLOAD "${DST}" "${CACHE_URL}"
    STATUS status
    HTTPHEADER "Authorization: Token $ENV{ASSET_UPLOAD_TOKEN}"
    TLS_VERIFY ON)
  list(GET status 0 status_code)
  if (NOT "${status_code}" EQUAL "0")
    message(FATAL_ERROR "Error uploading to cache.")
  endif()
endif()