Skip to content

Commit

Permalink
perf(backend): update 3 media items at once
Browse files Browse the repository at this point in the history
  • Loading branch information
IgnisDa committed Dec 16, 2024
1 parent 98bb0a5 commit 5bc62a4
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 11 deletions.
2 changes: 1 addition & 1 deletion apps/backend/src/job.rs
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@ pub async fn perform_application_job(
.await
.is_ok(),
ApplicationJob::UpdatePerson(person_id) => misc_service
.update_person_and_notify_users(person_id)
.update_person_and_notify_users(&person_id)
.await
.is_ok(),
ApplicationJob::HandleAfterMediaSeenTasks(seen) => misc_service
Expand Down
20 changes: 10 additions & 10 deletions crates/services/miscellaneous/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ use enums::{
EntityLot, MediaLot, MediaSource, MetadataToMetadataRelation, SeenState, UserNotificationLot,
UserToMediaReason,
};
use futures::TryStreamExt;
use futures::{future::join_all, TryStreamExt};
use itertools::Itertools;
use markdown::{to_html_with_options as markdown_to_html_opts, CompileOptions, Options};
use media_models::{
Expand Down Expand Up @@ -1896,10 +1896,10 @@ ORDER BY RANDOM() LIMIT 10;
"Users to be notified for metadata state changes: {:?}",
meta_map
);
for (metadata_id, _) in meta_map {
self.update_metadata_and_notify_users(&metadata_id, true)
.await
.ok();
for (m1, m2, m3) in meta_map.keys().tuple_windows() {
let promises = vec![m1, m2, m3].into_iter();
let promises = promises.map(|m| self.update_metadata_and_notify_users(m, true));
join_all(promises).await;
}
Ok(())
}
Expand All @@ -1911,10 +1911,10 @@ ORDER BY RANDOM() LIMIT 10;
"Users to be notified for people state changes: {:?}",
person_map
);
for (person_id, _) in person_map {
self.update_person_and_notify_users(person_id.parse().unwrap())
.await
.ok();
for (p1, p2, p3) in person_map.keys().tuple_windows() {
let promises = vec![p1, p2, p3].into_iter();
let promises = promises.map(|p| self.update_person_and_notify_users(p));
join_all(promises).await;
}
Ok(())
}
Expand Down Expand Up @@ -2596,7 +2596,7 @@ ORDER BY RANDOM() LIMIT 10;
update_metadata_and_notify_users(metadata_id, force_update, &self.0).await
}

pub async fn update_person_and_notify_users(&self, person_id: String) -> Result<()> {
pub async fn update_person_and_notify_users(&self, person_id: &String) -> Result<()> {
let notifications = self
.update_person(person_id.clone())
.await
Expand Down

0 comments on commit 5bc62a4

Please sign in to comment.