Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
749975dcc7 |
3447
Cargo.lock
generated
Normal file
3447
Cargo.lock
generated
Normal file
File diff suppressed because it is too large
Load Diff
12
Cargo.toml
Normal file
12
Cargo.toml
Normal file
@ -0,0 +1,12 @@
|
||||
[package]
|
||||
edition = "2024"
|
||||
name = "web"
|
||||
version = "0.1.0"
|
||||
|
||||
[dependencies]
|
||||
chrono = { version = "0.4" }
|
||||
fathom-function = { git = "ssh://git@github.com/fathom-io/pipeline-calculations.git", branch = "johnabell/pipeline-route" }
|
||||
pipeline-application = { git = "ssh://git@github.com/fathom-io/pipeline-calculations.git", branch = "johnabell/pipeline-route", features = ["platform-stable"] }
|
||||
serde = { version = "1.0.219", features = ["derive"] }
|
||||
tokio = { version = "1.43.0", features = ["macros", "rt-multi-thread"] }
|
||||
uuid = { version = "1" }
|
||||
69
src/main.rs
Normal file
69
src/main.rs
Normal file
@ -0,0 +1,69 @@
|
||||
use chrono::NaiveDate;
|
||||
use fathom_function::Context;
|
||||
use pipeline_application::application::{
|
||||
Application, InlineInspection, InspectionType, ReportType, ToolTolerances, Env
|
||||
};
|
||||
use serde::{Deserialize, Deserializer};
|
||||
use uuid::Uuid;
|
||||
|
||||
#[fathom_function::function(default(
|
||||
org_id = "2a3e8d73-840a-4596-9df9-3cf7bce87c46",
|
||||
project_id = "67f69bf439da107809237aa1"
|
||||
))]
|
||||
async fn pipeline_route(context: Context, input: Input) -> Result<String, String> {
|
||||
Application::new(Env::QA, context.org_id, &context.project_id)
|
||||
.unwrap()
|
||||
.process_ili_report(
|
||||
uuid::uuid!("01961b6f-3c1b-76f1-8ccb-e4a2fd1b6574"),
|
||||
input.file_details.first().unwrap().file_id,
|
||||
ToolTolerances::default(),
|
||||
input,
|
||||
)
|
||||
.await
|
||||
.unwrap();
|
||||
Ok("Success".to_owned())
|
||||
}
|
||||
|
||||
#[derive(Debug, Deserialize)]
|
||||
struct Input {
|
||||
pipeline_id: Vec<Uuid>,
|
||||
#[serde(deserialize_with = "deserialize_date")]
|
||||
date: NaiveDate,
|
||||
vendor_name: String,
|
||||
report_type: ReportType,
|
||||
/// The inspection type and technology used.
|
||||
inspection_type: InspectionType,
|
||||
file_details: Vec<FileDetails>,
|
||||
// TODO: parse the output of the tool tolerances.
|
||||
}
|
||||
|
||||
impl From<Input> for InlineInspection {
|
||||
fn from(value: Input) -> Self {
|
||||
Self {
|
||||
date: value.date,
|
||||
vendor_name: value.vendor_name,
|
||||
report_type: value.report_type,
|
||||
inspection_type: value.inspection_type,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Debug, Clone, PartialEq, Eq, Deserialize)]
|
||||
#[serde(rename_all = "camelCase")]
|
||||
pub struct FileDetails {
|
||||
pub file_id: Uuid,
|
||||
pub revision_id: Uuid,
|
||||
}
|
||||
|
||||
const FORMAT: &'static str = "%a %b %d %Y";
|
||||
|
||||
pub fn deserialize_date<'de, D>(
|
||||
deserializer: D,
|
||||
) -> Result<NaiveDate, D::Error>
|
||||
where
|
||||
D: Deserializer<'de>,
|
||||
{
|
||||
let s = String::deserialize(deserializer)?;
|
||||
let dt = NaiveDate::parse_from_str(&s, FORMAT).map_err(serde::de::Error::custom)?;
|
||||
Ok(dt)
|
||||
}
|
||||
Loading…
Reference in New Issue
Block a user