hermes-client-python 1.4.18__tar.gz → 1.4.21__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.
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: hermes-client-python
3
- Version: 1.4.18
3
+ Version: 1.4.21
4
4
  Summary: Async Python client for Hermes search server
5
5
  Project-URL: Homepage, https://github.com/SpaceFrontiers/hermes
6
6
  Project-URL: Repository, https://github.com/SpaceFrontiers/hermes
@@ -4,7 +4,7 @@ build-backend = "hatchling.build"
4
4
 
5
5
  [project]
6
6
  name = "hermes-client-python"
7
- version = "1.4.18"
7
+ version = "1.4.21"
8
8
  description = "Async Python client for Hermes search server"
9
9
  readme = "README.md"
10
10
  license = "MIT"
@@ -247,6 +247,8 @@ class HermesClient:
247
247
  dense_vector: tuple[str, list[float]] | None = None,
248
248
  nprobe: int = 0,
249
249
  rerank_factor: int = 0,
250
+ heap_factor: float = 1.0,
251
+ combiner: str = "sum",
250
252
  limit: int = 10,
251
253
  offset: int = 0,
252
254
  fields_to_load: list[str] | None = None,
@@ -262,6 +264,8 @@ class HermesClient:
262
264
  dense_vector: Dense vector query as (field, vector) tuple
263
265
  nprobe: Number of clusters to probe for dense vector (IVF indexes)
264
266
  rerank_factor: Re-ranking factor for dense vector search
267
+ heap_factor: Approximate search factor for sparse vectors (1.0=exact, 0.8=faster)
268
+ combiner: Score combiner for multi-value fields: "sum", "max", or "avg"
265
269
  limit: Maximum number of results
266
270
  offset: Offset for pagination
267
271
  fields_to_load: List of fields to include in results
@@ -307,6 +311,8 @@ class HermesClient:
307
311
  dense_vector=dense_vector,
308
312
  nprobe=nprobe,
309
313
  rerank_factor=rerank_factor,
314
+ heap_factor=heap_factor,
315
+ combiner=combiner,
310
316
  )
311
317
 
