A web user interface and API for our reproducible builds of MirageOS unikernels and host system tools.
Find a file
Reynir Björnsson 58d05ba908 Add more json to endpoints, populate-local.sh
Some basic json is added to the endpoints that list jobs and builds.

With this a script populate-local.sh can be used to fetch a number of
builds from a remote instance and upload them to a local instance. This
is useful for populating an instance with real builds for testing
purposes.

Closes #11.
2025-01-16 14:49:23 +01:00
auth remove usage of cstruct, require mirage-crypto 1.0.0 2024-09-02 16:14:26 +02:00
bin console_of_string: be a bit more robust 2025-01-15 13:44:27 +01:00
db remove superfluous mirage-crypto dependency 2024-09-05 17:02:14 +02:00
http_status_middleware Add http status metrics middleware 2021-06-08 12:36:53 +00:00
lib Add more json to endpoints, populate-local.sh 2025-01-16 14:49:23 +01:00
opamdiff Fix label for right file 2025-01-10 16:15:22 +01:00
packaging Check version in visualizations.sh 2024-03-25 16:46:52 +01:00
test update to uuidm 0.9.9 deprecations 2024-12-17 12:11:44 +01:00
.gitignore add opam dir to gitignore 2024-12-20 07:03:58 +01:00
.ocp-indent Remove trailing whitespace 2022-02-07 13:51:56 +00:00
builder-web.opam Yojson is now a non-test dependency 2024-12-20 10:12:55 +01:00
CHANGES.md v0.2.0 CHANGES.md 2024-09-06 14:25:47 +02:00
dune-project further CI fixes: require alcotest 1.2.0 (for check'), disable formatting (no .ocamlformat) 2023-09-18 10:52:02 +02:00
LICENSE.md debian packaging 2021-06-29 09:41:05 +00:00
populate-local.sh Add more json to endpoints, populate-local.sh 2025-01-16 14:49:23 +01:00
README.md some documentation 2024-12-20 07:03:47 +01:00

Builder-web - a web frontend for reproducible builds

Builder-web takes in submissions of builds, typically from builder, and displays the produced artifacts in a way that makes it easy to compare checksums and build status. Produced binaries can be downloaded and executed. builds.robur.coop itself runs builder-web.

Overview

Builder-web is a single binary web server using a sqlite3 database with versioned schemas. Finished builds from builder are uploaded to builder-web, stored and indexed in the database and presented in the web interface to the user. Users can:

  • Get an overview of jobs - a job is typically script or opam package that is run and builds an artifact,
  • Browse all builds of a job - each job may have multiple builds, that are executed periodically by builder
  • Browse individual build and download artifacts and build information for reproducing the same binary.
  • Compare two builds, observing the differences in used opam packages, environment variables, and system packages.
  • Search for the SHA-256 hash of a binary to view a build that resulted in that binary.

Installation

Installing from source can be done with opam: opam install builder-web.

We also provide reproducible binary packages.

Setup

Builder-web consists of a binary builder-web that runs a web server on port 3000 listening on all interfaces by default. These values can be changed with the --port and --host flags respectively. See builder-web --help for more information.

Service scripts for FreeBSD and systemd are provided.

The web server expects a sqlite3 database in its data directory. An empty database can be created with builder-db migrate.

Database migrations

The sqlite3 database builder-web uses contains versioning information. On every schema change the database schema version is updated, and migration and rollback scripts are provided. The tool for database migrations is builder-migrations. See the builder-migrations --help output for each migration for further details.

Less common workflows

Here are listed some less common but useful workflows:

Extracting builds from one server to another

This is useful for development on a separate machine that doesn't run the build jobs itself.

On the source server:

builder-db extract-build <build-hash> --dest <build-hash>.full

After copying the file over the destination server (you need a user first, see builder-db user-add --help):

curl --data-binary @<build-hash>.full http://<user>:<passwd>@localhost:<builder-web-port>/upload

JSON Responses

Some endpoints return JSON when the headers contain Accept: application/json.

  • /compare/:build_left/:build_right
  • /job/:job/build/latest/**
  • /job/:job/build/latest