geoip: pass through the dataDir so consumers know where to look

This commit is contained in:
Peter Hoeg 2022-06-28 15:47:13 +08:00
parent 95e79164be
commit 959efb4705

View file

@ -1,24 +1,29 @@
{ lib, stdenv, fetchFromGitHub, autoreconfHook { lib
, stdenv
, fetchFromGitHub
, autoreconfHook
, drvName ? "geoip" , drvName ? "geoip"
# in geoipDatabase, you can insert a package defining # in geoipDatabase, you can insert a package defining
# "${geoipDatabase}/share/GeoIP" e.g. geolite-legacy # "${geoipDatabase}/share/GeoIP" e.g. geolite-legacy
, geoipDatabase ? "/var/lib/geoip-databases" , geoipDatabase ? "/var/lib/geoip-databases"
}: }:
let let
dataDir = if lib.isDerivation geoipDatabase dataDir =
if lib.isDerivation geoipDatabase
then "${toString geoipDatabase}/share/GeoIP" then "${toString geoipDatabase}/share/GeoIP"
else geoipDatabase; else geoipDatabase;
in in
stdenv.mkDerivation rec { stdenv.mkDerivation rec {
pname = drvName; pname = drvName;
version = "1.6.12"; version = "1.6.12";
src = fetchFromGitHub { src = fetchFromGitHub {
owner = "maxmind"; owner = "maxmind";
repo = "geoip-api-c"; repo = "geoip-api-c";
rev = "v${version}"; rev = "v${version}";
sha256 = "0ixyp3h51alnncr17hqp1p0rlqz9w69nlhm60rbzjjz3vjx52ajv"; sha256 = "0ixyp3h51alnncr17hqp1p0rlqz9w69nlhm60rbzjjz3vjx52ajv";
}; };
@ -35,11 +40,13 @@ stdenv.mkDerivation rec {
find . -name Makefile.in -exec sed -i -r 's#^pkgdatadir\s*=.+$#pkgdatadir = ${dataDir}#' {} \; find . -name Makefile.in -exec sed -i -r 's#^pkgdatadir\s*=.+$#pkgdatadir = ${dataDir}#' {} \;
''; '';
passthru = { inherit dataDir; };
meta = with lib; { meta = with lib; {
description = "An API for GeoIP/Geolocation databases"; description = "An API for GeoIP/Geolocation databases";
maintainers = with maintainers; [ thoughtpolice raskin ]; maintainers = with maintainers; [ thoughtpolice raskin ];
license = licenses.lgpl21; license = licenses.lgpl21;
platforms = platforms.unix; platforms = platforms.unix;
homepage = "https://www.maxmind.com"; homepage = "https://www.maxmind.com";
}; };
} }