Skip to main content

DocumentsClient

Struct DocumentsClient 

Source
pub struct DocumentsClient { /* private fields */ }
Expand description

Sub-client for POST /projects/{pid}/documents{,/claim}. Obtained via [crate::client::ProjectScope::documents].

Implementations§

Source§

impl DocumentsClient

Source

pub async fn progress( &self, content_hash: &str, ) -> Result<Option<IngestProgress>>

Snapshot the server-side conversion progress for a content hash (#1151). Returns None if no in-flight conversion is registered (terminal already, or never uploaded). Cheap — a few-byte JSON response off an in-memory map. Mirrors TS documents.progress and Python documents.progress.

Source

pub async fn claim( &self, content_hash: &str, filename: &str, ) -> Result<ClaimOutcome>

Check whether the server has these bytes cached (by content_hash). On hit, the server creates-or-finds a per-project ref and the SDK returns ClaimOutcome::Hit with the doc_id and current conversion status. On miss, the caller must upload the bytes.

The content_hash returned in UploadResult comes from the server’s response, not the caller’s argument — so a caller that passes a wrong hash gets the server’s authoritative value back.

Source

pub async fn upload( &self, filename: &str, bytes: Vec<u8>, ) -> Result<UploadResult>

Upload bytes. Server hashes, dedups against the blobs table, creates a per-project ref, returns a doc_<uuid> scoped to this project.

Source

pub async fn ingest( &self, filename: &str, bytes: Vec<u8>, ) -> Result<UploadResult>

Convenience: hash locally, call claim, fall back to upload on miss. On hit where the blob is still Converting, polls the claim endpoint until the status is terminal or the configured ingest poll timeout elapses (default 300 s, see crate::AkribesClientBuilder::ingest_poll_timeout). Returns AkribesError::Transient on timeout so the caller can retry. If the server reports Failed (after its own inline auto-reconvert has given up), returns AkribesError::Other.

Trait Implementations§

Source§

impl Clone for DocumentsClient

Source§

fn clone(&self) -> DocumentsClient

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for DocumentsClient

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more