nidx-binding 6.3.4.post154__tar.gz → 6.3.4.post159__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (243) hide show
  1. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/PKG-INFO +1 -1
  2. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_protos/pyproject.toml +1 -1
  3. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_relation/src/graph_query_parser.rs +34 -12
  4. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_relation/tests/test_graph_search.rs +146 -2
  5. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/pyproject.toml +1 -1
  6. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-0cfce9b29547f8f5bafa6e440f86103be7b8c4ad2fd92db9ac223f4efbe23d10.json +0 -0
  7. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-1a561eed00f3dbe868bf5030059793300209179dc8fb73e4b57a54b5e81262fe.json +0 -0
  8. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-1d3fca2682e25a01143da92285297f134a6a105a96f64d87e0db3abb219855e4.json +0 -0
  9. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-249b3b57c27a71baa823f1fe0f0bba9c9af36f61c28f731e58beea60ec48e687.json +0 -0
  10. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-24cb6b683daa42d7125f862e25943ab4be7bf275cd8739f8da4859d701795e1a.json +0 -0
  11. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-263c8fce6db5b03bbd012fafdba6943cbee6ed7eb8976cdef4f5b01dde7ca6fd.json +0 -0
  12. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-2a5d92fb1638df830a4477a7cdf24e6db6b43034b7bbe74fdfb63e8afe2c4071.json +0 -0
  13. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-2b065a363f58caed60e3706603c1260dbf5a4c795604a5b68edda22eb07fec1b.json +0 -0
  14. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-3fc3cb39934683de8cd475ce1368c8373453eb1e01f81587d66b9d14b109ce6e.json +0 -0
  15. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-48f33b77b7c1633467b0b2efcaa1d3c207e7757e4f1d83b40d15e6ca365f7771.json +0 -0
  16. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-4ae09f2c08e2f324bee01bb8487a8f37678a1c5e9d327339235c50d4921a8949.json +0 -0
  17. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-4d7a76fa413c9ef0ce2a47ac7bb7e01d3e6a2aabded9487d21010a53efee8852.json +0 -0
  18. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-4fcbdd6657c7dc9b60b3a563dd41711b3dbcf72ce063427b7a01f8cddf34c244.json +0 -0
  19. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-577109ac00ccfbd38ecaccab94116f2f46a4caf5612afa372cded197123c1e08.json +0 -0
  20. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-5db25f97d8578d6d78f2f6bd4b72cc82a9b1b82805c6422d967ac63b20d99db4.json +0 -0
  21. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-5ec3233a3a23e926055056d46bdde17836a633066dbb5f349502648cd3ea9a60.json +0 -0
  22. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-66edb6ea424d8681927dcddb6bac5f1239175f4775d1f40417ba15054b0c6f19.json +0 -0
  23. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-6f9c6d201c1b5712efb68c363bffd3e0169c11f2a8f925e8cd4e8808599ff7b4.json +0 -0
  24. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-733c3ebacc86f444bf5e2dd79ade660c291e88a00fc09b722f6e2e191545874c.json +0 -0
  25. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-77a245aed9f6f8b9fc643efbd4b1e2e8e99bbba085e3e75a4f29321cd7b2a25c.json +0 -0
  26. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-7a3bf27c330c468a596e8a297cf7d8b192e31e67ecc5177c1267f579e8e247c7.json +0 -0
  27. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-7a7e59e47b30b12237511fd3d7da2d17b0471ad2b006af48d6a6f587c779692b.json +0 -0
  28. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-7dcbb33312cc9f11ae3a6d73b1ace017a9f19a8bf8f10304fc57977c8efeadff.json +0 -0
  29. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-7efa7c0d747afc4b6aed0586ff846c27839c3213ff7ee9f30c89b0d0f17e60e3.json +0 -0
  30. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-8493140d788604d498a4e48da4158708572ccc9d60185290a00d549cc84533db.json +0 -0
  31. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-8493bb0059b013eaca42fd10cd7d04f0d06a8acaed379eff0d23f3229edde9ee.json +0 -0
  32. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-87996b3d6c7a2195438d7038015b06949102bce8c7b8cd8db1f83aaf23cbe489.json +0 -0
  33. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-8f096d8171b89f9615d18f95d696dc9e4fb3674e103161a713cdc806f7a68506.json +0 -0
  34. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-917732a56ee04bf3a6e127319dda8225210869c82f9828d878162394dba4e078.json +0 -0
  35. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-95fe4ef93ee90733db1b67ed7987f80b5aac792f1590b979c68b418d1599eb98.json +0 -0
  36. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-9b67658569b343d8b4b61ae0a7dc721f367f2ba33c7b69b9e68bfd5c9bff5206.json +0 -0
  37. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-9c8062ea55d070afef68309e58fa987eb37fda44e1efbf68c8ba2af7846cc968.json +0 -0
  38. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-a06e1d9f6f95e4c4c2b98310ebddcc9d963cc033582bf2e945e8bf3a301b4247.json +0 -0
  39. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-a55265c9b07bd1399961a6f1e757201fd0eebe868ddaf96437111113d80fce92.json +0 -0
  40. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-a891a37be5c2d7cce775c2dd33726b0318fd3839beab222a1b22bc6174604207.json +0 -0
  41. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-a945191bb4b3e37d6823ed3ad499339d007d69983105de8567777d9daf517b28.json +0 -0
  42. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-abe9f7832f2bd799ac44008da031e8d8ab52d4f5fbfc2a7e3974e8873bae55b2.json +0 -0
  43. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-aca588cca57a85e4d7fcc40c23cd87e57d53d11ca550d78e7e3d5e39e524fcd3.json +0 -0
  44. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-b02f8aafc00a7724510772ac41269e368c5bccf03ef7b4590e0ef6fd1a1bf64f.json +0 -0
  45. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-b742e17cabe2d64617e9aa64bafc782172f7a4f8023d1b54f952a0fb39f6b2b8.json +0 -0
  46. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-b94e349dbc0daec57f8f8f6e9e2dffb06100b1bb2b41d297c9f3b191da37a83d.json +0 -0
  47. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-bd9afa22994aba671dbf7b5f89b53c2ee02f53c0442a81265786a6d52d08512f.json +0 -0
  48. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-be60554eca98a5899efc6b49785cecd6444a6d39afed9e4a884ce2dbf162012c.json +0 -0
  49. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-bf49702b506c9a1650ece1f8e8d9f14834a902f8caefafe30ded55e2790f2188.json +0 -0
  50. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-bfb8ae2e860e451b0868a7b1b50a451d998b2105f9fdfd307b26a1775d145e9f.json +0 -0
  51. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-bfcd21ed704cd305db5c17fcdec7d92aa4ac501913c9c9514d8ff92928c0c7e7.json +0 -0
  52. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-c3ab694650f49a75b146fb877a92e48c4f20f0d99f70f8ec859fbb763b01a1e5.json +0 -0
  53. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-c55542bb9fae544d87fae6f30e0fe8a9088d12075f4442ab4fe2fcd05e472234.json +0 -0
  54. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-cb29a6556d35ac630ee0aa885dd7341cf9573bd3efd216ff8a887b87686b03db.json +0 -0
  55. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-d0a1f341a89f5f14696b10baa72db9d95551c2b7e5fc67308fd52dc03dd98a92.json +0 -0
  56. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-d2ad0a0ca2649c9e4873cfcc1fc66d2d07cc45d0f65c560b06d7b5f592f4fa8a.json +0 -0
  57. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-d6cfe78eb635ba0b89ca4021a4dc8182d18ab5b197f30149cd28488eba4c1df5.json +0 -0
  58. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-d729b56dea00e49dcdba8cf0001e2811da27351eabe98212db3b589f18fc6f32.json +0 -0
  59. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-d9658bfd4e7170b41d03f2ddf2446d0bf54171c0d39d53bf20af2b8437f2ec48.json +0 -0
  60. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-dbba7b3d3289425bae711aedbf73fbc3699f857f86f84d95c3b556d05c5658b0.json +0 -0
  61. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-dcb96b649d6d63a58efd5d445453a4f3d7869a56ff714b69bedf3d616a0473ca.json +0 -0
  62. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-ebd876fbf5362a5900e75bc05f2f11c73c406ef7da4e95097fc6a1c3d1b8bc54.json +0 -0
  63. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-eef5cc6bce1cc14eba8f3e68971724ef181e88cffcedd74673615f2026b89a62.json +0 -0
  64. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/.sqlx/query-ef56d5fefc5774040d1ee397beadb475f6af02768c22f0e583c74062e2e821ce.json +0 -0
  65. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/Cargo.lock +0 -0
  66. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/Cargo.toml +0 -0
  67. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/README.md +0 -0
  68. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/migrations/20241007163501_initial.sql +0 -0
  69. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/migrations/20241211120039_merge_job_priority.sql +0 -0
  70. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/migrations/20241211121159_basic_indexes.sql +0 -0
  71. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/migrations/20241212151105_check_segment_records.sql +0 -0
  72. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/migrations/20250110145554_in_flight_messages.sql +0 -0
  73. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_binding/Cargo.toml +0 -0
  74. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_binding/src/lib.rs +0 -0
  75. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/Cargo.toml +0 -0
  76. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/src/fuzzy_query.rs +0 -0
  77. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/src/lib.rs +0 -0
  78. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/src/query_io.rs +0 -0
  79. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/src/reader.rs +0 -0
  80. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/src/request_types.rs +0 -0
  81. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/src/resource_indexer.rs +0 -0
  82. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/src/schema.rs +0 -0
  83. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/src/search_query.rs +0 -0
  84. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/src/search_response.rs +0 -0
  85. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/src/set_query.rs +0 -0
  86. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/src/stop_words.rs +0 -0
  87. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/README.md +0 -0
  88. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/ar.json +0 -0
  89. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/az.json +0 -0
  90. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/bn.json +0 -0
  91. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/ca.json +0 -0
  92. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/ch.json +0 -0
  93. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/da.json +0 -0
  94. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/de.json +0 -0
  95. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/el.json +0 -0
  96. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/en.json +0 -0
  97. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/es.json +0 -0
  98. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/eu.json +0 -0
  99. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/extract.py +0 -0
  100. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/fi.json +0 -0
  101. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/fr.json +0 -0
  102. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/he.json +0 -0
  103. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/hu.json +0 -0
  104. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/id.json +0 -0
  105. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/it.json +0 -0
  106. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/kk.json +0 -0
  107. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/ne.json +0 -0
  108. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/nl.json +0 -0
  109. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/no.json +0 -0
  110. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/pt.json +0 -0
  111. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/ro.json +0 -0
  112. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/ru.json +0 -0
  113. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/sl.json +0 -0
  114. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/sv.json +0 -0
  115. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/tg.json +0 -0
  116. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/stop_words/tr.json +0 -0
  117. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/tests/common/mod.rs +0 -0
  118. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_paragraph/tests/reader.rs +0 -0
  119. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_protos/Cargo.toml +0 -0
  120. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_protos/build.py +0 -0
  121. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_protos/build.rs +0 -0
  122. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_protos/src/lib.rs +0 -0
  123. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_protos/src/nidx.proto +0 -0
  124. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_relation/Cargo.toml +0 -0
  125. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_relation/src/graph_collector.rs +0 -0
  126. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_relation/src/io_maps.rs +0 -0
  127. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_relation/src/lib.rs +0 -0
  128. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_relation/src/reader.rs +0 -0
  129. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_relation/src/resource_indexer.rs +0 -0
  130. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_relation/src/schema.rs +0 -0
  131. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_relation/tests/common/mod.rs +0 -0
  132. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_relation/tests/test_graph_query_parser_search.rs +0 -0
  133. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_relation/tests/test_reader.rs +0 -0
  134. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_relation/tests/test_writer.rs +0 -0
  135. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_tantivy/Cargo.toml +0 -0
  136. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_tantivy/src/index_reader.rs +0 -0
  137. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_tantivy/src/lib.rs +0 -0
  138. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_tests/Cargo.toml +0 -0
  139. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_tests/src/graph.rs +0 -0
  140. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_tests/src/lib.rs +0 -0
  141. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_text/Cargo.toml +0 -0
  142. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_text/src/lib.rs +0 -0
  143. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_text/src/prefilter.rs +0 -0
  144. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_text/src/query_io.rs +0 -0
  145. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_text/src/reader.rs +0 -0
  146. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_text/src/request_types.rs +0 -0
  147. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_text/src/resource_indexer.rs +0 -0
  148. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_text/src/schema.rs +0 -0
  149. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_text/src/search_query.rs +0 -0
  150. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_text/tests/common/mod.rs +0 -0
  151. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_text/tests/test_flow.rs +0 -0
  152. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_text/tests/test_search.rs +0 -0
  153. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_text/tests/test_streaming.rs +0 -0
  154. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_types/Cargo.toml +0 -0
  155. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_types/src/lib.rs +0 -0
  156. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_types/src/prefilter.rs +0 -0
  157. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_types/src/query_language.rs +0 -0
  158. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/Cargo.toml +0 -0
  159. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/config.rs +0 -0
  160. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/data_point/disk_hnsw.rs +0 -0
  161. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/data_point/mod.rs +0 -0
  162. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/data_point/node.rs +0 -0
  163. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/data_point/ops_hnsw.rs +0 -0
  164. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/data_point/params.rs +0 -0
  165. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/data_point/ram_hnsw.rs +0 -0
  166. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/data_point/tests.rs +0 -0
  167. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/data_point_provider/mod.rs +0 -0
  168. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/data_point_provider/reader.rs +0 -0
  169. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/data_types/data_store.rs +0 -0
  170. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/data_types/mod.rs +0 -0
  171. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/data_types/trie.rs +0 -0
  172. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/data_types/trie_ram.rs +0 -0
  173. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/formula/mod.rs +0 -0
  174. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/indexer.rs +0 -0
  175. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/inverted_index/fst_index.rs +0 -0
  176. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/inverted_index/map.rs +0 -0
  177. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/inverted_index.rs +0 -0
  178. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/lib.rs +0 -0
  179. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/query_io.rs +0 -0
  180. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/request_types.rs +0 -0
  181. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/utils.rs +0 -0
  182. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/vector_types/dense_f32.rs +0 -0
  183. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/src/vector_types/mod.rs +0 -0
  184. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/tests/common/mod.rs +0 -0
  185. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/tests/test_basic_search.rs +0 -0
  186. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/nidx_vector/tests/test_hidden.rs +0 -0
  187. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/api/grpc.rs +0 -0
  188. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/api/shards.rs +0 -0
  189. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/api.rs +0 -0
  190. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/control.rs +0 -0
  191. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/errors.rs +0 -0
  192. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/grpc_server.rs +0 -0
  193. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/import_export.rs +0 -0
  194. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/indexer.rs +0 -0
  195. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/lib.rs +0 -0
  196. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/main.rs +0 -0
  197. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/metadata/deletion.rs +0 -0
  198. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/metadata/index.rs +0 -0
  199. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/metadata/index_request.rs +0 -0
  200. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/metadata/merge_job.rs +0 -0
  201. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/metadata/segment.rs +0 -0
  202. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/metadata/shard.rs +0 -0
  203. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/metadata.rs +0 -0
  204. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/metrics.rs +0 -0
  205. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/scheduler/audit_task.rs +0 -0
  206. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/scheduler/log_merge.rs +0 -0
  207. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/scheduler/merge_task.rs +0 -0
  208. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/scheduler/metrics_task.rs +0 -0
  209. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/scheduler/purge_tasks.rs +0 -0
  210. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/scheduler/vector_merge.rs +0 -0
  211. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/scheduler.rs +0 -0
  212. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/searcher/grpc.rs +0 -0
  213. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/searcher/index_cache.rs +0 -0
  214. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/searcher/query_language.rs +0 -0
  215. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/searcher/query_planner.rs +0 -0
  216. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/searcher/shard_search.rs +0 -0
  217. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/searcher/shard_selector.rs +0 -0
  218. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/searcher/shard_suggest.rs +0 -0
  219. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/searcher/streams.rs +0 -0
  220. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/searcher/sync.rs +0 -0
  221. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/searcher.rs +0 -0
  222. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/segment_store.rs +0 -0
  223. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/settings.rs +0 -0
  224. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/telemetry/duration_layer.rs +0 -0
  225. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/telemetry/log_format.rs +0 -0
  226. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/telemetry/middleware.rs +0 -0
  227. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/telemetry.rs +0 -0
  228. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/tool.rs +0 -0
  229. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/src/worker.rs +0 -0
  230. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/tests/common/mod.rs +0 -0
  231. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/tests/common/services.rs +0 -0
  232. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/tests/test_date_range_search.rs +0 -0
  233. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/tests/test_search_filtering.rs +0 -0
  234. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/tests/test_search_relations.rs +0 -0
  235. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/tests/test_search_sorting.rs +0 -0
  236. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/tests/test_searcher_cluster.rs +0 -0
  237. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/tests/test_security_search.rs +0 -0
  238. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/tests/test_shards.rs +0 -0
  239. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/tests/test_shards_api.rs +0 -0
  240. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/tests/test_suggest.rs +0 -0
  241. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/tests/test_synced_searcher.rs +0 -0
  242. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/tests/test_vector_normalization.rs +0 -0
  243. {nidx_binding-6.3.4.post154 → nidx_binding-6.3.4.post159}/tests/test_vectorsets.rs +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: nidx_binding