312
318
  request = pb.SearchRequest(
@@ -501,6 +507,11 @@ def _from_field_value(fv: pb.FieldValue) -> Any:
501
507
  return None
502
508
 
503
509
 
510
+ def _combiner_to_proto(combiner: str) -> int:
511
+ """Convert combiner string to proto enum value."""
512
+ return {"sum": 0, "max": 1, "avg": 2}.get(combiner.lower(), 0)
513
+
514
+
504
515
  def _build_query(
505
516
  *,
506
517
  term: tuple[str, str] | None = None,
@@ -510,6 +521,8 @@ def _build_query(
510
521
  dense_vector: tuple[str, list[float]] | None = None,
511
522
  nprobe: int = 0,
512
523
  rerank_factor: int = 0,
524
+ heap_factor: float = 1.0,
525
+ combiner: str = "sum",
513
526
  ) -> pb.Query:
514
527
  """Build a protobuf Query from parameters."""
515
528
  if term is not None:
@@ -533,17 +546,30 @@ def _build_query(
533
546
  boolean=pb.BooleanQuery(must=must, should=should, must_not=must_not)
534
547
  )
535
548
 
549
+ combiner_value = _combiner_to_proto(combiner)
550
+
536
551
  if sparse_vector is not None:
537
552
  field, indices, values = sparse_vector
538
553
  return pb.Query(
539
554
  sparse_vector=pb.SparseVectorQuery(
540
- field=field, indices=indices, values=values
555
+ field=field,
556
+ indices=indices,
557
+ values=values,
558
+ combiner=combiner_value,
559
+ heap_factor=heap_factor,
541
560
  )
542
561
  )
543
562
 
544
563
  if sparse_text is not None:
545
564
  field, text = sparse_text
546
- return pb.Query(sparse_vector=pb.SparseVectorQuery(field=field, text=text))
565
+ return pb.Query(
566
+ sparse_vector=pb.SparseVectorQuery(
567
+ field=field,
568
+ text=text,
569
+ combiner=combiner_value,
570
+ heap_factor=heap_factor,
571
+ )
572
+ )
547
573
 
548
574
  if dense_vector is not None:
549
575
  field, vector = dense_vector
@@ -553,6 +579,7 @@ def _build_query(
553
579
  vector=vector,
554
580
  nprobe=nprobe,
555
581
  rerank_factor=rerank_factor,
582
+ combiner=combiner_value,
556
583
  )
557
584
  )
558
585
 
@@ -0,0 +1,112 @@
1
+ # -*- coding: utf-8 -*-
2
+ # Generated by the protocol buffer compiler. DO NOT EDIT!
3
+ # NO CHECKED-IN PROTOBUF GENCODE
4
+ # source: hermes.proto
5
+ # Protobuf Python Version: 6.31.1
6
+ """Generated protocol buffer code."""
7
+ from google.protobuf import descriptor as _descriptor
8
+ from google.protobuf import descriptor_pool as _descriptor_pool
9
+ from google.protobuf import runtime_version as _runtime_version
10
+ from google.protobuf import symbol_database as _symbol_database
11
+ from google.protobuf.internal import builder as _builder
12
+ _runtime_version.ValidateProtobufRuntimeVersion(
13
+ _runtime_version.Domain.PUBLIC,
14
+ 6,
15
+ 31,
16
+ 1,
17
+ '',
18
+ 'hermes.proto'
19
+ )
20
+ # @@protoc_insertion_point(imports)
21
+
22
+ _sym_db = _symbol_database.Default()
23
+
24
+
25
+
26
+
27
+ DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x0chermes.proto\x12\x06hermes\"\x88\x02\n\x05Query\x12!\n\x04term\x18\x01 \x01(\x0b\x32\x11.hermes.TermQueryH\x00\x12\'\n\x07\x62oolean\x18\x02 \x01(\x0b\x32\x14.hermes.BooleanQueryH\x00\x12#\n\x05\x62oost\x18\x03 \x01(\x0b\x32\x12.hermes.BoostQueryH\x00\x12\x1f\n\x03\x61ll\x18\x04 \x01(\x0b\x32\x10.hermes.AllQueryH\x00\x12\x32\n\rsparse_vector\x18\x05 \x01(\x0b\x32\x19.hermes.SparseVectorQueryH\x00\x12\x30\n\x0c\x64\x65nse_vector\x18\x06 \x01(\x0b\x32\x18.hermes.DenseVectorQueryH\x00\x42\x07\n\x05query\"\x94\x01\n\x11SparseVectorQuery\x12\r\n\x05\x66ield\x18\x01 \x01(\t\x12\x0f\n\x07indices\x18\x02 \x03(\r\x12\x0e\n\x06values\x18\x03 \x03(\x02\x12\x0c\n\x04text\x18\x04 \x01(\t\x12,\n\x08\x63ombiner\x18\x05 \x01(\x0e\x32\x1a.hermes.MultiValueCombiner\x12\x13\n\x0bheap_factor\x18\x06 \x01(\x02\"\x86\x01\n\x10\x44\x65nseVectorQuery\x12\r\n\x05\x66ield\x18\x01 \x01(\t\x12\x0e\n\x06vector\x18\x02 \x03(\x02\x12\x0e\n\x06nprobe\x18\x03 \x01(\r\x12\x15\n\rrerank_factor\x18\x04 \x01(\r\x12,\n\x08\x63ombiner\x18\x05 \x01(\x0e\x32\x1a.hermes.MultiValueCombiner\"(\n\tTermQuery\x12\r\n\x05\x66ield\x18\x01 \x01(\t\x12\x0c\n\x04term\x18\x02 \x01(\t\"k\n\x0c\x42ooleanQuery\x12\x1b\n\x04must\x18\x01 \x03(\x0b\x32\r.hermes.Query\x12\x1d\n\x06should\x18\x02 \x03(\x0b\x32\r.hermes.Query\x12\x1f\n\x08must_not\x18\x03 \x03(\x0b\x32\r.hermes.Query\"9\n\nBoostQuery\x12\x1c\n\x05query\x18\x01 \x01(\x0b\x32\r.hermes.Query\x12\r\n\x05\x62oost\x18\x02 \x01(\x02\"\n\n\x08\x41llQuery\"x\n\rSearchRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\x12\x1c\n\x05query\x18\x02 \x01(\x0b\x32\r.hermes.Query\x12\r\n\x05limit\x18\x03 \x01(\r\x12\x0e\n\x06offset\x18\x04 \x01(\r\x12\x16\n\x0e\x66ields_to_load\x18\x05 \x03(\t\"\xca\x01\n\tSearchHit\x12\x0e\n\x06\x64oc_id\x18\x01 \x01(\r\x12\r\n\x05score\x18\x02 \x01(\x02\x12-\n\x06\x66ields\x18\x03 \x03(\x0b\x32\x1d.hermes.SearchHit.FieldsEntry\x12,\n\x0eordinal_scores\x18\x04 \x03(\x0b\x32\x14.hermes.OrdinalScore\x1a\x41\n\x0b\x46ieldsEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12!\n\x05value\x18\x02 \x01(\x0b\x32\x12.hermes.FieldValue:\x02\x38\x01\".\n\x0cOrdinalScore\x12\x0f\n\x07ordinal\x18\x01 \x01(\r\x12\r\n\x05score\x18\x02 \x01(\x02\"\xdb\x01\n\nFieldValue\x12\x0e\n\x04text\x18\x01 \x01(\tH\x00\x12\r\n\x03u64\x18\x02 \x01(\x04H\x00\x12\r\n\x03i64\x18\x03 \x01(\x03H\x00\x12\r\n\x03\x66\x36\x34\x18\x04 \x01(\x01H\x00\x12\x15\n\x0b\x62ytes_value\x18\x05 \x01(\x0cH\x00\x12-\n\rsparse_vector\x18\x06 \x01(\x0b\x32\x14.hermes.SparseVectorH\x00\x12+\n\x0c\x64\x65nse_vector\x18\x07 \x01(\x0b\x32\x13.hermes.DenseVectorH\x00\x12\x14\n\njson_value\x18\x08 \x01(\tH\x00\x42\x07\n\x05value\"/\n\x0cSparseVector\x12\x0f\n\x07indices\x18\x01 \x03(\r\x12\x0e\n\x06values\x18\x02 \x03(\x02\"\x1d\n\x0b\x44\x65nseVector\x12\x0e\n\x06values\x18\x01 \x03(\x02\"V\n\x0eSearchResponse\x12\x1f\n\x04hits\x18\x01 \x03(\x0b\x32\x11.hermes.SearchHit\x12\x12\n\ntotal_hits\x18\x02 \x01(\r\x12\x0f\n\x07took_ms\x18\x03 \x01(\x04\"8\n\x12GetDocumentRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\x12\x0e\n\x06\x64oc_id\x18\x02 \x01(\r\"\x91\x01\n\x13GetDocumentResponse\x12\x37\n\x06\x66ields\x18\x01 \x03(\x0b\x32\'.hermes.GetDocumentResponse.FieldsEntry\x1a\x41\n\x0b\x46ieldsEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12!\n\x05value\x18\x02 \x01(\x0b\x32\x12.hermes.FieldValue:\x02\x38\x01\")\n\x13GetIndexInfoRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\"b\n\x14GetIndexInfoResponse\x12\x12\n\nindex_name\x18\x01 \x01(\t\x12\x10\n\x08num_docs\x18\x02 \x01(\r\x12\x14\n\x0cnum_segments\x18\x03 \x01(\r\x12\x0e\n\x06schema\x18\x04 \x01(\t\"8\n\x12\x43reateIndexRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\x12\x0e\n\x06schema\x18\x02 \x01(\t\"&\n\x13\x43reateIndexResponse\x12\x0f\n\x07success\x18\x01 \x01(\x08\"=\n\nFieldEntry\x12\x0c\n\x04name\x18\x01 \x01(\t\x12!\n\x05value\x18\x02 \x01(\x0b\x32\x12.hermes.FieldValue\"3\n\rNamedDocument\x12\"\n\x06\x66ields\x18\x01 \x03(\x0b\x32\x12.hermes.FieldEntry\"Z\n\x1a\x42\x61tchIndexDocumentsRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\x12(\n\tdocuments\x18\x02 \x03(\x0b\x32\x15.hermes.NamedDocument\"I\n\x1b\x42\x61tchIndexDocumentsResponse\x12\x15\n\rindexed_count\x18\x01 \x01(\r\x12\x13\n\x0b\x65rror_count\x18\x02 \x01(\r\"N\n\x14IndexDocumentRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\x12\"\n\x06\x66ields\x18\x02 \x03(\x0b\x32\x12.hermes.FieldEntry\"/\n\x16IndexDocumentsResponse\x12\x15\n\rindexed_count\x18\x01 \x01(\r\"#\n\rCommitRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\"3\n\x0e\x43ommitResponse\x12\x0f\n\x07success\x18\x01 \x01(\x08\x12\x10\n\x08num_docs\x18\x02 \x01(\r\"\'\n\x11\x46orceMergeRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\";\n\x12\x46orceMergeResponse\x12\x0f\n\x07success\x18\x01 \x01(\x08\x12\x14\n\x0cnum_segments\x18\x02 \x01(\r\"(\n\x12\x44\x65leteIndexRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\"&\n\x13\x44\x65leteIndexResponse\x12\x0f\n\x07success\x18\x01 \x01(\x08*J\n\x12MultiValueCombiner\x12\x10\n\x0c\x43OMBINER_SUM\x10\x00\x12\x10\n\x0c\x43OMBINER_MAX\x10\x01\x12\x10\n\x0c\x43OMBINER_AVG\x10\x02\x32\xdb\x01\n\rSearchService\x12\x37\n\x06Search\x12\x15.hermes.SearchRequest\x1a\x16.hermes.SearchResponse\x12\x46\n\x0bGetDocument\x12\x1a.hermes.GetDocumentRequest\x1a\x1b.hermes.GetDocumentResponse\x12I\n\x0cGetIndexInfo\x12\x1b.hermes.GetIndexInfoRequest\x1a\x1c.hermes.GetIndexInfoResponse2\xce\x03\n\x0cIndexService\x12\x46\n\x0b\x43reateIndex\x12\x1a.hermes.CreateIndexRequest\x1a\x1b.hermes.CreateIndexResponse\x12P\n\x0eIndexDocuments\x12\x1c.hermes.IndexDocumentRequest\x1a\x1e.hermes.IndexDocumentsResponse(\x01\x12^\n\x13\x42\x61tchIndexDocuments\x12\".hermes.BatchIndexDocumentsRequest\x1a#.hermes.BatchIndexDocumentsResponse\x12\x37\n\x06\x43ommit\x12\x15.hermes.CommitRequest\x1a\x16.hermes.CommitResponse\x12\x43\n\nForceMerge\x12\x19.hermes.ForceMergeRequest\x1a\x1a.hermes.ForceMergeResponse\x12\x46\n\x0b\x44\x65leteIndex\x12\x1a.hermes.DeleteIndexRequest\x1a\x1b.hermes.DeleteIndexResponseb\x06proto3')
28
+
29
+ _globals = globals()
30
+ _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
31
+ _builder.BuildTopDescriptorsAndMessages(DESCRIPTOR, 'hermes_pb2', _globals)
32
+ if not _descriptor._USE_C_DESCRIPTORS:
33
+ DESCRIPTOR._loaded_options = None
34
+ _globals['_SEARCHHIT_FIELDSENTRY']._loaded_options = None
35
+ _globals['_SEARCHHIT_FIELDSENTRY']._serialized_options = b'8\001'
36
+ _globals['_GETDOCUMENTRESPONSE_FIELDSENTRY']._loaded_options = None
37
+ _globals['_GETDOCUMENTRESPONSE_FIELDSENTRY']._serialized_options = b'8\001'
38
+ _globals['_MULTIVALUECOMBINER']._serialized_start=2699
39
+ _globals['_MULTIVALUECOMBINER']._serialized_end=2773
40
+ _globals['_QUERY']._serialized_start=25
41
+ _globals['_QUERY']._serialized_end=289
42
+ _globals['_SPARSEVECTORQUERY']._serialized_start=292
43
+ _globals['_SPARSEVECTORQUERY']._serialized_end=440
44
+ _globals['_DENSEVECTORQUERY']._serialized_start=443
45
+ _globals['_DENSEVECTORQUERY']._serialized_end=577
46
+ _globals['_TERMQUERY']._serialized_start=579
47
+ _globals['_TERMQUERY']._serialized_end=619
48
+ _globals['_BOOLEANQUERY']._serialized_start=621
49
+ _globals['_BOOLEANQUERY']._serialized_end=728
50
+ _globals['_BOOSTQUERY']._serialized_start=730
51
+ _globals['_BOOSTQUERY']._serialized_end=787
52
+ _globals['_ALLQUERY']._serialized_start=789
53
+ _globals['_ALLQUERY']._serialized_end=799
54
+ _globals['_SEARCHREQUEST']._serialized_start=801
55
+ _globals['_SEARCHREQUEST']._serialized_end=921
56
+ _globals['_SEARCHHIT']._serialized_start=924
57
+ _globals['_SEARCHHIT']._serialized_end=1126
58
+ _globals['_SEARCHHIT_FIELDSENTRY']._serialized_start=1061
59
+ _globals['_SEARCHHIT_FIELDSENTRY']._serialized_end=1126
60
+ _globals['_ORDINALSCORE']._serialized_start=1128
61
+ _globals['_ORDINALSCORE']._serialized_end=1174
62
+ _globals['_FIELDVALUE']._serialized_start=1177
63
+ _globals['_FIELDVALUE']._serialized_end=1396
64
+ _globals['_SPARSEVECTOR']._serialized_start=1398
65
+ _globals['_SPARSEVECTOR']._serialized_end=1445
66
+ _globals['_DENSEVECTOR']._serialized_start=1447
67
+ _globals['_DENSEVECTOR']._serialized_end=1476
68
+ _globals['_SEARCHRESPONSE']._serialized_start=1478
69
+ _globals['_SEARCHRESPONSE']._serialized_end=1564
70
+ _globals['_GETDOCUMENTREQUEST']._serialized_start=1566
71
+ _globals['_GETDOCUMENTREQUEST']._serialized_end=1622
72
+ _globals['_GETDOCUMENTRESPONSE']._serialized_start=1625
73
+ _globals['_GETDOCUMENTRESPONSE']._serialized_end=1770
74
+ _globals['_GETDOCUMENTRESPONSE_FIELDSENTRY']._serialized_start=1061
75
+ _globals['_GETDOCUMENTRESPONSE_FIELDSENTRY']._serialized_end=1126
76
+ _globals['_GETINDEXINFOREQUEST']._serialized_start=1772
77
+ _globals['_GETINDEXINFOREQUEST']._serialized_end=1813
78
+ _globals['_GETINDEXINFORESPONSE']._serialized_start=1815
79
+ _globals['_GETINDEXINFORESPONSE']._serialized_end=1913
80
+ _globals['_CREATEINDEXREQUEST']._serialized_start=1915
81
+ _globals['_CREATEINDEXREQUEST']._serialized_end=1971
82
+ _globals['_CREATEINDEXRESPONSE']._serialized_start=1973
83
+ _globals['_CREATEINDEXRESPONSE']._serialized_end=2011
84
+ _globals['_FIELDENTRY']._serialized_start=2013
85
+ _globals['_FIELDENTRY']._serialized_end=2074
86
+ _globals['_NAMEDDOCUMENT']._serialized_start=2076
87
+ _globals['_NAMEDDOCUMENT']._serialized_end=2127
88
+ _globals['_BATCHINDEXDOCUMENTSREQUEST']._serialized_start=2129
89
+ _globals['_BATCHINDEXDOCUMENTSREQUEST']._serialized_end=2219
90
+ _globals['_BATCHINDEXDOCUMENTSRESPONSE']._serialized_start=2221
91
+ _globals['_BATCHINDEXDOCUMENTSRESPONSE']._serialized_end=2294
92
+ _globals['_INDEXDOCUMENTREQUEST']._serialized_start=2296
93
+ _globals['_INDEXDOCUMENTREQUEST']._serialized_end=2374
94
+ _globals['_INDEXDOCUMENTSRESPONSE']._serialized_start=2376
95
+ _globals['_INDEXDOCUMENTSRESPONSE']._serialized_end=2423
96
+ _globals['_COMMITREQUEST']._serialized_start=2425
97
+ _globals['_COMMITREQUEST']._serialized_end=2460
98
+ _globals['_COMMITRESPONSE']._serialized_start=2462
99
+ _globals['_COMMITRESPONSE']._serialized_end=2513
100
+ _globals['_FORCEMERGEREQUEST']._serialized_start=2515
101
+ _globals['_FORCEMERGEREQUEST']._serialized_end=2554
102
+ _globals['_FORCEMERGERESPONSE']._serialized_start=2556
103
+ _globals['_FORCEMERGERESPONSE']._serialized_end=2615
104
+ _globals['_DELETEINDEXREQUEST']._serialized_start=2617
105
+ _globals['_DELETEINDEXREQUEST']._serialized_end=2657
106
+ _globals['_DELETEINDEXRESPONSE']._serialized_start=2659
107
+ _globals['_DELETEINDEXRESPONSE']._serialized_end=2697
108
+ _globals['_SEARCHSERVICE']._serialized_start=2776
109
+ _globals['_SEARCHSERVICE']._serialized_end=2995
110
+ _globals['_INDEXSERVICE']._serialized_start=2998
111
+ _globals['_INDEXSERVICE']._serialized_end=3460
112
+ # @@protoc_insertion_point(module_scope)
@@ -1,108 +0,0 @@
1
- # -*- coding: utf-8 -*-
2
- # Generated by the protocol buffer compiler. DO NOT EDIT!
3
- # NO CHECKED-IN PROTOBUF GENCODE
4
- # source: hermes.proto
5
- # Protobuf Python Version: 6.31.1
6
- """Generated protocol buffer code."""
7
- from google.protobuf import descriptor as _descriptor
8
- from google.protobuf import descriptor_pool as _descriptor_pool
9
- from google.protobuf import runtime_version as _runtime_version
10
- from google.protobuf import symbol_database as _symbol_database
11
- from google.protobuf.internal import builder as _builder
12
- _runtime_version.ValidateProtobufRuntimeVersion(
13
- _runtime_version.Domain.PUBLIC,
14
- 6,
15
- 31,
16
- 1,
17
- '',
18
- 'hermes.proto'
19
- )
20
- # @@protoc_insertion_point(imports)
21
-
22
- _sym_db = _symbol_database.Default()
23
-
24
-
25
-
26
-
27
- DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x0chermes.proto\x12\x06hermes\"\x88\x02\n\x05Query\x12!\n\x04term\x18\x01 \x01(\x0b\x32\x11.hermes.TermQueryH\x00\x12\'\n\x07\x62oolean\x18\x02 \x01(\x0b\x32\x14.hermes.BooleanQueryH\x00\x12#\n\x05\x62oost\x18\x03 \x01(\x0b\x32\x12.hermes.BoostQueryH\x00\x12\x1f\n\x03\x61ll\x18\x04 \x01(\x0b\x32\x10.hermes.AllQueryH\x00\x12\x32\n\rsparse_vector\x18\x05 \x01(\x0b\x32\x19.hermes.SparseVectorQueryH\x00\x12\x30\n\x0c\x64\x65nse_vector\x18\x06 \x01(\x0b\x32\x18.hermes.DenseVectorQueryH\x00\x42\x07\n\x05query\"Q\n\x11SparseVectorQuery\x12\r\n\x05\x66ield\x18\x01 \x01(\t\x12\x0f\n\x07indices\x18\x02 \x03(\r\x12\x0e\n\x06values\x18\x03 \x03(\x02\x12\x0c\n\x04text\x18\x04 \x01(\t\"X\n\x10\x44\x65nseVectorQuery\x12\r\n\x05\x66ield\x18\x01 \x01(\t\x12\x0e\n\x06vector\x18\x02 \x03(\x02\x12\x0e\n\x06nprobe\x18\x03 \x01(\r\x12\x15\n\rrerank_factor\x18\x04 \x01(\r\"(\n\tTermQuery\x12\r\n\x05\x66ield\x18\x01 \x01(\t\x12\x0c\n\x04term\x18\x02 \x01(\t\"k\n\x0c\x42ooleanQuery\x12\x1b\n\x04must\x18\x01 \x03(\x0b\x32\r.hermes.Query\x12\x1d\n\x06should\x18\x02 \x03(\x0b\x32\r.hermes.Query\x12\x1f\n\x08must_not\x18\x03 \x03(\x0b\x32\r.hermes.Query\"9\n\nBoostQuery\x12\x1c\n\x05query\x18\x01 \x01(\x0b\x32\r.hermes.Query\x12\r\n\x05\x62oost\x18\x02 \x01(\x02\"\n\n\x08\x41llQuery\"x\n\rSearchRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\x12\x1c\n\x05query\x18\x02 \x01(\x0b\x32\r.hermes.Query\x12\r\n\x05limit\x18\x03 \x01(\r\x12\x0e\n\x06offset\x18\x04 \x01(\r\x12\x16\n\x0e\x66ields_to_load\x18\x05 \x03(\t\"\x9c\x01\n\tSearchHit\x12\x0e\n\x06\x64oc_id\x18\x01 \x01(\r\x12\r\n\x05score\x18\x02 \x01(\x02\x12-\n\x06\x66ields\x18\x03 \x03(\x0b\x32\x1d.hermes.SearchHit.FieldsEntry\x1a\x41\n\x0b\x46ieldsEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12!\n\x05value\x18\x02 \x01(\x0b\x32\x12.hermes.FieldValue:\x02\x38\x01\"\xdb\x01\n\nFieldValue\x12\x0e\n\x04text\x18\x01 \x01(\tH\x00\x12\r\n\x03u64\x18\x02 \x01(\x04H\x00\x12\r\n\x03i64\x18\x03 \x01(\x03H\x00\x12\r\n\x03\x66\x36\x34\x18\x04 \x01(\x01H\x00\x12\x15\n\x0b\x62ytes_value\x18\x05 \x01(\x0cH\x00\x12-\n\rsparse_vector\x18\x06 \x01(\x0b\x32\x14.hermes.SparseVectorH\x00\x12+\n\x0c\x64\x65nse_vector\x18\x07 \x01(\x0b\x32\x13.hermes.DenseVectorH\x00\x12\x14\n\njson_value\x18\x08 \x01(\tH\x00\x42\x07\n\x05value\"/\n\x0cSparseVector\x12\x0f\n\x07indices\x18\x01 \x03(\r\x12\x0e\n\x06values\x18\x02 \x03(\x02\"\x1d\n\x0b\x44\x65nseVector\x12\x0e\n\x06values\x18\x01 \x03(\x02\"V\n\x0eSearchResponse\x12\x1f\n\x04hits\x18\x01 \x03(\x0b\x32\x11.hermes.SearchHit\x12\x12\n\ntotal_hits\x18\x02 \x01(\r\x12\x0f\n\x07took_ms\x18\x03 \x01(\x04\"8\n\x12GetDocumentRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\x12\x0e\n\x06\x64oc_id\x18\x02 \x01(\r\"\x91\x01\n\x13GetDocumentResponse\x12\x37\n\x06\x66ields\x18\x01 \x03(\x0b\x32\'.hermes.GetDocumentResponse.FieldsEntry\x1a\x41\n\x0b\x46ieldsEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12!\n\x05value\x18\x02 \x01(\x0b\x32\x12.hermes.FieldValue:\x02\x38\x01\")\n\x13GetIndexInfoRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\"b\n\x14GetIndexInfoResponse\x12\x12\n\nindex_name\x18\x01 \x01(\t\x12\x10\n\x08num_docs\x18\x02 \x01(\r\x12\x14\n\x0cnum_segments\x18\x03 \x01(\r\x12\x0e\n\x06schema\x18\x04 \x01(\t\"8\n\x12\x43reateIndexRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\x12\x0e\n\x06schema\x18\x02 \x01(\t\"&\n\x13\x43reateIndexResponse\x12\x0f\n\x07success\x18\x01 \x01(\x08\"=\n\nFieldEntry\x12\x0c\n\x04name\x18\x01 \x01(\t\x12!\n\x05value\x18\x02 \x01(\x0b\x32\x12.hermes.FieldValue\"3\n\rNamedDocument\x12\"\n\x06\x66ields\x18\x01 \x03(\x0b\x32\x12.hermes.FieldEntry\"Z\n\x1a\x42\x61tchIndexDocumentsRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\x12(\n\tdocuments\x18\x02 \x03(\x0b\x32\x15.hermes.NamedDocument\"I\n\x1b\x42\x61tchIndexDocumentsResponse\x12\x15\n\rindexed_count\x18\x01 \x01(\r\x12\x13\n\x0b\x65rror_count\x18\x02 \x01(\r\"N\n\x14IndexDocumentRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\x12\"\n\x06\x66ields\x18\x02 \x03(\x0b\x32\x12.hermes.FieldEntry\"/\n\x16IndexDocumentsResponse\x12\x15\n\rindexed_count\x18\x01 \x01(\r\"#\n\rCommitRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\"3\n\x0e\x43ommitResponse\x12\x0f\n\x07success\x18\x01 \x01(\x08\x12\x10\n\x08num_docs\x18\x02 \x01(\r\"\'\n\x11\x46orceMergeRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\";\n\x12\x46orceMergeResponse\x12\x0f\n\x07success\x18\x01 \x01(\x08\x12\x14\n\x0cnum_segments\x18\x02 \x01(\r\"(\n\x12\x44\x65leteIndexRequest\x12\x12\n\nindex_name\x18\x01 \x01(\t\"&\n\x13\x44\x65leteIndexResponse\x12\x0f\n\x07success\x18\x01 \x01(\x08\x32\xdb\x01\n\rSearchService\x12\x37\n\x06Search\x12\x15.hermes.SearchRequest\x1a\x16.hermes.SearchResponse\x12\x46\n\x0bGetDocument\x12\x1a.hermes.GetDocumentRequest\x1a\x1b.hermes.GetDocumentResponse\x12I\n\x0cGetIndexInfo\x12\x1b.hermes.GetIndexInfoRequest\x1a\x1c.hermes.GetIndexInfoResponse2\xce\x03\n\x0cIndexService\x12\x46\n\x0b\x43reateIndex\x12\x1a.hermes.CreateIndexRequest\x1a\x1b.hermes.CreateIndexResponse\x12P\n\x0eIndexDocuments\x12\x1c.hermes.IndexDocumentRequest\x1a\x1e.hermes.IndexDocumentsResponse(\x01\x12^\n\x13\x42\x61tchIndexDocuments\x12\".hermes.BatchIndexDocumentsRequest\x1a#.hermes.BatchIndexDocumentsResponse\x12\x37\n\x06\x43ommit\x12\x15.hermes.CommitRequest\x1a\x16.hermes.CommitResponse\x12\x43\n\nForceMerge\x12\x19.hermes.ForceMergeRequest\x1a\x1a.hermes.ForceMergeResponse\x12\x46\n\x0b\x44\x65leteIndex\x12\x1a.hermes.DeleteIndexRequest\x1a\x1b.hermes.DeleteIndexResponseb\x06proto3')
28
-
29
- _globals = globals()
30
- _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
31
- _builder.BuildTopDescriptorsAndMessages(DESCRIPTOR, 'hermes_pb2', _globals)
32
- if not _descriptor._USE_C_DESCRIPTORS:
33
- DESCRIPTOR._loaded_options = None
34
- _globals['_SEARCHHIT_FIELDSENTRY']._loaded_options = None
35
- _globals['_SEARCHHIT_FIELDSENTRY']._serialized_options = b'8\001'
36
- _globals['_GETDOCUMENTRESPONSE_FIELDSENTRY']._loaded_options = None
37
- _globals['_GETDOCUMENTRESPONSE_FIELDSENTRY']._serialized_options = b'8\001'
38
- _globals['_QUERY']._serialized_start=25
39
- _globals['_QUERY']._serialized_end=289
40
- _globals['_SPARSEVECTORQUERY']._serialized_start=291
41
- _globals['_SPARSEVECTORQUERY']._serialized_end=372
42
- _globals['_DENSEVECTORQUERY']._serialized_start=374
43
- _globals['_DENSEVECTORQUERY']._serialized_end=462
44
- _globals['_TERMQUERY']._serialized_start=464
45
- _globals['_TERMQUERY']._serialized_end=504
46
- _globals['_BOOLEANQUERY']._serialized_start=506
47
- _globals['_BOOLEANQUERY']._serialized_end=613
48
- _globals['_BOOSTQUERY']._serialized_start=615
49
- _globals['_BOOSTQUERY']._serialized_end=672
50
- _globals['_ALLQUERY']._serialized_start=674
51
- _globals['_ALLQUERY']._serialized_end=684
52
- _globals['_SEARCHREQUEST']._serialized_start=686
53
- _globals['_SEARCHREQUEST']._serialized_end=806
54
- _globals['_SEARCHHIT']._serialized_start=809
55
- _globals['_SEARCHHIT']._serialized_end=965
56
- _globals['_SEARCHHIT_FIELDSENTRY']._serialized_start=900
57
- _globals['_SEARCHHIT_FIELDSENTRY']._serialized_end=965
58
- _globals['_FIELDVALUE']._serialized_start=968
59
- _globals['_FIELDVALUE']._serialized_end=1187
60
- _globals['_SPARSEVECTOR']._serialized_start=1189
61
- _globals['_SPARSEVECTOR']._serialized_end=1236
62
- _globals['_DENSEVECTOR']._serialized_start=1238
63
- _globals['_DENSEVECTOR']._serialized_end=1267
64
- _globals['_SEARCHRESPONSE']._serialized_start=1269
65
- _globals['_SEARCHRESPONSE']._serialized_end=1355
66
- _globals['_GETDOCUMENTREQUEST']._serialized_start=1357
67
- _globals['_GETDOCUMENTREQUEST']._serialized_end=1413
68
- _globals['_GETDOCUMENTRESPONSE']._serialized_start=1416
69
- _globals['_GETDOCUMENTRESPONSE']._serialized_end=1561
70
- _globals['_GETDOCUMENTRESPONSE_FIELDSENTRY']._serialized_start=900
71
- _globals['_GETDOCUMENTRESPONSE_FIELDSENTRY']._serialized_end=965
72
- _globals['_GETINDEXINFOREQUEST']._serialized_start=1563
73
- _globals['_GETINDEXINFOREQUEST']._serialized_end=1604
74
- _globals['_GETINDEXINFORESPONSE']._serialized_start=1606
75
- _globals['_GETINDEXINFORESPONSE']._serialized_end=1704
76
- _globals['_CREATEINDEXREQUEST']._serialized_start=1706
77
- _globals['_CREATEINDEXREQUEST']._serialized_end=1762
78
- _globals['_CREATEINDEXRESPONSE']._serialized_start=1764
79
- _globals['_CREATEINDEXRESPONSE']._serialized_end=1802
80
- _globals['_FIELDENTRY']._serialized_start=1804
81
- _globals['_FIELDENTRY']._serialized_end=1865
82
- _globals['_NAMEDDOCUMENT']._serialized_start=1867
83
- _globals['_NAMEDDOCUMENT']._serialized_end=1918
84
- _globals['_BATCHINDEXDOCUMENTSREQUEST']._serialized_start=1920
85
- _globals['_BATCHINDEXDOCUMENTSREQUEST']._serialized_end=2010
86
- _globals['_BATCHINDEXDOCUMENTSRESPONSE']._serialized_start=2012
87
- _globals['_BATCHINDEXDOCUMENTSRESPONSE']._serialized_end=2085
88
- _globals['_INDEXDOCUMENTREQUEST']._serialized_start=2087
89
- _globals['_INDEXDOCUMENTREQUEST']._serialized_end=2165
90
- _globals['_INDEXDOCUMENTSRESPONSE']._serialized_start=2167
91
- _globals['_INDEXDOCUMENTSRESPONSE']._serialized_end=2214
92
- _globals['_COMMITREQUEST']._serialized_start=2216
93
- _globals['_COMMITREQUEST']._serialized_end=2251
94
- _globals['_COMMITRESPONSE']._serialized_start=2253
95
- _globals['_COMMITRESPONSE']._serialized_end=2304
96
- _globals['_FORCEMERGEREQUEST']._serialized_start=2306
97
- _globals['_FORCEMERGEREQUEST']._serialized_end=2345
98
- _globals['_FORCEMERGERESPONSE']._serialized_start=2347
99
- _globals['_FORCEMERGERESPONSE']._serialized_end=2406
100
- _globals['_DELETEINDEXREQUEST']._serialized_start=2408
101
- _globals['_DELETEINDEXREQUEST']._serialized_end=2448
102
- _globals['_DELETEINDEXRESPONSE']._serialized_start=2450
103
- _globals['_DELETEINDEXRESPONSE']._serialized_end=2488
104
- _globals['_SEARCHSERVICE']._serialized_start=2491
105
- _globals['_SEARCHSERVICE']._serialized_end=2710
106
- _globals['_INDEXSERVICE']._serialized_start=2713
107
- _globals['_INDEXSERVICE']._serialized_end=3175
108
- # @@protoc_insertion_point(module_scope)