{ lib , fetchFromGitHub , buildGoModule , testers , boulder }: buildGoModule rec { pname = "boulder"; version = "2022-09-06"; src = fetchFromGitHub { owner = "letsencrypt"; repo = "boulder"; rev = "release-${version}"; leaveDotGit = true; postFetch = '' cd $out git rev-parse --short=8 HEAD 2>/dev/null >$out/COMMIT find "$out" -name .git -print0 | xargs -0 rm -rf ''; hash = "sha256-BteHJAjIMPckbNIxgZCSSZV2iUc/yKVd0Px+S9ZwwUI="; }; vendorHash = null; subPackages = [ "cmd/boulder" ]; patches = [ ./no-build-id-test.patch ]; ldflags = [ "-s" "-w" "-X github.com/letsencrypt/boulder/core.BuildHost=nixbld@localhost" ]; preBuild = '' ldflags+=" -X \"github.com/letsencrypt/boulder/core.BuildID=${src.rev} +$(cat COMMIT)\"" ldflags+=" -X \"github.com/letsencrypt/boulder/core.BuildTime=$(date -u -d @0)\"" ''; preCheck = '' # Test all targets. unset subPackages # Disable tests that require additional services. rm -rf \ cmd/admin-revoker/main_test.go \ cmd/bad-key-revoker/main_test.go \ cmd/cert-checker/main_test.go \ cmd/contact-auditor/main_test.go \ cmd/expiration-mailer/main_test.go \ cmd/expiration-mailer/send_test.go \ cmd/id-exporter/main_test.go \ cmd/rocsp-tool/client_test.go \ db/map_test.go \ db/multi_test.go \ db/rollback_test.go \ log/log_test.go \ ocsp/updater/updater_test.go \ ra/ra_test.go \ rocsp/rocsp_test.go \ sa/database_test.go \ sa/model_test.go \ sa/precertificates_test.go \ sa/rate_limits_test.go \ sa/sa_test.go \ test/load-generator/acme/directory_test.go \ va/caa_test.go \ va/dns_test.go \ va/http_test.go \ va/tlsalpn_test.go \ va/va_test.go ''; postInstall = '' for i in $($out/bin/boulder --list); do ln -s $out/bin/boulder $out/bin/$i done ''; passthru.tests.version = testers.testVersion { package = boulder; command = "boulder --version"; inherit version; }; meta = with lib; { homepage = "https://github.com/letsencrypt/boulder"; description = "An ACME-based certificate authority, written in Go"; longDescription = '' This is an implementation of an ACME-based CA. The ACME protocol allows the CA to automatically verify that an applicant for a certificate actually controls an identifier, and allows domain holders to issue and revoke certificates for their domains. Boulder is the software that runs Let's Encrypt. ''; license = licenses.mpl20; maintainers = with maintainers; [ azahi ]; }; }