use chrono::{DateTime, Utc};
use serde::{Deserialize, Serialize};
use uuid::Uuid;
use utoipa::ToSchema;
#[derive(Debug, Clone, Serialize, Deserialize, ToSchema, PartialEq, Eq)]
#[serde(rename_all = "lowercase")]
pub enum ReviewStatus {
Pending,
Confirmed,
Rejected,
AutoMerged,
}
#[derive(Debug, Clone, Serialize, Deserialize, ToSchema)]
pub struct ReviewQueueItem {
pub id: Uuid,
pub worker_id_a: Uuid,
pub worker_id_b: Uuid,
pub match_score: f64,
pub match_quality: String,
pub detection_method: String,
pub score_breakdown: Option<serde_json::Value>,
pub status: ReviewStatus,
pub reviewed_by: Option<String>,
pub created_at: DateTime<Utc>,
pub reviewed_at: Option<DateTime<Utc>>,
}
#[derive(Debug, Deserialize, ToSchema)]
pub struct BatchDeduplicationRequest {
#[serde(default = "default_threshold")]
pub threshold: f64,
#[serde(default = "default_max_candidates")]
pub max_candidates: usize,
#[serde(default = "default_auto_merge_threshold")]
pub auto_merge_threshold: f64,
}
fn default_threshold() -> f64 {
0.7
}
fn default_max_candidates() -> usize {
50
}
fn default_auto_merge_threshold() -> f64 {
0.95
}
#[derive(Debug, Serialize, ToSchema)]
pub struct BatchDeduplicationResponse {
pub workers_scanned: usize,
pub duplicates_found: usize,
pub auto_merged: usize,
pub queued_for_review: usize,
pub review_items: Vec<ReviewQueueItem>,
}