holochain_conductor_api/config/interface.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
use holochain_types::websocket::AllowedOrigins;
use serde::Deserialize;
use serde::Serialize;
/// Information neeeded to spawn an admin interface
#[derive(Clone, Deserialize, Serialize, Debug, PartialEq)]
pub struct AdminInterfaceConfig {
/// By what means the interface will be exposed.
/// Currently the only option is a local websocket running on a configurable port.
pub driver: InterfaceDriver,
}
/// Configuration for interfaces, specifying the means by which an interface
/// should be opened.
///
/// **NB**: This struct is used in both [`ConductorConfig`]
/// and [`ConductorState`],
/// so any change to the serialization strategy is a breaking change.
///
/// [`ConductorConfig`]: crate::conductor::ConductorConfig
/// [`ConductorState`]: https://docs.rs/holochain/latest/holochain/conductor/state/struct.ConductorState.html
#[derive(Clone, Deserialize, Serialize, Debug, PartialEq)]
#[serde(tag = "type", rename_all = "snake_case")]
pub enum InterfaceDriver {
/// An interface implemented via websockets
Websocket {
/// The port on which to establish the WebsocketListener
port: u16,
/// Allowed origins for this interface.
///
/// This should be one of:
/// - A comma separated list of origins - `http://localhost:3000,http://localhost:3001`,
/// - A single origin - `http://localhost:3000`,
/// - Any origin - `*`
///
/// Connections from any origin which is not permitted by this config will be rejected.
allowed_origins: AllowedOrigins,
},
}
impl InterfaceDriver {
/// Get the port for this driver.
pub fn port(&self) -> u16 {
match self {
InterfaceDriver::Websocket { port, .. } => *port,
}
}
/// Get the allowed origins for this driver.
pub fn allowed_origins(&self) -> &AllowedOrigins {
match self {
InterfaceDriver::Websocket {
allowed_origins, ..
} => allowed_origins,
}
}
}