Add bulk tagging support

Signed-off-by: trivernis <trivernis@protonmail.com>
pull/1/head
trivernis 3 years ago
parent d3b4093f93
commit 9ca1715177
Signed by: Trivernis
GPG Key ID: DFFFCC2C7A02DB45

@ -42,7 +42,7 @@ pub struct AddTagsRequestBuilder {
} }
/// List of actions for a given tag /// List of actions for a given tag
#[derive(Clone, Debug)] #[derive(Clone, Debug, PartialOrd, PartialEq, Hash)]
pub enum TagAction { pub enum TagAction {
/// Add to a local tag service. /// Add to a local tag service.
AddToLocalService, AddToLocalService,
@ -63,6 +63,8 @@ pub enum TagAction {
RescindPetitionFromRepository, RescindPetitionFromRepository,
} }
impl Eq for TagAction {}
impl TagAction { impl TagAction {
fn into_id(self) -> u8 { fn into_id(self) -> u8 {
match self { match self {

@ -1 +1,2 @@
pub mod import_builder; pub mod import_builder;
pub mod tagging_builder;

@ -0,0 +1,70 @@
use crate::endpoints::adding_tags::{AddTagsRequestBuilder, TagAction};
use crate::error::Result;
use crate::models::tag::Tag;
use crate::service::ServiceName;
use crate::Client;
use std::collections::HashMap;
pub struct TaggingBuilder {
client: Client,
hashes: Vec<String>,
tag_mappings: HashMap<ServiceName, HashMap<TagAction, Vec<Tag>>>,
}
impl TaggingBuilder {
pub(crate) fn new(client: Client) -> Self {
Self {
client,
hashes: Vec::new(),
tag_mappings: Default::default(),
}
}
/// Adds a file that should get the tags defined for this request
pub fn add_file<S: ToString>(mut self, hash: S) -> Self {
self.hashes.push(hash.to_string());
self
}
/// Adds a single tag for a given service
pub fn add_tag(self, service: ServiceName, action: TagAction, tag: Tag) -> Self {
self.add_tags(service, action, vec![tag])
}
/// Adds tags with actions for the given service
pub fn add_tags(mut self, service: ServiceName, action: TagAction, mut tags: Vec<Tag>) -> Self {
let service_action_mappings =
if let Some(service_action_mappings) = self.tag_mappings.get_mut(&service) {
service_action_mappings
} else {
self.tag_mappings.insert(service.clone(), HashMap::new());
self.tag_mappings.get_mut(&service).unwrap()
};
if let Some(action_tag_mappings) = service_action_mappings.get_mut(&action) {
action_tag_mappings.append(&mut tags)
} else {
service_action_mappings.insert(action, tags);
}
self
}
/// Executes the request
pub async fn run(self) -> Result<()> {
let mut request = AddTagsRequestBuilder::default().add_hashes(self.hashes);
for (service, action_tag_mappings) in self.tag_mappings {
for (action, tags) in action_tag_mappings {
for tag in tags {
request = request.add_tag_with_action(
service.0.clone(),
tag.to_string(),
action.clone(),
);
}
}
}
self.client.add_tags(request.build()).await
}
}

@ -1,4 +1,5 @@
use crate::builders::import_builder::ImportBuilder; use crate::builders::import_builder::ImportBuilder;
use crate::builders::tagging_builder::TaggingBuilder;
use crate::endpoints::common::FileIdentifier; use crate::endpoints::common::FileIdentifier;
use crate::endpoints::searching_and_fetching_files::FileSearchLocation; use crate::endpoints::searching_and_fetching_files::FileSearchLocation;
use crate::error::Result; use crate::error::Result;
@ -68,6 +69,11 @@ impl Hydrus {
Ok(HydrusFile::from_metadata(self.client.clone(), metadata)) Ok(HydrusFile::from_metadata(self.client.clone(), metadata))
} }
/// Starts a request to bulk add tags to files
pub fn tagging(&self) -> TaggingBuilder {
TaggingBuilder::new(self.client.clone())
}
/// Searches for files that have the given tags and returns a list of hydrus files as a result /// Searches for files that have the given tags and returns a list of hydrus files as a result
pub async fn search( pub async fn search(
&self, &self,

@ -1,6 +1,7 @@
use super::super::common; use super::super::common;
use hydrus_api::endpoints::adding_tags::TagAction;
use hydrus_api::endpoints::searching_and_fetching_files::FileSearchLocation; use hydrus_api::endpoints::searching_and_fetching_files::FileSearchLocation;
use hydrus_api::service::ServiceType; use hydrus_api::service::{ServiceName, ServiceType};
use hydrus_api::url::UrlType; use hydrus_api::url::UrlType;
#[tokio::test] #[tokio::test]
@ -43,3 +44,19 @@ async fn it_searches() {
.await .await
.unwrap(); .unwrap();
} }
#[tokio::test]
async fn it_adds_tags() {
let hydrus = common::get_hydrus();
hydrus
.tagging()
.add_tag(
ServiceName::my_tags(),
TagAction::AddToLocalService,
"summer".into(),
)
.add_file("0000000000000000000000000000000000000000000000000000000000000000")
.run()
.await
.unwrap();
}

Loading…
Cancel
Save