3
- Version: 6.3.4.post154
3
+ Version: 6.3.4.post159
4
4
  Classifier: Programming Language :: Rust
5
5
  Classifier: Programming Language :: Python :: Implementation :: CPython
6
6
  Classifier: Programming Language :: Python :: Implementation :: PyPy
@@ -4,7 +4,7 @@ build-backend = "pdm.backend"
4
4
 
5
5
  [project]
6
6
  name = "nidx_protos"
7
- version = "6.3.4.post154"
7
+ version = "6.3.4.post159"
8
8
  license = { text = "AGPL" }
9
9
  description = "Protobuf definitions for nucliadb/nidx"
10
10
  authors = [ { name = "Nuclia", email = "nucliadb@nuclia.com" }]
@@ -18,11 +18,12 @@
18
18
  // along with this program. If not, see <http://www.gnu.org/licenses/>.
19
19
  //
20
20
  use anyhow::anyhow;
21
+ use nidx_protos::graph_query::FacetFilter;
21
22
  use nidx_protos::relation::RelationType;
22
23
  use nidx_protos::relation_node::NodeType;
23
24
  use nidx_types::query_language::{BooleanExpression, BooleanOperation, Operator};
24
25
  use tantivy::query::{AllQuery, BooleanQuery, FuzzyTermQuery, Occur, Query, TermQuery};
