diff options
Diffstat (limited to 'nixpkgs/pkgs/by-name/su/surrealdb/package.nix')
-rw-r--r-- | nixpkgs/pkgs/by-name/su/surrealdb/package.nix | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/nixpkgs/pkgs/by-name/su/surrealdb/package.nix b/nixpkgs/pkgs/by-name/su/surrealdb/package.nix new file mode 100644 index 000000000000..f5c8fecc1b09 --- /dev/null +++ b/nixpkgs/pkgs/by-name/su/surrealdb/package.nix @@ -0,0 +1,69 @@ +{ lib +, stdenv +, rustPlatform +, fetchFromGitHub +, pkg-config +, openssl +, rocksdb +, testers +, surrealdb +, darwin +, protobuf +}: + +rustPlatform.buildRustPackage rec { + pname = "surrealdb"; + version = "1.3.1"; + + src = fetchFromGitHub { + owner = "surrealdb"; + repo = "surrealdb"; + rev = "v${version}"; + hash = "sha256-dnfgU7nTX3vvqN9Mox6USRfpFdEI/dAOKIVZ2Jd4t9o="; + }; + + cargoHash = "sha256-B+x+xEcwHqoYMolAuMQzSiO/QA1FiBGO3eis9kgN1S4="; + + # error: linker `aarch64-linux-gnu-gcc` not found + postPatch = '' + rm .cargo/config.toml + ''; + + PROTOC = "${protobuf}/bin/protoc"; + PROTOC_INCLUDE = "${protobuf}/include"; + + ROCKSDB_INCLUDE_DIR = "${rocksdb}/include"; + ROCKSDB_LIB_DIR = "${rocksdb}/lib"; + + nativeBuildInputs = [ + pkg-config + rustPlatform.bindgenHook + ]; + + buildInputs = [ openssl ] + ++ lib.optionals stdenv.isDarwin [ darwin.apple_sdk.frameworks.SystemConfiguration ]; + + doCheck = false; + + checkFlags = [ + # flaky + "--skip=ws_integration::none::merge" + # requires docker + "--skip=database_upgrade" + ]; + + __darwinAllowLocalNetworking = true; + + passthru.tests.version = testers.testVersion { + package = surrealdb; + command = "surreal version"; + }; + + meta = with lib; { + description = "A scalable, distributed, collaborative, document-graph database, for the realtime web"; + homepage = "https://surrealdb.com/"; + mainProgram = "surreal"; + license = licenses.bsl11; + maintainers = with maintainers; [ sikmir happysalada ]; + }; +} |