pub struct QueryEngine { /* private fields */ }Expand description
Query engine for semantic search
Implementations§
Source§impl QueryEngine
impl QueryEngine
Sourcepub fn new(
graph: Arc<Mutex<GraphStore>>,
embedder: Arc<EmbeddingEngine>,
) -> Self
pub fn new( graph: Arc<Mutex<GraphStore>>, embedder: Arc<EmbeddingEngine>, ) -> Self
Create a new query engine
Sourcepub fn with_cache_capacity(
graph: Arc<Mutex<GraphStore>>,
embedder: Arc<EmbeddingEngine>,
cache_capacity: usize,
) -> Self
pub fn with_cache_capacity( graph: Arc<Mutex<GraphStore>>, embedder: Arc<EmbeddingEngine>, cache_capacity: usize, ) -> Self
Create a new query engine with custom cache capacity
Sourcepub fn with_context_budget(self, budget: usize) -> Self
pub fn with_context_budget(self, budget: usize) -> Self
Set the context token budget (builder pattern)
Sourcepub fn with_intelligence(
self,
intelligence: Box<dyn IntelligenceEngine>,
) -> Self
pub fn with_intelligence( self, intelligence: Box<dyn IntelligenceEngine>, ) -> Self
Set the intelligence engine for RAG (builder pattern)
Sourcepub fn set_intelligence(&mut self, intelligence: Box<dyn IntelligenceEngine>)
pub fn set_intelligence(&mut self, intelligence: Box<dyn IntelligenceEngine>)
Set or replace the intelligence engine after creation
Sourcepub fn search(&self, query: &str, k: usize) -> Result<Vec<SearchResult>>
pub fn search(&self, query: &str, k: usize) -> Result<Vec<SearchResult>>
Search for relevant chunks using a hybrid (semantic + lexical) approach
Uses integer Reciprocal Rank Fusion (RRF) per CP-003 §7 for deterministic results: Score(d) = 1,000,000 / (k + rank(d))
Sourcepub fn search_semantic(
&self,
query: &str,
k: usize,
) -> Result<Vec<SearchResult>>
pub fn search_semantic( &self, query: &str, k: usize, ) -> Result<Vec<SearchResult>>
Perform purely semantic search (vector only)
Sourcepub fn search_lexical(&self, query: &str, k: usize) -> Result<Vec<SearchResult>>
pub fn search_lexical(&self, query: &str, k: usize) -> Result<Vec<SearchResult>>
Perform purely lexical search (keyword only)
Sourcepub fn search_filtered(
&self,
query: &str,
k: usize,
filters: &[Filter],
) -> Result<Vec<SearchResult>>
pub fn search_filtered( &self, query: &str, k: usize, filters: &[Filter], ) -> Result<Vec<SearchResult>>
Search with filters applied
Per CP-012: Supports filtering by document path, MIME type, and modification time.
Sourcepub fn search_cached(&self, query: &str, k: usize) -> Result<Vec<SearchResult>>
pub fn search_cached(&self, query: &str, k: usize) -> Result<Vec<SearchResult>>
Search with caching
Per CP-020: Uses query cache for faster repeated queries.
Sourcepub fn invalidate_cache(&self) -> Result<()>
pub fn invalidate_cache(&self) -> Result<()>
Invalidate the query cache
Sourcepub fn get_chunks_for_document(&self, doc_id: Uuid) -> Result<Vec<SearchResult>>
pub fn get_chunks_for_document(&self, doc_id: Uuid) -> Result<Vec<SearchResult>>
Get all chunks for a specific document
Sourcepub fn graph(&self) -> Arc<Mutex<GraphStore>>
pub fn graph(&self) -> Arc<Mutex<GraphStore>>
Access the underlying graph store (for testing/debugging)
Sourcepub async fn generate_answer(&self, query: &str) -> Result<GenerationResult>
pub async fn generate_answer(&self, query: &str) -> Result<GenerationResult>
Generate an answer using the knowledge graph and an LLM
Sourcepub fn generate_proof_receipt(
&self,
query: &str,
search_results: &[SearchResult],
identity: &DeviceIdentity,
) -> Result<ProofReceipt>
pub fn generate_proof_receipt( &self, query: &str, search_results: &[SearchResult], identity: &DeviceIdentity, ) -> Result<ProofReceipt>
Generate a cryptographic proof receipt for a query.
This creates a signed, verifiable record of exactly what context was available when a search was performed. The receipt includes Merkle proofs for each chunk, allowing independent verification.
Source§impl QueryEngine
impl QueryEngine
Sourcepub fn live_search(
&self,
query: &str,
remote_results: &[VerifiedRemoteResult],
max_results: usize,
) -> Result<Vec<MergedSearchResult>>
pub fn live_search( &self, query: &str, remote_results: &[VerifiedRemoteResult], max_results: usize, ) -> Result<Vec<MergedSearchResult>>
Perform a live search that dispatches the query to the local index and to remote peers in parallel, merging results via cross-source RRF.
This is the primary search entrypoint when the node has peer connections.
Remote results that arrive within timeout are merged. Local results
are always included regardless of remote availability.
Auto Trait Implementations§
impl !Freeze for QueryEngine
impl !RefUnwindSafe for QueryEngine
impl Send for QueryEngine
impl Sync for QueryEngine
impl Unpin for QueryEngine
impl UnsafeUnpin for QueryEngine
impl !UnwindSafe for QueryEngine
Blanket Implementations§
Source§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
Source§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSend for T
impl<T> DowncastSend for T
Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self to use its Binary implementation when Debug-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self to use its Display implementation when
Debug-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self to use its LowerExp implementation when
Debug-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self to use its LowerHex implementation when
Debug-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self to use its Octal implementation when Debug-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self to use its Pointer implementation when
Debug-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self to use its UpperExp implementation when
Debug-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self to use its UpperHex implementation when
Debug-formatted.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
Source§impl<T> PossiblyOption<T> for T
impl<T> PossiblyOption<T> for T
Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B> of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap() only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.