From 9c754b4dacd408485f386bc989ee7e46a967e90a Mon Sep 17 00:00:00 2001 From: Alexandre Gomez Date: Thu, 6 Oct 2022 11:28:59 +0200 Subject: [PATCH] refactor: (controller) remove useless code Removed duplicated code & some "vector" struct that was not needed Signed-off-by: Alexandre Gomez --- .../src/external_api/instance/controller.rs | 23 ++++--- .../lib/src/external_api/instance/filter.rs | 61 ----------------- .../lib/src/external_api/instance/mod.rs | 1 - .../lib/src/external_api/instance/model.rs | 34 ++-------- .../lib/src/external_api/instance/service.rs | 6 +- .../src/external_api/namespace/controller.rs | 19 +++--- .../lib/src/external_api/namespace/model.rs | 37 ++--------- .../lib/src/external_api/namespace/service.rs | 10 +-- .../lib/src/external_api/node/controller.rs | 25 +++---- controller/lib/src/external_api/node/model.rs | 47 ++++--------- .../src/external_api/workload/controller.rs | 19 +++--- .../lib/src/external_api/workload/model.rs | 66 ++++++------------- .../lib/src/external_api/workload/service.rs | 10 +-- 13 files changed, 97 insertions(+), 261 deletions(-) delete mode 100644 controller/lib/src/external_api/instance/filter.rs diff --git a/controller/lib/src/external_api/instance/controller.rs b/controller/lib/src/external_api/instance/controller.rs index 6929d2f4..b4c12305 100644 --- a/controller/lib/src/external_api/instance/controller.rs +++ b/controller/lib/src/external_api/instance/controller.rs @@ -1,12 +1,12 @@ use std::sync::Arc; -use crate::external_api::generic::model::{APIResponse, APIResponseMetadata}; +use crate::external_api::generic::model::{APIResponse, APIResponseMetadata, Pagination}; use crate::external_api::interface::ActixAppState; use crate::external_api::workload::controller::WorkloadControllerError; use crate::external_api::workload::service::WorkloadServiceError; use super::super::workload::service::WorkloadService; -use super::model::{Instance, InstanceDTO, InstanceVector, Pagination}; +use super::model::{Instance, InstanceDTO}; use super::service::{InstanceService, InstanceServiceError}; use actix_web::http::StatusCode; use actix_web::{web, HttpResponse, Responder, Scope}; @@ -224,19 +224,18 @@ impl InstanceController { } }; - match pagination { + let instances = match pagination { Some(pagination) => { - let instances = instance_service + instance_service .get_instances(pagination.limit, pagination.offset, &namespace) - .await; - - InstanceVector::new(instances).to_http() + .await } - None => { - let instances = instance_service.get_instances(0, 0, &namespace).await; + None => instance_service.get_instances(0, 0, &namespace).await, + }; - InstanceVector::new(instances).to_http() - } - } + HttpResponse::build(StatusCode::OK).json(APIResponse::> { + data: instances, + metadata: APIResponseMetadata::default(), + }) } } diff --git a/controller/lib/src/external_api/instance/filter.rs b/controller/lib/src/external_api/instance/filter.rs deleted file mode 100644 index 2bae13cd..00000000 --- a/controller/lib/src/external_api/instance/filter.rs +++ /dev/null @@ -1,61 +0,0 @@ -use super::model::Instance; -use thiserror::Error; - -#[derive(Debug, Error)] -pub enum InstanceFilterServiceError { - #[error("Offset out of range")] - OffsetOutOfRange, -} - -/// `FilterService` is a struct that can be used as a service in the WorkloadService. -pub struct InstanceFilterService {} - -impl InstanceFilterService { - pub fn new() -> Self { - InstanceFilterService {} - } - - /// It takes a vector of workloads and a limit, and returns a vector of workloads that is limited to the - /// number of workloads specified by the limit - /// - /// # Arguments: - /// - /// * `workloads`: A vector of workloads to be limited. - /// * `limit`: The number of workloads to return. - /// - /// # Returns: - /// - /// A vector of workloads. - - pub fn limit(&mut self, instances: &Vec, mut limit: u32) -> Vec { - if limit > instances.len() as u32 { - limit = instances.len() as u32; - } - instances[0..limit as usize].to_vec() - } - - /// "Return a subset of the workloads vector, starting at the offset index." - /// - /// The first thing we do is check if the offset is greater than the length of the workloads vector. If - /// it is, we return an error - /// - /// # Arguments: - /// - /// * `workloads`: A vector of workloads to be filtered. - /// * `offset`: The offset to start from. - /// - /// # Returns: - /// - /// A vector of workloads - - pub fn offset( - &mut self, - instances: &Vec, - offset: u32, - ) -> Result, InstanceFilterServiceError> { - if offset > instances.len() as u32 { - return Err(InstanceFilterServiceError::OffsetOutOfRange); - } - Ok(instances[offset as usize..].to_vec()) - } -} diff --git a/controller/lib/src/external_api/instance/mod.rs b/controller/lib/src/external_api/instance/mod.rs index e12181de..9c5ae537 100644 --- a/controller/lib/src/external_api/instance/mod.rs +++ b/controller/lib/src/external_api/instance/mod.rs @@ -1,4 +1,3 @@ pub mod controller; -mod filter; pub mod model; pub mod service; diff --git a/controller/lib/src/external_api/instance/model.rs b/controller/lib/src/external_api/instance/model.rs index 8d8efb0c..9dfba02d 100644 --- a/controller/lib/src/external_api/instance/model.rs +++ b/controller/lib/src/external_api/instance/model.rs @@ -1,11 +1,13 @@ use std::net::Ipv4Addr; -use actix_web::HttpResponse; use proto::controller::{InstanceState, Type}; use rand::{distributions::Alphanumeric, Rng}; use serde::{Deserialize, Serialize}; -use crate::external_api::generic::model::{APIResponse, APIResponseMetadata}; +#[derive(Deserialize, Serialize)] +pub struct InstanceDTO { + pub workload_name: String, +} #[derive(Deserialize, Serialize, Clone, Debug)] pub struct Instance { @@ -23,40 +25,12 @@ pub struct Instance { pub namespace: String, } -#[derive(Deserialize, Serialize)] -pub struct InstanceVector { - pub instances: Vec, -} -impl InstanceVector { - pub fn new(instances: Vec) -> InstanceVector { - InstanceVector { instances } - } - pub fn to_http(self) -> HttpResponse { - HttpResponse::Ok().json(APIResponse::> { - data: self.instances, - metadata: APIResponseMetadata::default(), - }) - } -} - #[derive(Deserialize, Serialize, Clone, Debug)] pub struct Resource { pub limit: Option, pub usage: Option, } -#[derive(Deserialize, Serialize)] -pub struct InstanceDTO { - pub workload_name: String, -} - -#[derive(Deserialize, Serialize)] - -pub struct Pagination { - pub limit: u32, - pub offset: u32, -} - #[derive(Deserialize, Serialize, Clone, Debug)] pub struct ResourceSummary { pub cpu: u64, diff --git a/controller/lib/src/external_api/instance/service.rs b/controller/lib/src/external_api/instance/service.rs index 2d594d1b..cf746bcb 100644 --- a/controller/lib/src/external_api/instance/service.rs +++ b/controller/lib/src/external_api/instance/service.rs @@ -1,9 +1,9 @@ use std::net::{Ipv4Addr, SocketAddr}; use std::sync::Arc; -use super::filter::InstanceFilterService; use super::model::Instance; use crate::etcd::{EtcdClient, EtcdClientError}; +use crate::external_api::generic::filter::FilterService; use crate::external_api::workload::model::Workload; use crate::grpc_client::interface::{SchedulerClientInterface, SchedulerClientInterfaceError}; use log::{debug, trace}; @@ -32,7 +32,7 @@ pub enum InstanceServiceError { pub struct InstanceService { grpc_service: SchedulerClientInterface, etcd_service: EtcdClient, - filter_service: InstanceFilterService, + filter_service: FilterService, } // `InstanceService` is a struct that is inspired from Controllers Provider Modules architectures. It is used as a service in the InstanceController. A service can use other services. @@ -54,7 +54,7 @@ impl InstanceService { etcd_service: EtcdClient::new(etcd_address.to_string()) .await .map_err(InstanceServiceError::EtcdError)?, - filter_service: InstanceFilterService::new(), + filter_service: FilterService::new(), }) } diff --git a/controller/lib/src/external_api/namespace/controller.rs b/controller/lib/src/external_api/namespace/controller.rs index d1eb3f26..1f95ae57 100644 --- a/controller/lib/src/external_api/namespace/controller.rs +++ b/controller/lib/src/external_api/namespace/controller.rs @@ -115,18 +115,19 @@ impl NamespaceController { Err(err) => return NamespaceControllerError::NamespaceServiceError(err).into(), }; - match pagination { + let namespaces = match pagination { Some(pagination) => { - let namespaces = namespace_service + namespace_service .get_all_namespace(pagination.limit, pagination.offset) - .await; - namespaces.to_http() + .await } - None => { - let namespaces = namespace_service.get_all_namespace(0, 0).await; - namespaces.to_http() - } - } + None => namespace_service.get_all_namespace(0, 0).await, + }; + + HttpResponse::build(StatusCode::OK).json(APIResponse::> { + metadata: APIResponseMetadata::default(), + data: namespaces, + }) } pub async fn patch_namespace( diff --git a/controller/lib/src/external_api/namespace/model.rs b/controller/lib/src/external_api/namespace/model.rs index cbeab6d1..e6f44769 100644 --- a/controller/lib/src/external_api/namespace/model.rs +++ b/controller/lib/src/external_api/namespace/model.rs @@ -1,10 +1,10 @@ -use actix_web::HttpResponse; use serde::{Deserialize, Serialize}; -use crate::external_api::generic::model::{APIResponse, APIResponseMetadata}; +#[derive(Serialize, Deserialize)] +pub struct NamespaceDTO { + pub name: String, +} -#[derive(Debug, Serialize, Deserialize, Clone)] -pub struct Metadata {} #[derive(Debug, Serialize, Deserialize, Clone)] pub struct Namespace { pub id: String, @@ -13,31 +13,4 @@ pub struct Namespace { } #[derive(Debug, Serialize, Deserialize, Clone)] -pub struct NamespaceDTO { - pub name: String, -} - -#[derive(Deserialize, Serialize)] -pub struct NamespaceVector { - pub namespaces: Vec, -} -impl NamespaceVector { - pub fn new(namespaces: Vec) -> NamespaceVector { - NamespaceVector { namespaces } - } - pub fn to_http(&self) -> HttpResponse { - match serde_json::to_string(&self.namespaces) { - Ok(json) => HttpResponse::Ok().json(APIResponse { - data: Some(json), - metadata: APIResponseMetadata::default(), - }), - Err(_) => HttpResponse::InternalServerError().json(APIResponse::<()> { - metadata: APIResponseMetadata { - error: Some("Internal Server Error".to_string()), - ..Default::default() - }, - ..Default::default() - }), - } - } -} +pub struct Metadata {} diff --git a/controller/lib/src/external_api/namespace/service.rs b/controller/lib/src/external_api/namespace/service.rs index 2b323944..c2da5e8c 100644 --- a/controller/lib/src/external_api/namespace/service.rs +++ b/controller/lib/src/external_api/namespace/service.rs @@ -6,7 +6,7 @@ use serde_json; use std::net::SocketAddr; use thiserror::Error; -use super::model::{Metadata, Namespace, NamespaceDTO, NamespaceVector}; +use super::model::{Metadata, Namespace, NamespaceDTO}; #[derive(Debug, Error)] pub enum NamespaceServiceError { @@ -55,7 +55,7 @@ impl NamespaceService { } } - pub async fn get_all_namespace(&mut self, limit: u32, offset: u32) -> NamespaceVector { + pub async fn get_all_namespace(&mut self, limit: u32, offset: u32) -> Vec { let mut new_vec: Vec = Vec::new(); match self.etcd_service.get_all().await { Some(namespaces) => { @@ -68,7 +68,7 @@ impl NamespaceService { if offset > 0 { match self.filter_service.offset(&new_vec, offset) { Ok(namespaces) => new_vec = namespaces, - Err(_) => return NamespaceVector::new(vec![]), + Err(_) => return vec![], } } if limit > 0 { @@ -76,9 +76,9 @@ impl NamespaceService { } trace!("Namespaces found: {:?}", new_vec); - NamespaceVector::new(new_vec) + new_vec } - None => NamespaceVector::new(vec![]), + None => vec![], } } diff --git a/controller/lib/src/external_api/node/controller.rs b/controller/lib/src/external_api/node/controller.rs index fe3d85b3..b7c9ed02 100644 --- a/controller/lib/src/external_api/node/controller.rs +++ b/controller/lib/src/external_api/node/controller.rs @@ -5,10 +5,7 @@ use crate::external_api::{ use actix_web::{http::StatusCode, web, HttpResponse, Responder, Scope}; use thiserror::Error; -use super::{ - model::NodeVector, - service::{NodeService, NodeServiceError}, -}; +use super::service::{NodeService, NodeServiceError}; use log::{debug, error}; @@ -98,20 +95,18 @@ impl NodeController { Err(err) => return NodeControllerError::NodeServiceError(err).into(), }; - match pagination { + let nodes = match pagination { Some(pagination) => { - let nodes = node_service + node_service .get_all_nodes(pagination.limit, pagination.offset) - .await; - NodeVector::new(nodes).to_http() - } - None => { - let nodes = node_service.get_all_nodes(0, 0).await; - NodeVector::new(nodes).to_http() + .await } - } + None => node_service.get_all_nodes(0, 0).await, + }; - // let nodes = node_service.get_all_nodes().await; - // web::Json(nodes) + HttpResponse::build(StatusCode::OK).json(APIResponse { + data: nodes, + metadata: APIResponseMetadata::default(), + }) } } diff --git a/controller/lib/src/external_api/node/model.rs b/controller/lib/src/external_api/node/model.rs index 36e27720..cdfa887f 100644 --- a/controller/lib/src/external_api/node/model.rs +++ b/controller/lib/src/external_api/node/model.rs @@ -1,7 +1,5 @@ -use actix_web::HttpResponse; use serde::{Deserialize, Serialize}; -use crate::external_api::generic::model::{APIResponse, APIResponseMetadata}; use crate::external_api::instance::model::Instance; #[derive(Deserialize, Serialize)] @@ -10,17 +8,12 @@ pub struct NodeDTO { } #[derive(Deserialize, Serialize, Clone, Debug)] - -pub struct ResourceSummary { - pub cpu: i64, - pub memory: i64, - pub disk: i64, -} - -#[derive(Deserialize, Serialize, Clone, Debug)] -pub struct Resource { - pub usage: ResourceSummary, - pub limit: ResourceSummary, +pub struct NodeStatus { + pub id: String, + pub state: NodeState, + pub status_description: String, + pub resource: Resource, + pub instances: Vec, } #[derive(Deserialize, Serialize, Clone, Debug)] @@ -33,26 +26,14 @@ pub enum NodeState { } #[derive(Deserialize, Serialize, Clone, Debug)] -pub struct NodeStatus { - pub id: String, - pub state: NodeState, - pub status_description: String, - pub resource: Resource, - pub instances: Vec, +pub struct Resource { + pub usage: ResourceSummary, + pub limit: ResourceSummary, } -#[derive(Deserialize, Serialize)] -pub struct NodeVector { - pub nodes: Vec, -} -impl NodeVector { - pub fn new(nodes: Vec) -> NodeVector { - NodeVector { nodes } - } - pub fn to_http(self) -> HttpResponse { - HttpResponse::Ok().json(APIResponse { - data: self, - metadata: APIResponseMetadata::default(), - }) - } +#[derive(Deserialize, Serialize, Clone, Debug)] +pub struct ResourceSummary { + pub cpu: i64, + pub memory: i64, + pub disk: i64, } diff --git a/controller/lib/src/external_api/workload/controller.rs b/controller/lib/src/external_api/workload/controller.rs index 9ca90bcc..f1ee384c 100644 --- a/controller/lib/src/external_api/workload/controller.rs +++ b/controller/lib/src/external_api/workload/controller.rs @@ -161,18 +161,19 @@ impl WorkloadController { Err(err) => return WorkloadControllerError::WorkloadServiceError(err).into(), }; - match pagination { + let workloads = match pagination { Some(pagination) => { - let workloads = workload_service + workload_service .get_all_workloads(pagination.limit, pagination.offset, &namespace) - .await; - workloads.to_http() + .await } - None => { - let workloads = workload_service.get_all_workloads(0, 0, &namespace).await; - workloads.to_http() - } - } + None => workload_service.get_all_workloads(0, 0, &namespace).await, + }; + + HttpResponse::build(StatusCode::OK).json(APIResponse::> { + data: workloads, + metadata: APIResponseMetadata::default(), + }) } /// `patch_workload` is an asynchronous function that handle **/workload/\/** route (PATCH) diff --git a/controller/lib/src/external_api/workload/model.rs b/controller/lib/src/external_api/workload/model.rs index d75fb954..3bde90a1 100644 --- a/controller/lib/src/external_api/workload/model.rs +++ b/controller/lib/src/external_api/workload/model.rs @@ -1,23 +1,14 @@ -use actix_web::HttpResponse; use serde::{Deserialize, Serialize}; -use crate::external_api::generic::model::{APIResponse, APIResponseMetadata}; - -#[derive(Deserialize, Serialize, Clone, Debug)] -pub enum Type { - Container = 0, -} -#[derive(Deserialize, Serialize, Clone, Debug)] -pub struct Ressources { - pub cpu: u64, - pub memory: u64, - pub disk: u64, -} -#[derive(Deserialize, Serialize, Clone, Debug)] -pub struct Ports { - pub source: i32, - pub destination: i32, +#[derive(Deserialize, Serialize)] +pub struct WorkloadDTO { + pub name: String, + pub environment: Vec, + pub ports: Vec, + pub uri: String, + pub resources: Ressources, } + #[derive(Deserialize, Serialize, Clone, Debug)] pub struct Workload { pub id: String, @@ -30,35 +21,18 @@ pub struct Workload { pub namespace: String, } -#[derive(Deserialize, Serialize)] -pub struct WorkloadDTO { - pub name: String, - pub environment: Vec, - pub ports: Vec, - pub uri: String, - pub resources: Ressources, +#[derive(Deserialize, Serialize, Clone, Debug)] +pub enum Type { + Container = 0, } -#[derive(Deserialize, Serialize)] -pub struct WorkloadVector { - pub workloads: Vec, +#[derive(Deserialize, Serialize, Clone, Debug)] +pub struct Ressources { + pub cpu: u64, + pub memory: u64, + pub disk: u64, } -impl WorkloadVector { - pub fn new(workloads: Vec) -> WorkloadVector { - WorkloadVector { workloads } - } - pub fn to_http(&self) -> HttpResponse { - match serde_json::to_string(&self.workloads) { - Ok(json) => HttpResponse::Ok().json(APIResponse { - data: Some(json), - metadata: APIResponseMetadata::default(), - }), - Err(_) => HttpResponse::InternalServerError().json(APIResponse::<()> { - metadata: APIResponseMetadata { - error: Some("Internal Server Error".to_string()), - ..Default::default() - }, - ..Default::default() - }), - } - } +#[derive(Deserialize, Serialize, Clone, Debug)] +pub struct Ports { + pub source: i32, + pub destination: i32, } diff --git a/controller/lib/src/external_api/workload/service.rs b/controller/lib/src/external_api/workload/service.rs index 01125b75..25f6c062 100644 --- a/controller/lib/src/external_api/workload/service.rs +++ b/controller/lib/src/external_api/workload/service.rs @@ -1,6 +1,6 @@ use std::net::SocketAddr; -use super::model::{Ressources, Type, Workload, WorkloadDTO, WorkloadVector}; +use super::model::{Ressources, Type, Workload, WorkloadDTO}; use crate::etcd::{EtcdClient, EtcdClientError}; use crate::external_api::generic::filter::FilterService; use crate::external_api::namespace::service::{NamespaceService, NamespaceServiceError}; @@ -93,7 +93,7 @@ impl WorkloadService { limit: u32, offset: u32, namespace: &str, - ) -> WorkloadVector { + ) -> Vec { let mut new_vec: Vec = Vec::new(); match self.etcd_service.get_all().await { Some(workloads) => { @@ -108,7 +108,7 @@ impl WorkloadService { if offset > 0 { match self.filter_service.offset(&new_vec, offset) { Ok(workloads) => new_vec = workloads, - Err(_) => return WorkloadVector::new(vec![]), + Err(_) => return vec![], } } if limit > 0 { @@ -116,9 +116,9 @@ impl WorkloadService { } trace!("Workloads found: {:?}", new_vec); - WorkloadVector::new(new_vec) + new_vec } - None => WorkloadVector::new(vec![]), + None => vec![], } }