|  |  | @ -1,19 +1,17 @@ | 
			
		
	
		
		
			
				
					
					|  |  |  | use crate::db::UDB; |  |  |  | use crate::db::UDB; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | use crate::errors::Error; | 
			
		
	
		
		
			
				
					
					|  |  |  | use diesel::SaveChangesDsl; |  |  |  | use diesel::SaveChangesDsl; | 
			
		
	
		
		
			
				
					
					|  |  |  | use hyper::Body; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | use serde::Serialize; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | use u_lib::{ |  |  |  | use u_lib::{ | 
			
		
	
		
		
			
				
					
					|  |  |  |     messaging::{AsMsg, BaseMessage, Reportable}, |  |  |  |     messaging::{AsMsg, BaseMessage, Reportable}, | 
			
		
	
		
		
			
				
					
					|  |  |  |     models::*, |  |  |  |     models::*, | 
			
		
	
		
		
			
				
					
					|  |  |  |     utils::{OneOrVec, Stripped}, |  |  |  |     utils::{OneOrVec, Stripped}, | 
			
		
	
		
		
			
				
					
					|  |  |  |     ULocalError, |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | }; |  |  |  | }; | 
			
		
	
		
		
			
				
					
					|  |  |  | use uuid::Uuid; |  |  |  | use uuid::Uuid; | 
			
		
	
		
		
			
				
					
					|  |  |  | use warp::{ |  |  |  | use warp::{ | 
			
		
	
		
		
			
				
					
					|  |  |  |     http::{Response, StatusCode}, |  |  |  |     http::{Response, StatusCode}, | 
			
		
	
		
		
			
				
					
					|  |  |  |     Rejection, Reply, |  |  |  |     Rejection, Reply, | 
			
		
	
		
		
			
				
					
					|  |  |  | }; |  |  |  | }; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | /* | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | pub fn build_response(code: StatusCode, body: impl Into<Body>) -> Response<Body> { |  |  |  | pub fn build_response(code: StatusCode, body: impl Into<Body>) -> Response<Body> { | 
			
		
	
		
		
			
				
					
					|  |  |  |     Response::builder().status(code).body(body.into()).unwrap() |  |  |  |     Response::builder().status(code).body(body.into()).unwrap() | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
	
		
		
			
				
					|  |  | @ -29,116 +27,86 @@ pub fn build_err(body: impl ToString) -> Response<Body> { | 
			
		
	
		
		
			
				
					
					|  |  |  | pub fn build_message<M: AsMsg + Serialize>(m: M) -> Response<Body> { |  |  |  | pub fn build_message<M: AsMsg + Serialize>(m: M) -> Response<Body> { | 
			
		
	
		
		
			
				
					
					|  |  |  |     warp::reply::json(&m.as_message()).into_response() |  |  |  |     warp::reply::json(&m.as_message()).into_response() | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | */ | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | pub struct Endpoints; |  |  |  | pub struct Endpoints; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | impl Endpoints { |  |  |  | impl Endpoints { | 
			
		
	
		
		
			
				
					
					|  |  |  |     pub async fn add_agent(msg: Agent) -> Result<Response<Body>, Rejection> { |  |  |  |     pub async fn add_agent(msg: Agent) -> Result<(), Rejection> { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         info!("hnd: add_agent"); |  |  |  |         UDB::lock_db().insert_agent(&msg).map_err(From::from) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         UDB::lock_db() |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |             .insert_agent(&msg) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |             .map(|_| build_ok("")) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |             .or_else(|e| Ok(build_err(e))) |  |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     pub async fn get_agents(uid: Option<Uuid>) -> Result<Response<Body>, Rejection> { |  |  |  |     pub async fn get_agents(uid: Option<Uuid>) -> Result<Vec<Agent>, Rejection> { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         info!("hnd: get_agents"); |  |  |  |         UDB::lock_db().get_agents(uid).map_err(From::from) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         UDB::lock_db() |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |             .get_agents(uid) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |             .map(build_message) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |             .or_else(|e| Ok(build_err(e))) |  |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     pub async fn get_jobs(uid: Option<Uuid>) -> Result<Response<Body>, Rejection> { |  |  |  |     pub async fn get_jobs(uid: Option<Uuid>) -> Result<Vec<JobMeta>, Rejection> { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         info!("hnd: get_jobs"); |  |  |  |         UDB::lock_db().get_jobs(uid).map_err(From::from) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         UDB::lock_db() |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |             .get_jobs(uid) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |             .map(build_message) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |             .or_else(|e| Ok(build_err(e))) |  |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     pub async fn get_agent_jobs(uid: Option<Uuid>) -> Result<Response<Body>, Rejection> { |  |  |  |     pub async fn get_agent_jobs(uid: Option<Uuid>) -> Result<Vec<AssignedJob>, Rejection> { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         info!("hnd: get_agent_jobs"); |  |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         UDB::lock_db() |  |  |  |         UDB::lock_db() | 
			
		
	
		
		
			
				
					
					|  |  |  |             .get_exact_jobs(uid, false) |  |  |  |             .get_exact_jobs(uid, false) | 
			
		
	
		
		
			
				
					
					|  |  |  |             .map(build_message) |  |  |  |             .map_err(From::from) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |             .or_else(|e| Ok(build_err(e))) |  |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     pub async fn get_personal_jobs(uid: Option<Uuid>) -> Result<Response<Body>, Rejection> { |  |  |  |     pub async fn get_personal_jobs(uid: Option<Uuid>) -> Result<Vec<AssignedJob>, Rejection> { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         info!("hnd: get_personal_jobs"); |  |  |  |         let agents = UDB::lock_db().get_agents(uid)?; | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         let agents = UDB::lock_db().get_agents(uid).unwrap(); |  |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         if agents.is_empty() { |  |  |  |         if agents.is_empty() { | 
			
		
	
		
		
			
				
					
					|  |  |  |             let db = UDB::lock_db(); |  |  |  |             let db = UDB::lock_db(); | 
			
		
	
		
		
			
				
					
					|  |  |  |             db.insert_agent(&Agent::with_id(uid.unwrap())).unwrap(); |  |  |  |             db.insert_agent(&Agent::with_id(uid.unwrap()))?; | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |             let job = db.find_job_by_alias("agent_hello").unwrap(); |  |  |  |             let job = db.find_job_by_alias("agent_hello")?; | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |             if let Err(e) = db.set_jobs_for_agent(&uid.unwrap(), &[job.id]) { |  |  |  |             db.set_jobs_for_agent(&uid.unwrap(), &[job.id])?; | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |                 return Ok(build_err(e)); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |             } |  |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         } |  |  |  |         } | 
			
		
	
		
		
			
				
					
					|  |  |  |         let result = UDB::lock_db().get_exact_jobs(uid, true); |  |  |  |         let result = UDB::lock_db().get_exact_jobs(uid, true); | 
			
		
	
		
		
			
				
					
					|  |  |  |         match result { |  |  |  |         match result { | 
			
		
	
		
		
			
				
					
					|  |  |  |             Ok(r) => { |  |  |  |             Ok(r) => { | 
			
		
	
		
		
			
				
					
					|  |  |  |                 let db = UDB::lock_db(); |  |  |  |                 let db = UDB::lock_db(); | 
			
		
	
		
		
			
				
					
					|  |  |  |                 for j in r.iter() { |  |  |  |                 for j in r.iter() { | 
			
		
	
		
		
			
				
					
					|  |  |  |                     db.update_job_status(j.id, JobState::Running).unwrap(); |  |  |  |                     db.update_job_status(j.id, JobState::Running)?; | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |                 } |  |  |  |                 } | 
			
		
	
		
		
			
				
					
					|  |  |  |                 Ok(build_message(r)) |  |  |  |                 Ok(r) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |             } |  |  |  |             } | 
			
		
	
		
		
			
				
					
					|  |  |  |             Err(e) => Ok(build_err(e)), |  |  |  |             Err(e) => Err(e.into()), | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         } |  |  |  |         } | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     pub async fn upload_jobs( |  |  |  |     pub async fn upload_jobs(msg: BaseMessage<'static, Vec<JobMeta>>) -> Result<(), Rejection> { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         msg: BaseMessage<'static, Vec<JobMeta>>, |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     ) -> Result<Response<Body>, Rejection> { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |         info!("hnd: upload_jobs"); |  |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         UDB::lock_db() |  |  |  |         UDB::lock_db() | 
			
		
	
		
		
			
				
					
					|  |  |  |             .insert_jobs(&msg.into_inner()) |  |  |  |             .insert_jobs(&msg.into_inner()) | 
			
		
	
		
		
			
				
					
					|  |  |  |             .map(|_| build_ok("")) |  |  |  |             .map_err(From::from) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |             .or_else(|e| Ok(build_err(e))) |  |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     pub async fn del(uid: Uuid) -> Result<Response<Body>, Rejection> { |  |  |  |     pub async fn del(uid: Uuid) -> Result<usize, Rejection> { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         info!("hnd: del"); |  |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         let db = UDB::lock_db(); |  |  |  |         let db = UDB::lock_db(); | 
			
		
	
		
		
			
				
					
					|  |  |  |         let del_fns = &[UDB::del_agents, UDB::del_jobs, UDB::del_results]; |  |  |  |         let del_fns = &[UDB::del_agents, UDB::del_jobs, UDB::del_results]; | 
			
		
	
		
		
			
				
					
					|  |  |  |         for del_fn in del_fns { |  |  |  |         for del_fn in del_fns { | 
			
		
	
		
		
			
				
					
					|  |  |  |             let affected = del_fn(&db, &[uid]).unwrap(); |  |  |  |             let affected = del_fn(&db, &[uid]).unwrap(); | 
			
		
	
		
		
			
				
					
					|  |  |  |             if affected > 0 { |  |  |  |             if affected > 0 { | 
			
		
	
		
		
			
				
					
					|  |  |  |                 return Ok(build_message(affected as i32)); |  |  |  |                 return Ok(affected); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |             } |  |  |  |             } | 
			
		
	
		
		
			
				
					
					|  |  |  |         } |  |  |  |         } | 
			
		
	
		
		
			
				
					
					|  |  |  |         Ok(build_message(0)) |  |  |  |         Ok(0) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     pub async fn set_jobs( |  |  |  |     pub async fn set_jobs( | 
			
		
	
		
		
			
				
					
					|  |  |  |         agent_uid: Uuid, |  |  |  |         agent_uid: Uuid, | 
			
		
	
		
		
			
				
					
					|  |  |  |         msg: BaseMessage<'static, Vec<String>>, |  |  |  |         msg: BaseMessage<'static, Vec<String>>, | 
			
		
	
		
		
			
				
					
					|  |  |  |     ) -> Result<Response<Body>, Rejection> { |  |  |  |     ) -> Result<Vec<Uuid>, Rejection> { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         info!("hnd: set_jobs_by_alias, agent: {}", agent_uid); |  |  |  |         msg.into_inner() | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         let jobs: Result<Vec<Uuid>, ULocalError> = msg |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |             .into_inner() |  |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |             .into_iter() |  |  |  |             .into_iter() | 
			
		
	
		
		
			
				
					
					|  |  |  |             .map(|ident| { |  |  |  |             .map(|ident| { | 
			
		
	
		
		
			
				
					
					|  |  |  |                 info!("hnd: set_jobs_by_alias, job: {}", ident); |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |                 Uuid::parse_str(&ident) |  |  |  |                 Uuid::parse_str(&ident) | 
			
		
	
		
		
			
				
					
					|  |  |  |                     .or_else(|_| UDB::lock_db().find_job_by_alias(&ident).map(|j| j.id)) |  |  |  |                     .or_else(|_| UDB::lock_db().find_job_by_alias(&ident).map(|j| j.id)) | 
			
		
	
		
		
			
				
					
					|  |  |  |             }) |  |  |  |             }) | 
			
		
	
		
		
			
				
					
					|  |  |  |             .collect(); |  |  |  |             .collect::<Result<Vec<Uuid>, Error>>() | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         match jobs { |  |  |  |             .and_then(|j| UDB::lock_db().set_jobs_for_agent(&agent_uid, &j)) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |             Ok(j) => UDB::lock_db() |  |  |  |             .map_err(From::from) | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |                 .set_jobs_for_agent(&agent_uid, &j) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |                 .map(build_message) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |                 .or_else(|e| Ok(build_err(e))), |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |             Err(e) => Ok(build_err(e)), |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |         } |  |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     pub async fn report<Data: OneOrVec<Reportable> + AsMsg + 'static>( |  |  |  |     pub async fn report<Data: OneOrVec<Reportable> + AsMsg + 'static>( | 
			
		
	
		
		
			
				
					
					|  |  |  |         msg: BaseMessage<'static, Data>, |  |  |  |         msg: BaseMessage<'static, Data>, | 
			
		
	
		
		
			
				
					
					|  |  |  |     ) -> Result<Response<Body>, Rejection> { |  |  |  |     ) -> Result<(), Rejection> { | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |         info!("hnd: report"); |  |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         let id = msg.id; |  |  |  |         let id = msg.id; | 
			
		
	
		
		
			
				
					
					|  |  |  |         let mut failed = vec![]; |  |  |  |         let mut failed = vec![]; | 
			
		
	
		
		
			
				
					
					|  |  |  |         for entry in msg.into_inner().into_vec() { |  |  |  |         for entry in msg.into_inner().into_vec() { | 
			
		
	
	
		
		
			
				
					|  |  | @ -150,7 +118,7 @@ impl Endpoints { | 
			
		
	
		
		
			
				
					
					|  |  |  |                     let db = UDB::lock_db(); |  |  |  |                     let db = UDB::lock_db(); | 
			
		
	
		
		
			
				
					
					|  |  |  |                     if let Err(e) = res |  |  |  |                     if let Err(e) = res | 
			
		
	
		
		
			
				
					
					|  |  |  |                         .save_changes::<AssignedJob>(&db.conn) |  |  |  |                         .save_changes::<AssignedJob>(&db.conn) | 
			
		
	
		
		
			
				
					
					|  |  |  |                         .map_err(ULocalError::from) |  |  |  |                         .map_err(Error::from) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |                     { |  |  |  |                     { | 
			
		
	
		
		
			
				
					
					|  |  |  |                         failed.push(e.to_string()) |  |  |  |                         failed.push(e.to_string()) | 
			
		
	
		
		
			
				
					
					|  |  |  |                     } |  |  |  |                     } | 
			
		
	
	
		
		
			
				
					|  |  | @ -172,9 +140,8 @@ impl Endpoints { | 
			
		
	
		
		
			
				
					
					|  |  |  |             } |  |  |  |             } | 
			
		
	
		
		
			
				
					
					|  |  |  |         } |  |  |  |         } | 
			
		
	
		
		
			
				
					
					|  |  |  |         if !failed.is_empty() { |  |  |  |         if !failed.is_empty() { | 
			
		
	
		
		
			
				
					
					|  |  |  |             let err_msg = ULocalError::ProcessingError(failed.join(", ")); |  |  |  |             return Err(Error::ProcessingError(failed.join(", ")).into()); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |             return Ok(build_err(err_msg)); |  |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         } |  |  |  |         } | 
			
		
	
		
		
			
				
					
					|  |  |  |         Ok(build_ok("")) |  |  |  |         Ok(()) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
	
		
		
			
				
					|  |  | 
 |