feat: Implement merge person functionality with associated request and repository methods

This commit is contained in:
2025-11-15 17:46:36 +01:00
parent 8a735c7c26
commit b80c4e0895
6 changed files with 91 additions and 14 deletions

View File

@@ -1,5 +1,9 @@
use async_trait::async_trait;
use libertas_core::{error::{CoreError, CoreResult}, models::FaceRegion, repositories::FaceRegionRepository};
use libertas_core::{
error::{CoreError, CoreResult},
models::FaceRegion,
repositories::FaceRegionRepository,
};
use sqlx::PgPool;
use uuid::Uuid;
@@ -125,4 +129,20 @@ impl FaceRegionRepository for PostgresFaceRegionRepository {
.map_err(|e| CoreError::Database(e.to_string()))?;
Ok(())
}
}
async fn reassign_person(&self, old_person_id: Uuid, new_person_id: Uuid) -> CoreResult<()> {
sqlx::query!(
r#"
UPDATE face_regions
SET person_id = $1
WHERE person_id = $2
"#,
new_person_id,
old_person_id
)
.execute(&self.pool)
.await
.map_err(|e| CoreError::Database(e.to_string()))?;
Ok(())
}
}