use std::{fmt::Display, str::FromStr};
use serde::{Deserialize, Serialize};
use crate::clinvar_minimal::pbs;
#[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord)]
pub enum Pathogenicity {
Pathogenic,
LikelyPathogenic,
UncertainSignificance,
LikelyBenign,
Benign,
}
impl Display for Pathogenicity {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
match self {
Pathogenicity::Pathogenic => write!(f, "pathogenic"),
Pathogenicity::LikelyPathogenic => write!(f, "likely pathogenic"),
Pathogenicity::UncertainSignificance => write!(f, "uncertain significance"),
Pathogenicity::LikelyBenign => write!(f, "likely benign"),
Pathogenicity::Benign => write!(f, "benign"),
}
}
}
impl FromStr for Pathogenicity {
type Err = anyhow::Error;
fn from_str(s: &str) -> Result<Self, Self::Err> {
match s {
"pathogenic" => Ok(Pathogenicity::Pathogenic),
"likely pathogenic" => Ok(Pathogenicity::LikelyPathogenic),
"uncertain significance" => Ok(Pathogenicity::UncertainSignificance),
"likely benign" => Ok(Pathogenicity::LikelyBenign),
"benign" => Ok(Pathogenicity::Benign),
_ => anyhow::bail!("Unknown pathogenicity: {}", s),
}
}
}
impl Serialize for Pathogenicity {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where
S: serde::Serializer,
{
serializer.serialize_str(&self.to_string())
}
}
impl<'de> Deserialize<'de> for Pathogenicity {
fn deserialize<D>(d: D) -> Result<Self, D::Error>
where
D: serde::Deserializer<'de>,
{
let s = String::deserialize(d)?;
Self::from_str(&s).map_err(serde::de::Error::custom)
}
}
impl From<Pathogenicity> for pbs::Pathogenicity {
fn from(value: Pathogenicity) -> Self {
match value {
Pathogenicity::Pathogenic => pbs::Pathogenicity::Pathogenic,
Pathogenicity::LikelyPathogenic => pbs::Pathogenicity::LikelyPathogenic,
Pathogenicity::UncertainSignificance => pbs::Pathogenicity::UncertainSignificance,
Pathogenicity::LikelyBenign => pbs::Pathogenicity::LikelyBenign,
Pathogenicity::Benign => pbs::Pathogenicity::Benign,
}
}
}
impl From<i32> for Pathogenicity {
fn from(value: i32) -> Self {
match value {
0 => Pathogenicity::Pathogenic,
1 => Pathogenicity::LikelyPathogenic,
2 => Pathogenicity::UncertainSignificance,
3 => Pathogenicity::LikelyBenign,
4 => Pathogenicity::Benign,
_ => unreachable!(),
}
}
}
#[derive(Serialize, Deserialize, Debug, Clone, PartialEq, Eq)]
pub struct Record {
pub release: String,
pub chromosome: String,
pub start: u32,
pub end: u32,
pub reference: String,
pub alternative: String,
pub vcv: String,
#[serde(deserialize_with = "deserialize_pathogenicity")]
pub summary_clinvar_pathogenicity: Vec<Pathogenicity>,
pub summary_clinvar_gold_stars: u32,
#[serde(deserialize_with = "deserialize_pathogenicity")]
pub summary_paranoid_pathogenicity: Vec<Pathogenicity>,
pub summary_paranoid_gold_stars: u32,
}
fn deserialize_pathogenicity<'de, D>(deserializer: D) -> Result<Vec<Pathogenicity>, D::Error>
where
D: serde::Deserializer<'de>,
{
let s: &str = Deserialize::deserialize(deserializer)?;
let s = s.replace('{', "[").replace('}', "]");
serde_json::from_str(&s).map_err(serde::de::Error::custom)
}