Add hydrus search builder for complex searches
Signed-off-by: trivernis <trivernis@protonmail.com>pull/5/head
parent
ad30c14ddb
commit
2a297c0636
@ -1,3 +1,4 @@
|
||||
pub mod import_builder;
|
||||
pub mod tagging_builder;
|
||||
pub mod tag_builder;
|
||||
pub mod search_builder;
|
||||
|
@ -0,0 +1,115 @@
|
||||
use crate::api_core::searching_and_fetching_files::FileSearchOptions;
|
||||
use crate::error::Result;
|
||||
use crate::utils::tag_list_to_string_list;
|
||||
use crate::wrapper::hydrus_file::HydrusFile;
|
||||
use crate::wrapper::service::ServiceName;
|
||||
use crate::wrapper::tag::Tag;
|
||||
use crate::Client;
|
||||
|
||||
pub enum SortType {
|
||||
FileSize,
|
||||
Duration,
|
||||
ImportTime,
|
||||
FileType,
|
||||
Random,
|
||||
Width,
|
||||
Height,
|
||||
Ratio,
|
||||
NumberOfPixels,
|
||||
NumberOfTags,
|
||||
NumberOfMediaViewers,
|
||||
MediaViewTime,
|
||||
Bitrate,
|
||||
HasAudio,
|
||||
ModifiedTime,
|
||||
Framerate,
|
||||
NumberOfFrames,
|
||||
}
|
||||
|
||||
#[derive(Clone, Debug)]
|
||||
pub struct SearchBuilder {
|
||||
client: Client,
|
||||
tags: Vec<Tag>,
|
||||
options: FileSearchOptions,
|
||||
}
|
||||
|
||||
impl SearchBuilder {
|
||||
pub(crate) fn new(client: Client) -> Self {
|
||||
Self {
|
||||
client,
|
||||
tags: Vec::new(),
|
||||
options: FileSearchOptions::new(),
|
||||
}
|
||||
}
|
||||
|
||||
/// Add multiple tags to filter by
|
||||
pub fn add_tags(mut self, mut tags: Vec<Tag>) -> Self {
|
||||
self.tags.append(&mut tags);
|
||||
self
|
||||
}
|
||||
|
||||
/// Add a tag to filter by
|
||||
pub fn add_tag(mut self, tag: Tag) -> Self {
|
||||
self.tags.push(tag);
|
||||
self
|
||||
}
|
||||
|
||||
/// Sets the sort type
|
||||
pub fn sort_by(mut self, sort_type: SortType) -> Self {
|
||||
self.options = self.options.sort_type(sort_type as u8);
|
||||
self
|
||||
}
|
||||
|
||||
/// Sorts descending
|
||||
pub fn sort_descending(mut self) -> Self {
|
||||
self.options = self.options.desc();
|
||||
self
|
||||
}
|
||||
|
||||
/// Sorts ascending
|
||||
pub fn sort_ascending(mut self) -> Self {
|
||||
self.options = self.options.asc();
|
||||
self
|
||||
}
|
||||
|
||||
/// Sets the file service name to search in
|
||||
pub fn file_service_name(mut self, service: ServiceName) -> Self {
|
||||
self.options = self.options.file_service_name(service);
|
||||
self
|
||||
}
|
||||
|
||||
/// Sets the tag service to search by
|
||||
pub fn tag_service_name(mut self, service: ServiceName) -> Self {
|
||||
self.options = self.options.tag_service_name(service);
|
||||
self
|
||||
}
|
||||
|
||||
/// Sets the file service key. This option is preferred over
|
||||
/// setting it by name because it's faster
|
||||
pub fn file_service_key<S: ToString>(mut self, key: S) -> Self {
|
||||
self.options = self.options.file_service_key(key);
|
||||
self
|
||||
}
|
||||
|
||||
/// Sets the tag service key. This option is preferred over
|
||||
/// setting it by name because it's faster
|
||||
pub fn tag_service_key<S: ToString>(mut self, key: S) -> Self {
|
||||
self.options = self.options.tag_service_key(key);
|
||||
self
|
||||
}
|
||||
|
||||
/// Runs the search
|
||||
pub async fn run(self) -> Result<Vec<HydrusFile>> {
|
||||
let client = self.client.clone();
|
||||
let response = client
|
||||
.search_files(tag_list_to_string_list(self.tags), self.options)
|
||||
.await?;
|
||||
let files = response
|
||||
.file_ids
|
||||
.into_iter()
|
||||
.map(|id| HydrusFile::from_id(client.clone(), id))
|
||||
.collect();
|
||||
|
||||
Ok(files)
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue