forked from NationTech/harmony
wip: Working hard on topology, seems to have something that may work, next step is put the building blocks together for real
This commit is contained in:
@@ -8,4 +8,5 @@ harmony = { path = "../harmony" }
|
||||
log = { workspace = true }
|
||||
env_logger = { workspace = true }
|
||||
tokio = { workspace = true }
|
||||
cidr = { workspace = true }
|
||||
|
||||
|
||||
@@ -1,23 +0,0 @@
|
||||
use harmony::domain::{
|
||||
hardware::{Host, HostCategory, Location, NetworkInterface},
|
||||
inventory::Inventory,
|
||||
};
|
||||
|
||||
pub fn get_inventory() -> Inventory {
|
||||
let network = vec![NetworkInterface::new(1_000_000_000, "TODO MAC ADDRESS".into(), true ) ];
|
||||
let storage = vec![];
|
||||
Inventory {
|
||||
location: Location::new(
|
||||
"1134 Grande Allée Ouest 1er étage, Québec, Qc".into(),
|
||||
"FQM 1134 1er étage".into(),
|
||||
),
|
||||
host: vec![Host {
|
||||
category: HostCategory::Server,
|
||||
network,
|
||||
storage,
|
||||
labels: vec![],
|
||||
}],
|
||||
switch: vec![],
|
||||
firewall: vec![],
|
||||
}
|
||||
}
|
||||
82
harmony-rs/fqm/src/inventory/mod.rs
Normal file
82
harmony-rs/fqm/src/inventory/mod.rs
Normal file
@@ -0,0 +1,82 @@
|
||||
use harmony::{
|
||||
hardware::{Host, HostCategory, Label, Location, NetworkInterface, Storage, StorageConnectionType, StorageKind},
|
||||
inventory::Inventory,
|
||||
};
|
||||
|
||||
pub fn get_inventory() -> Inventory {
|
||||
Inventory {
|
||||
location: Location::new(
|
||||
"1134 Grande Allée Ouest 1er étage, Québec, Qc".into(),
|
||||
"FQM 1134 1er étage".into(),
|
||||
),
|
||||
host: vec![],
|
||||
switch: vec![],
|
||||
firewall: vec![get_firewall_1()],
|
||||
}
|
||||
}
|
||||
|
||||
fn get_firewall_1() -> Host {
|
||||
Host {
|
||||
category: HostCategory::Firewall,
|
||||
network: vec![
|
||||
NetworkInterface::new(
|
||||
"igb0".to_string(),
|
||||
"00:90:7f:df:2c:1f".to_string(),
|
||||
1_000_000_000,
|
||||
true,
|
||||
),
|
||||
NetworkInterface::new(
|
||||
"igb1".to_string(),
|
||||
"00:90:7f:df:2c:20".to_string(),
|
||||
1_000_000_000,
|
||||
true,
|
||||
),
|
||||
NetworkInterface::new(
|
||||
"igb2".to_string(),
|
||||
"00:90:7f:df:2c:21".to_string(),
|
||||
1_000_000_000,
|
||||
true,
|
||||
),
|
||||
NetworkInterface::new(
|
||||
"igb3".to_string(),
|
||||
"00:90:7f:df:2c:22".to_string(),
|
||||
1_000_000_000,
|
||||
true,
|
||||
),
|
||||
NetworkInterface::new(
|
||||
"igb4".to_string(),
|
||||
"00:90:7f:df:2c:23".to_string(),
|
||||
1_000_000_000,
|
||||
true,
|
||||
),
|
||||
NetworkInterface::new(
|
||||
"igb5".to_string(),
|
||||
"00:90:7f:df:2c:24".to_string(),
|
||||
1_000_000_000,
|
||||
true,
|
||||
),
|
||||
NetworkInterface::new(
|
||||
"igb6".to_string(),
|
||||
"00:90:7f:df:2c:25".to_string(),
|
||||
1_000_000_000,
|
||||
true,
|
||||
),
|
||||
NetworkInterface::new(
|
||||
"igb7".to_string(),
|
||||
"00:90:7f:df:2c:26".to_string(),
|
||||
1_000_000_000,
|
||||
true,
|
||||
),
|
||||
],
|
||||
storage: vec![Storage::new(
|
||||
StorageConnectionType::Sata6g,
|
||||
StorageKind::SSD,
|
||||
240_000_000_000,
|
||||
"TODO".to_string(),
|
||||
)],
|
||||
labels: vec![Label::new(
|
||||
"operatingSystem".to_string(),
|
||||
"opnsense".to_string(),
|
||||
)],
|
||||
}
|
||||
}
|
||||
@@ -1,9 +1,7 @@
|
||||
use fqm::inventory::get_inventory;
|
||||
use fqm::{inventory::get_inventory, topology::fqm_topology};
|
||||
use harmony::{
|
||||
domain::{
|
||||
inventory::{Inventory, InventoryFilter},
|
||||
inventory::InventoryFilter,
|
||||
maestro::Maestro,
|
||||
},
|
||||
modules::opnsense_dhcp::OPNSenseDhcpScore,
|
||||
};
|
||||
use log::info;
|
||||
@@ -15,6 +13,7 @@ async fn main() {
|
||||
tokio::spawn(async move {
|
||||
info!("FQM Harmony Starting");
|
||||
let maestro = Maestro::new(get_inventory());
|
||||
let topology = fqm_topology();
|
||||
let score = OPNSenseDhcpScore::new(InventoryFilter::new(vec![]));
|
||||
let result = maestro.interpret(score).await.unwrap();
|
||||
info!("{result}");
|
||||
|
||||
@@ -1,86 +1,24 @@
|
||||
use std::net::{IpAddr, Ipv4Addr};
|
||||
use std::net::Ipv4Addr;
|
||||
|
||||
use harmony::{
|
||||
hardware::*,
|
||||
topology::{ClusterMember, HAClusterTopology, IpAddress, OPNSenseManagement},
|
||||
};
|
||||
use cidr::Ipv4Cidr;
|
||||
use harmony::infra::opnsense::OPNSenseFirewall;
|
||||
use harmony::topology::{HAClusterTopology, IpAddress, UnmanagedRouter};
|
||||
|
||||
pub fn fqm_topology() -> HAClusterTopology {
|
||||
let opnsense_firewall = Box::new(OPNSenseFirewall::new(IpAddress::V4(Ipv4Addr::new(10, 10, 8, 2))));
|
||||
|
||||
HAClusterTopology {
|
||||
firewall: vec![ClusterMember {
|
||||
management: Box::new(OPNSenseManagement::new(
|
||||
"user".to_string(),
|
||||
"password".to_string(),
|
||||
)),
|
||||
host: Host {
|
||||
category: HostCategory::Firewall,
|
||||
network: vec![
|
||||
NetworkInterface::new(
|
||||
"igb0".to_string(),
|
||||
"00:90:7f:df:2c:1f".to_string(),
|
||||
1_000_000_000,
|
||||
true,
|
||||
),
|
||||
NetworkInterface::new(
|
||||
"igb1".to_string(),
|
||||
"00:90:7f:df:2c:20".to_string(),
|
||||
1_000_000_000,
|
||||
true,
|
||||
),
|
||||
NetworkInterface::new(
|
||||
"igb2".to_string(),
|
||||
"00:90:7f:df:2c:21".to_string(),
|
||||
1_000_000_000,
|
||||
true,
|
||||
),
|
||||
NetworkInterface::new(
|
||||
"igb3".to_string(),
|
||||
"00:90:7f:df:2c:22".to_string(),
|
||||
1_000_000_000,
|
||||
true,
|
||||
),
|
||||
NetworkInterface::new(
|
||||
"igb4".to_string(),
|
||||
"00:90:7f:df:2c:23".to_string(),
|
||||
1_000_000_000,
|
||||
true,
|
||||
),
|
||||
NetworkInterface::new(
|
||||
"igb5".to_string(),
|
||||
"00:90:7f:df:2c:24".to_string(),
|
||||
1_000_000_000,
|
||||
true,
|
||||
),
|
||||
NetworkInterface::new(
|
||||
"igb6".to_string(),
|
||||
"00:90:7f:df:2c:25".to_string(),
|
||||
1_000_000_000,
|
||||
true,
|
||||
),
|
||||
NetworkInterface::new(
|
||||
"igb7".to_string(),
|
||||
"00:90:7f:df:2c:26".to_string(),
|
||||
1_000_000_000,
|
||||
true,
|
||||
),
|
||||
],
|
||||
storage: vec![Storage::new(
|
||||
StorageConnectionType::Sata6g,
|
||||
StorageKind::SSD,
|
||||
240_000_000_000,
|
||||
"TODO".to_string(),
|
||||
)],
|
||||
labels: vec![Label::new(
|
||||
"operatingSystem".to_string(),
|
||||
"opnsense".to_string(),
|
||||
)],
|
||||
},
|
||||
}],
|
||||
control_plane: todo!(),
|
||||
workers: todo!(),
|
||||
ceph_hosts: todo!(),
|
||||
switch: todo!(),
|
||||
gateway: IpAddress::V4(Ipv4Addr::new(10, 10, 8, 1)),
|
||||
load_balancer: IpAddress::V4(Ipv4Addr::new(10, 10, 8, 1)),
|
||||
firewall: opnsense_firewall.clone(),
|
||||
control_plane: vec![],
|
||||
ceph_hosts: vec![],
|
||||
switch: vec![],
|
||||
router: Box::new(UnmanagedRouter::new(
|
||||
IpAddress::V4(Ipv4Addr::new(10, 10, 8, 1)),
|
||||
Ipv4Cidr::new(Ipv4Addr::new(10, 10, 8, 0), 22).expect("Subnet is valid"),
|
||||
)),
|
||||
load_balancer: opnsense_firewall.clone(),
|
||||
dhcp_server: opnsense_firewall.clone(),
|
||||
dns_server: opnsense_firewall.clone(),
|
||||
workers: vec![],
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user