1
0
Fork 0
mirror of https://codeberg.org/icewind/haze.git synced 2026-06-03 17:14:08 +02:00

improve service proxy

This commit is contained in:
Robin Appelman 2023-07-19 16:21:45 +02:00
commit e080be43a4
4 changed files with 24 additions and 24 deletions

View file

@ -1,6 +1,6 @@
use crate::service::ServiceTrait;
use crate::Result;
use crate::{Cloud, HazeConfig};
use crate::{Result, Service};
use bollard::Docker;
use miette::{miette, IntoDiagnostic};
use std::collections::HashMap;
@ -46,34 +46,18 @@ impl ActiveInstances {
return Some(ip);
}
let addr = if let Some(name) = name.strip_suffix("-push") {
// service proxy
let addr = if name.matches('-').count() == 2 {
let (name, service_name) = name.rsplit_once('-').unwrap();
let cloud = Cloud::get_by_filter(&self.docker, Some(name.into()), &self.config)
.await
.ok()?;
let push = cloud
let service = cloud
.services
.iter()
.filter_map(|service| match service {
Service::Push(push) => Some(push),
_ => None,
})
.next()?;
let ip = push.get_ip(&self.docker, &cloud.id).await.ok()??;
SocketAddr::new(ip, 7867)
} else if let Some(name) = name.strip_suffix("-office") {
let cloud = Cloud::get_by_filter(&self.docker, Some(name.into()), &self.config)
.await
.ok()?;
let office = cloud
.services
.iter()
.filter_map(|service| match service {
Service::Office(office) => Some(office),
_ => None,
})
.next()?;
let ip = office.get_ip(&self.docker, &cloud.id).await.ok()??;
SocketAddr::new(ip, 9980)
.find(|service| service.name() == service_name)?;
let ip = service.get_ip(&self.docker, &cloud.id).await.ok()??;
SocketAddr::new(ip, service.proxy_port())
} else {
SocketAddr::new(
Cloud::get_by_filter(&self.docker, Some(name.into()), &self.config)

View file

@ -3,6 +3,7 @@ mod dav;
mod kaspersky;
mod ldap;
mod objectstore;
mod oc;
mod office;
mod onlyoffice;
mod push;
@ -15,6 +16,7 @@ use crate::service::dav::Dav;
use crate::service::kaspersky::{Kaspersky, KasperskyIcap};
pub use crate::service::ldap::{Ldap, LdapAdmin};
pub use crate::service::objectstore::ObjectStore;
use crate::service::oc::Oc;
pub use crate::service::office::Office;
pub use crate::service::onlyoffice::OnlyOffice;
pub use crate::service::push::NotifyPush;
@ -155,6 +157,10 @@ pub trait ServiceTrait {
Err(Report::msg("service not started"))
}
}
fn proxy_port(&self) -> u16 {
80
}
}
#[enum_dispatch]
@ -172,6 +178,7 @@ pub enum Service {
Kaspersky(Kaspersky),
KasperskyIcap(KasperskyIcap),
ClamIcap(ClamIcap),
Oc(Oc),
Preset(PresetService),
}
@ -189,6 +196,7 @@ impl Service {
"smb" => Some(vec![Service::Smb(Smb)]),
"dav" => Some(vec![Service::Dav(Dav)]),
"sftp" => Some(vec![Service::Sftp(Sftp)]),
"oc" => Some(vec![Service::Oc(Oc)]),
"kaspersky" => Some(vec![Service::Kaspersky(Kaspersky)]),
"kaspersky-icap" => Some(vec![Service::KasperskyIcap(KasperskyIcap)]),
"clamav-icap" => Some(vec![Service::ClamIcap(ClamIcap)]),

View file

@ -141,4 +141,8 @@ impl ServiceTrait for Office {
),
])
}
fn proxy_port(&self) -> u16 {
9980
}
}

View file

@ -98,4 +98,8 @@ impl ServiceTrait for NotifyPush {
format!("occ notify_push:setup {}", addr),
])
}
fn proxy_port(&self) -> u16 {
7867
}
}