25
- use tantivy::schema::{Field, IndexRecordOption};
26
+ use tantivy::schema::{Facet, Field, IndexRecordOption};
26
27
  use tantivy::tokenizer::TokenizerManager;
27
28
 
28
29
  use crate::io_maps;
@@ -109,6 +110,8 @@ pub enum GraphQuery {
109
110
  RelationQuery(RelationQuery),
110
111
  // (:A)-[:R]->(:B)
111
112
  PathQuery(PathQuery),
113
+
114
+ Facet(String),
112
115
  }
113
116
 
114
117
  #[derive(Clone, Copy)]
@@ -117,7 +120,13 @@ enum NodePosition {
117
120
  Destination,
118
121
  }
119
122
 
120
- pub struct BoolNodeQuery(BooleanExpression<Node>);
123
+ #[derive(Clone)]
124
+ enum NodeExpression {
125
+ Node(Node),
126
+ Facet(String),
127
+ }
128
+
129
+ pub struct BoolNodeQuery(BooleanExpression<NodeExpression>);
121
130
  pub struct BoolGraphQuery(BooleanExpression<GraphQuery>);
122
131
 
123
132
  #[derive(Clone, Copy)]
@@ -172,9 +181,13 @@ impl<'a> GraphQueryParser<'a> {
172
181
  )
