diff --git a/pkgs/servers/nominatim/default.nix b/pkgs/servers/nominatim/default.nix new file mode 100644 index 000000000000..4b7f9e3e2577 --- /dev/null +++ b/pkgs/servers/nominatim/default.nix @@ -0,0 +1,68 @@ +{ stdenv, lib, fetchFromGitHub, fetchurl +, clang-tools, cmake, bzip2, zlib, expat, boost, git, pandoc, gzip +, postgresql_12 +, python3, python3Packages, php +}: + +let + countryGrid = fetchurl { + # Nominatim docs mention https://www.nominatim.org/data/country_grid.sql.gz but it's not a very good URL for pinning + url = "https://web.archive.org/web/20220323041006/https://nominatim.org/data/country_grid.sql.gz"; + sha256 = "sha256-/mY5Oq9WF0klXOv0xh0TqEJeMmuM5QQJ2IxANRZd4Ek="; + }; +in +stdenv.mkDerivation rec { + pname = "nominatim"; + version = "4.0.1"; + + src = fetchFromGitHub { + owner = "osm-search"; + repo = "Nominatim"; + rev = "v${version}"; + fetchSubmodules = true; + sha256 = "sha256-sKI/KBKveb5kAWJ7y1xw+ZF1thynr402rJhVjkIdFMo="; + }; + + nativeBuildInputs = [ + cmake + clang-tools + git + pandoc + php + ]; + + buildInputs = [ + bzip2 + zlib + expat + boost + python3 + # python3Packages.pylint # We don't want to run pylint because the package could break on pylint bumps which is really annoying. + # python3Packages.pytest # disabled since I can't get it to run tests anyway + # python3Packages.behave # disabled since I can't get it to run tests anyway + postgresql_12 + ]; + + propagatedBuildInputs = with python3Packages; [ + pyyaml + python-dotenv + psycopg2 + psutil + jinja2 + PyICU + datrie + ]; + + postPatch = '' + mkdir -p ./data + ln -s ${countryGrid} ./data/country_osm_grid.sql.gz + ''; + + meta = with lib; { + description = "Search engine for OpenStreetMap data"; + homepage = "https://nominatim.org/"; + license = licenses.gpl2Plus; + platforms = platforms.unix; + maintainers = [ maintainers.mausch ]; + }; +} diff --git a/pkgs/top-level/all-packages.nix b/pkgs/top-level/all-packages.nix index 60a0e7918868..4334e96dce08 100644 --- a/pkgs/top-level/all-packages.nix +++ b/pkgs/top-level/all-packages.nix @@ -1103,6 +1103,8 @@ with pkgs; midimonster = callPackage ../tools/audio/midimonster { }; + nominatim = callPackage ../servers/nominatim { }; + pferd = callPackage ../tools/misc/pferd {}; qFlipper = libsForQt515.callPackage ../tools/misc/qflipper { };