{ lib, buildGoModule, fetchFromGitHub, testers, runitor, }: buildGoModule rec { pname = "runitor"; version = "1.3.0"; vendorHash = null; src = fetchFromGitHub { owner = "bdd"; repo = "runitor"; rev = "v${version}"; sha256 = "sha256-9sg+ku3Qh/X/EZ2VCrvIc0pq5iyn4O8RZrO4KpkciAI="; }; ldflags = [ "-s" "-w" "-X main.Version=v${version}" ]; passthru.tests.version = testers.testVersion { package = runitor; command = "runitor -version"; version = "v${version}"; }; # Unit tests require binding to local addresses for listening sockets. __darwinAllowLocalNetworking = true; meta = with lib; { homepage = "https://bdd.fi/x/runitor"; description = "Command runner with healthchecks.io integration"; longDescription = '' Runitor runs the supplied command, captures its output, and based on its exit code reports successful or failed execution to https://healthchecks.io or your private instance. Healthchecks.io is a web service for monitoring periodic tasks. It's like a dead man's switch for your cron jobs. You get alerted if they don't run on time or terminate with a failure. ''; license = licenses.bsd0; maintainers = with maintainers; [ bdd ]; mainProgram = "runitor"; }; }