173
182
  }
174
183
 
175
- fn inner_parse_bool_node(&self, query: BooleanExpression<Node>, position: NodePosition) -> Box<dyn Query> {
184
+ fn inner_parse_bool_node(
185
+ &self,
186
+ query: BooleanExpression<NodeExpression>,
187
+ position: NodePosition,
188
+ ) -> Box<dyn Query> {
176
189
  match query {
177
- BooleanExpression::Literal(node) => match position {
190
+ BooleanExpression::Literal(NodeExpression::Node(node)) => match position {
178
191
  NodePosition::Source => {
179
192
  self.parse(GraphQuery::NodeQuery(NodeQuery::SourceNode(Expression::Value(node))))
180
193
  }
@@ -182,6 +195,7 @@ impl<'a> GraphQueryParser<'a> {
182
195
  Expression::Value(node),
183
196
  ))),
184
197
  },
198
+ BooleanExpression::Literal(NodeExpression::Facet(facet)) => self.parse_facet(&facet),
185
199
  BooleanExpression::Not(subquery) => {
186
200
  let subqueries = vec![
187
201
  (Occur::Must, Box::new(AllQuery) as Box<dyn Query>),
@@ -210,6 +224,7 @@ impl<'a> GraphQueryParser<'a> {
210
224
  GraphQuery::NodeQuery(query) => self.parse_node_query(query),
211
225
  GraphQuery::RelationQuery(query) => self.parse_relation_query(query),
212
226
  GraphQuery::PathQuery(query) => self.parse_path_query(query),
227
+ GraphQuery::Facet(facet) => self.parse_facet(&facet),
213
228
  }
214
229
  }
215
230
 
@@ -245,6 +260,13 @@ impl<'a> GraphQueryParser<'a> {
245
260
  self.parse_path_query(equivalent_path_query)
246
261
  }
247
262
 
263
+ fn parse_facet(&self, facet: &str) -> Box<dyn Query> {
264
+ Box::new(TermQuery::new(
265
+ tantivy::Term::from_facet(self.schema.facets, &Facet::from_text(facet).expect("Invalid facet")),
266
+ IndexRecordOption::Basic,
267
+ ))
268
+ }
269
+
248
270
  fn parse_path_query(&self, query: PathQuery) -> Box<dyn Query> {
249
271
  match query {
250
272
  PathQuery::DirectedPath((source_expression, relation_expression, destination_expression)) => {
@@ -564,14 +586,12 @@ impl TryFrom<&nidx_protos::graph_query::PathQuery> for BoolNodeQuery {
564
586
 
565
587
  let pb_node = path.source.as_ref().unwrap();
566
588
  let node = Node::try_from(pb_node)?;
567
- BooleanExpression::Literal(node)
589
+ BooleanExpression::Literal(NodeExpression::Node(node))
568
590
  }
569
-
570
591
  nidx_protos::graph_query::path_query::Query::BoolNot(bool_not) => {
571
592
  let subquery = BoolNodeQuery::try_from(bool_not.as_ref())?.0;
572
593
  BooleanExpression::Not(Box::new(subquery))
573
594
  }
574
-
575
595
  nidx_protos::graph_query::path_query::Query::BoolAnd(bool_and) => {
576
596
  BooleanExpression::Operation(BooleanOperation {
577
597
  operator: Operator::And,
@@ -582,7 +602,6 @@ impl TryFrom<&nidx_protos::graph_query::PathQuery> for BoolNodeQuery {
582
602
  .collect::<anyhow::Result<Vec<_>>>()?,
583
603
  })
584
604
  }
585
-
586
605
  nidx_protos::graph_query::path_query::Query::BoolOr(bool_or) => {
587
606
  BooleanExpression::Operation(BooleanOperation {
588
607
  operator: Operator::Or,
@@ -593,9 +612,12 @@ impl TryFrom<&nidx_protos::graph_query::PathQuery> for BoolNodeQuery {
593
612
  .collect::<anyhow::Result<Vec<_>>>()?,
594
613
  })
595
614
  }
615
+ nidx_protos::graph_query::path_query::Query::Facet(FacetFilter { facet }) => {
616
+ BooleanExpression::Literal(NodeExpression::Facet(facet.clone()))
617
+ }
596
618
  },
597
619
 
598
- None => BooleanExpression::Literal(Node::default()),
620
+ None => BooleanExpression::Literal(NodeExpression::Node(Node::default())),
599
621
  };
600
622
 
601
623
  Ok(BoolNodeQuery(bool_expr))
@@ -638,12 +660,10 @@ impl TryFrom<&nidx_protos::graph_query::PathQuery> for BoolGraphQuery {
638
660
 
639
661
  BooleanExpression::Literal(path_query)
640
662
  }
641
-
642
663
  nidx_protos::graph_query::path_query::Query::BoolNot(bool_not) => {
643
664
  let subquery = BoolGraphQuery::try_from(bool_not.as_ref())?.0;
644
665
  BooleanExpression::Not(Box::new(subquery))
645
666
  }
646
-
647
667
  nidx_protos::graph_query::path_query::Query::BoolAnd(bool_and) => {
648
668
  BooleanExpression::Operation(BooleanOperation {
649
669
  operator: Operator::And,
@@ -654,7 +674,6 @@ impl TryFrom<&nidx_protos::graph_query::PathQuery> for BoolGraphQuery {
654
674
  .collect::<anyhow::Result<Vec<_>>>()?,
655
675
  })
656
676
  }
657
-
658
677
  nidx_protos::graph_query::path_query::Query::BoolOr(bool_or) => {
659
678
  BooleanExpression::Operation(BooleanOperation {
660
679
  operator: Operator::Or,
@@ -665,6 +684,9 @@ impl TryFrom<&nidx_protos::graph_query::PathQuery> for BoolGraphQuery {
665
684
  .collect::<anyhow::Result<Vec<_>>>()?,
666
685
  })
667
686
  }
687
+ nidx_protos::graph_query::path_query::Query::Facet(FacetFilter { facet }) => {
688
+ BooleanExpression::Literal(GraphQuery::Facet(facet.clone()))
689
+ }
668
690
  },
669
691
 
670
692
  None => BooleanExpression::Literal(GraphQuery::PathQuery(PathQuery::UndirectedPath((
@@ -23,10 +23,13 @@ use std::collections::HashMap;
23
23
 
24
24
  use nidx_protos::graph_query::node::MatchKind;
25
25
  use nidx_protos::graph_query::path_query::Query;
26
- use nidx_protos::graph_query::{BoolQuery, Node, Path, PathQuery, Relation};
26
+ use nidx_protos::graph_query::{BoolQuery, FacetFilter, Node, Path, PathQuery, Relation};
27
27
  use nidx_protos::relation::RelationType;
28
28
  use nidx_protos::relation_node::NodeType;
29
- use nidx_protos::{GraphQuery, GraphSearchRequest, GraphSearchResponse, IndexRelations, Resource, ResourceId};
29
+ use nidx_protos::{
30
+ GraphQuery, GraphSearchRequest, GraphSearchResponse, IndexRelation, IndexRelations, RelationNode, Resource,
31
+ ResourceId,
32
+ };
30
33
  use nidx_relation::{RelationConfig, RelationIndexer, RelationSearcher};
31
34
  use nidx_tests::graph::friendly_parse;
32
35
  use nidx_types::prefilter::{FieldId, PrefilterResult};
@@ -569,6 +572,147 @@ fn test_prefilter() -> anyhow::Result<()> {
569
572
  Ok(())
570
573
  }
571
574
 
575
+ #[test]
576
+ fn test_facet_filter() -> anyhow::Result<()> {
577
+ let dir = TempDir::new().unwrap();
578
+
579
+ // Create a graph with relations with different facets
580
+ let relations = vec![
581
+ IndexRelation {
582
+ relation: Some(nidx_protos::Relation {
583
+ source: Some(RelationNode {
584
+ ntype: NodeType::Entity.into(),
585
+ subtype: "PERSON".to_string(),
586
+ value: "Peter Processor".to_string(),
587
+ }),
588
+ to: Some(RelationNode {
589
+ ntype: NodeType::Entity.into(),
590
+ subtype: "PERSON".to_string(),
591
+ value: "Pedro Procesador".to_string(),
592
+ }),
593
+ relation: RelationType::Entity.into(),
594
+ relation_label: "SAME".to_string(),
595
+ metadata: None,
596
+ }),
597
+ facets: vec![],
598
+ ..Default::default()
599
+ },
600
+ IndexRelation {
601
+ relation: Some(nidx_protos::Relation {
602
+ source: Some(RelationNode {
603
+ ntype: NodeType::Entity.into(),
604
+ subtype: "PERSON".to_string(),
605
+ value: "Ursula User".to_string(),
606
+ }),
607
+ to: Some(RelationNode {
608
+ ntype: NodeType::Entity.into(),
609
+ subtype: "PERSON".to_string(),
610
+ value: "Úrsula Usuaria".to_string(),
611
+ }),
612
+ relation: RelationType::Entity.into(),
613
+ relation_label: "SAME".to_string(),
614
+ metadata: None,
615
+ }),
616
+ facets: vec!["/g/u".to_string()],
617
+ ..Default::default()
618
+ },
619
+ IndexRelation {
620
+ relation: Some(nidx_protos::Relation {
621
+ source: Some(RelationNode {
622
+ ntype: NodeType::Entity.into(),
623
+ subtype: "PERSON".to_string(),
624
+ value: "Alfred Agent".to_string(),
625
+ }),
626
+ to: Some(RelationNode {
627
+ ntype: NodeType::Entity.into(),
628
+ subtype: "PERSON".to_string(),
629
+ value: "Alfred Agente".to_string(),
630
+ }),
631
+ relation: RelationType::Entity.into(),
632
+ relation_label: "SAME".to_string(),
633
+ metadata: None,
634
+ }),
635
+ facets: vec!["/g/da/mytask".to_string()],
636
+ ..Default::default()
637
+ },
638
+ ];
639
+ let field_relations = HashMap::from([("a/metadata".to_string(), IndexRelations { relations })]);
640
+ let resource = Resource {
641
+ resource: Some(ResourceId {
642
+ uuid: "0123456789abcdef0123456789abcdef".to_string(),
643
+ shard_id: "shard_id".to_string(),
644
+ }),
645
+ field_relations,
646
+ ..Default::default()
647
+ };
648
+
649
+ let segment_meta = RelationIndexer
650
+ .index_resource(dir.path(), &RelationConfig::default(), &resource)
651
+ .unwrap()
652
+ .unwrap();
653
+ let reader = RelationSearcher::open(
654
+ RelationConfig::default(),
655
+ TestOpener::new(vec![(segment_meta, 1i64.into())], vec![]),
656
+ )?;
657
+
658
+ // Everything
659
+ let result = search(&reader, Query::Path(Path::default()))?;
660
+ assert_eq!(result.relations.len(), 3);
661
+
662
+ // Processor
663
+ let result = search(
664
+ &reader,
665
+ Query::BoolNot(Box::new(PathQuery {
666
+ query: Some(Query::Facet(FacetFilter {
667
+ facet: "/g".to_string(),
668
+ })),
669
+ })),
670
+ )?;
671
+ assert_eq!(result.relations.len(), 1);
672
+ assert_eq!(result.nodes[0].value, "Peter Processor");
673
+
674
+ // User
675
+ let result = search(
676
+ &reader,
677
+ Query::Facet(FacetFilter {
678
+ facet: "/g/u".to_string(),
679
+ }),
680
+ )?;
681
+ assert_eq!(result.relations.len(), 1);
682
+ assert_eq!(result.nodes[0].value, "Ursula User");
683
+
684
+ // Any DA
685
+ let result = search(
686
+ &reader,
687
+ Query::Facet(FacetFilter {
688
+ facet: "/g/da".to_string(),
689
+ }),
690
+ )?;
691
+ assert_eq!(result.relations.len(), 1);
692
+ assert_eq!(result.nodes[0].value, "Alfred Agent");
693
+
694
+ // Specific DA
695
+ let result = search(
696
+ &reader,
697
+ Query::Facet(FacetFilter {
698
+ facet: "/g/da/mytask".to_string(),
699
+ }),
700
+ )?;
701
+ assert_eq!(result.relations.len(), 1);
702
+ assert_eq!(result.nodes[0].value, "Alfred Agent");
703
+
704
+ // Non-existing facet
705
+ let result = search(
706
+ &reader,
707
+ Query::Facet(FacetFilter {
708
+ facet: "/g/da/faketask".to_string(),
709
+ }),
710
+ )?;
711
+ assert_eq!(result.relations.len(), 0);
712
+
713
+ Ok(())
714
+ }
715
+
572
716
  fn create_reader() -> anyhow::Result<RelationSearcher> {
573
717
  let dir = TempDir::new().unwrap();
574
718
 
@@ -13,7 +13,7 @@ classifiers = [
13
13
  "Programming Language :: Python :: Implementation :: CPython",
14
14
  "Programming Language :: Python :: Implementation :: PyPy",
15
15
  ]
16
- version = "6.3.4.post154"
16
+ version = "6.3.4.post159"
17
17
 
18
18
  [project.urls]
19
19
  Homepage = "https://nuclia.com"