From d7365db0b8d8a2716d3228d17fc271fb8f7d1cfd Mon Sep 17 00:00:00 2001 From: "Andrew J. Stone" Date: Fri, 27 Jan 2023 23:27:58 +0000 Subject: [PATCH 1/8] wip --- common/src/address.rs | 2 ++ internal-dns-client/src/names.rs | 2 ++ openapi/sled-agent.json | 14 +++++++++++ package-manifest.toml | 22 +++++++++++++++-- sled-agent/src/params.rs | 6 +++++ sled-agent/src/services.rs | 22 +++++++++++++++++ smf/wicketd/manifest.xml | 42 ++++++++++++++++++++++++++++++++ wicketd/examples/config.toml | 2 -- wicketd/src/bin/wicketd.rs | 13 ++++++++-- wicketd/src/config.rs | 2 -- wicketd/src/lib.rs | 3 ++- 11 files changed, 121 insertions(+), 9 deletions(-) create mode 100644 smf/wicketd/manifest.xml diff --git a/common/src/address.rs b/common/src/address.rs index 46b1e63bd0..0bdbe91b9b 100644 --- a/common/src/address.rs +++ b/common/src/address.rs @@ -39,6 +39,8 @@ pub const CLICKHOUSE_PORT: u16 = 8123; pub const OXIMETER_PORT: u16 = 12223; pub const DENDRITE_PORT: u16 = 12224; pub const MGS_PORT: u16 = 12225; +pub const WICKETD_PORT: u16 = 12226; +pub const WICKETD_ARTIFACT_PORT: u16 = 12227; pub const NEXUS_INTERNAL_PORT: u16 = 12221; diff --git a/internal-dns-client/src/names.rs b/internal-dns-client/src/names.rs index 686a3fd5d9..9b5e90a38f 100644 --- a/internal-dns-client/src/names.rs +++ b/internal-dns-client/src/names.rs @@ -18,6 +18,7 @@ pub enum ServiceName { Nexus, Oximeter, ManagementGatewayService, + Wicketd, Dendrite, Tfport, } @@ -31,6 +32,7 @@ impl fmt::Display for ServiceName { ServiceName::Nexus => write!(f, "nexus"), ServiceName::Oximeter => write!(f, "oximeter"), ServiceName::ManagementGatewayService => write!(f, "mgs"), + ServiceName::Wicketd => write!(f, "wicketd"), ServiceName::Dendrite => write!(f, "dendrite"), ServiceName::Tfport => write!(f, "tfport"), } diff --git a/openapi/sled-agent.json b/openapi/sled-agent.json index bc78fe3a87..022e86fced 100644 --- a/openapi/sled-agent.json +++ b/openapi/sled-agent.json @@ -1483,6 +1483,20 @@ "type" ] }, + { + "type": "object", + "properties": { + "type": { + "type": "string", + "enum": [ + "wicketd" + ] + } + }, + "required": [ + "type" + ] + }, { "type": "object", "properties": { diff --git a/package-manifest.toml b/package-manifest.toml index 79e3f4f629..4b61df88ee 100644 --- a/package-manifest.toml +++ b/package-manifest.toml @@ -72,6 +72,24 @@ source.paths = [ { from = "smf/mgs", to = "/var/svc/manifest/site/mgs" } ] output.type = "zone" output.intermediate_only = true +[package.wicketd] +service_name = "wicketd" +source.type = "local" +source.rust.binary_names = ["wicketd"] +source.rust.release = true +#source.paths = [ { from = "smf/mgs", to = "/var/svc/manifest/site/mgs" } ] +output.type = "zone" +output.intermediate_only = true + +[package.wicket] +service_name = "wicket" +source.type = "local" +source.rust.binary_names = ["wicket"] +source.rust.release = true +output.type = "zone" +output.intermediate_only = true + + # Packages not built within Omicron, but which must be imported. # Refer to @@ -164,7 +182,7 @@ output.intermediate_only = true service_name = "switch" only_for_targets.switch_variant = "asic" source.type = "composite" -source.packages = [ "omicron-gateway.tar.gz", "dendrite-asic.tar.gz" ] +source.packages = [ "omicron-gateway.tar.gz", "dendrite-asic.tar.gz", "wicketd.tar.gz", "wicket.tar.gz" ] output.type = "zone" # To package and install the stub variant of the switch, do the following: @@ -177,5 +195,5 @@ output.type = "zone" service_name = "switch" only_for_targets.switch_variant = "stub" source.type = "composite" -source.packages = [ "omicron-gateway.tar.gz", "dendrite-stub.tar.gz" ] +source.packages = [ "omicron-gateway.tar.gz", "dendrite-stub.tar.gz", "wicketd.tar.gz", "wicket.tar.gz" ] output.type = "zone" diff --git a/sled-agent/src/params.rs b/sled-agent/src/params.rs index 8f3996a13b..455b0f5fba 100644 --- a/sled-agent/src/params.rs +++ b/sled-agent/src/params.rs @@ -378,6 +378,7 @@ pub enum ServiceType { InternalDns { server_address: SocketAddrV6, dns_address: SocketAddrV6 }, Oximeter, ManagementGatewayService, + Wicketd, Dendrite { asic: DendriteAsic }, Tfport { pkt_source: String }, } @@ -389,6 +390,7 @@ impl std::fmt::Display for ServiceType { ServiceType::InternalDns { .. } => write!(f, "internal_dns"), ServiceType::Oximeter => write!(f, "oximeter"), ServiceType::ManagementGatewayService => write!(f, "mgs"), + ServiceType::Wicketd => write!(f, "wicketd"), ServiceType::Dendrite { .. } => write!(f, "dendrite"), ServiceType::Tfport { .. } => write!(f, "tfport"), } @@ -412,6 +414,7 @@ impl From for sled_agent_client::types::ServiceType { } St::Oximeter => AutoSt::Oximeter, St::ManagementGatewayService => AutoSt::ManagementGatewayService, + St::Wicketd => AutoSt::Wicketd, St::Dendrite { asic } => AutoSt::Dendrite { asic: asic.into() }, St::Tfport { pkt_source } => AutoSt::Tfport { pkt_source }, } @@ -497,6 +500,7 @@ impl ServiceZoneRequest { ServiceType::ManagementGatewayService => { SRV::Service(ServiceName::ManagementGatewayService) } + ServiceType::Wicketd => SRV::Service(ServiceName::Wicketd), ServiceType::Dendrite { .. } => SRV::Service(ServiceName::Dendrite), ServiceType::Tfport { .. } => SRV::Service(ServiceName::Tfport), } @@ -516,6 +520,8 @@ impl ServiceZoneRequest { ServiceType::ManagementGatewayService => { Some(SocketAddrV6::new(self.addresses[0], MGS_PORT, 0, 0)) } + // TODO: Is this correct? + ServiceType::Wicketd => None, ServiceType::Dendrite { .. } => { Some(SocketAddrV6::new(self.addresses[0], DENDRITE_PORT, 0, 0)) } diff --git a/sled-agent/src/services.rs b/sled-agent/src/services.rs index 0bfcb002ea..e20f3fc66c 100644 --- a/sled-agent/src/services.rs +++ b/sled-agent/src/services.rs @@ -44,6 +44,8 @@ use omicron_common::address::NEXUS_INTERNAL_PORT; use omicron_common::address::OXIMETER_PORT; use omicron_common::address::RACK_PREFIX; use omicron_common::address::SLED_PREFIX; +use omicron_common::address::WICKETD_ARTIFACT_PORT; +use omicron_common::address::WICKETD_PORT; use omicron_common::nexus_config::{ self, DeploymentConfig as NexusDeploymentConfig, }; @@ -741,6 +743,26 @@ impl ServiceManager { smfh.refresh()?; } + ServiceType::Wicketd => { + info!(self.inner.log, "Setting up wicketd service"); + + smfh.setprop( + "config/address", + &format!("[::1]:{WICKETD_PORT}"), + )?; + + // TODO: Use bootstrap address + smfh.setprop( + "config/artifact-address", + &format!("[::1]:{WICKETD_ARTIFACT_PORT}"), + )?; + + smfh.setprop( + "config/mgs-address", + &format!("[::1]:{MGS_PORT}"), + )?; + smfh.refresh()?; + } ServiceType::Dendrite { asic } => { info!(self.inner.log, "Setting up dendrite service"); diff --git a/smf/wicketd/manifest.xml b/smf/wicketd/manifest.xml new file mode 100644 index 0000000000..aca347b11c --- /dev/null +++ b/smf/wicketd/manifest.xml @@ -0,0 +1,42 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/wicketd/examples/config.toml b/wicketd/examples/config.toml index 7a8923fe0d..703e871ba9 100644 --- a/wicketd/examples/config.toml +++ b/wicketd/examples/config.toml @@ -2,8 +2,6 @@ # Example wicketd config file # -mgs_addr = "[::1]:9999" - [log] # Show log messages of this level and more severe level = "debug" diff --git a/wicketd/src/bin/wicketd.rs b/wicketd/src/bin/wicketd.rs index 96ed77dbcd..0611aa8a92 100644 --- a/wicketd/src/bin/wicketd.rs +++ b/wicketd/src/bin/wicketd.rs @@ -28,6 +28,10 @@ enum Args { /// The address on the bootstrap network to serve artifacts at #[clap(long, action)] artifact_address: SocketAddrV6, + + /// The port on localhost for MGS + #[clap(long, action)] + mgs_address: SocketAddrV6, }, } @@ -43,7 +47,12 @@ async fn do_run() -> Result<(), CmdError> { match args { Args::Openapi => run_openapi().map_err(CmdError::Failure), - Args::Run { config_file_path, address, artifact_address } => { + Args::Run { + config_file_path, + address, + artifact_address, + mgs_address, + } => { let config = Config::from_file(&config_file_path).map_err(|e| { CmdError::Failure(format!( "failed to parse {}: {}", @@ -52,7 +61,7 @@ async fn do_run() -> Result<(), CmdError> { )) })?; - let args = wicketd::Args { address, artifact_address }; + let args = wicketd::Args { address, artifact_address, mgs_address }; run_server(config, args).await.map_err(CmdError::Failure) } } diff --git a/wicketd/src/config.rs b/wicketd/src/config.rs index a4681804b4..613da904d8 100644 --- a/wicketd/src/config.rs +++ b/wicketd/src/config.rs @@ -7,13 +7,11 @@ use dropshot::ConfigLogging; use serde::{Deserialize, Serialize}; use snafu::prelude::*; -use std::net::SocketAddrV6; use std::path::Path; use std::path::PathBuf; #[derive(Clone, Debug, Serialize, Deserialize)] pub struct Config { - pub mgs_addr: SocketAddrV6, pub log: ConfigLogging, } diff --git a/wicketd/src/lib.rs b/wicketd/src/lib.rs index 36010fd387..a31deda576 100644 --- a/wicketd/src/lib.rs +++ b/wicketd/src/lib.rs @@ -35,6 +35,7 @@ pub fn run_openapi() -> Result<(), String> { pub struct Args { pub address: SocketAddrV6, pub artifact_address: SocketAddrV6, + pub mgs_address: SocketAddrV6, } /// Run an instance of the wicketd server @@ -63,7 +64,7 @@ pub async fn run_server(config: Config, args: Args) -> Result<(), String> { ..Default::default() }; - let mgs_manager = MgsManager::new(&log, config.mgs_addr); + let mgs_manager = MgsManager::new(&log, args.mgs_address); let mgs_handle = mgs_manager.get_handle(); tokio::spawn(async move { mgs_manager.run().await; From 8342e6229b777fc1ae48c8a6d0da3ce751094bb9 Mon Sep 17 00:00:00 2001 From: "Andrew J. Stone" Date: Sat, 28 Jan 2023 00:12:18 +0000 Subject: [PATCH 2/8] add wicketd config.toml --- smf/wicketd/config.toml | 11 +++++++++++ 1 file changed, 11 insertions(+) create mode 100644 smf/wicketd/config.toml diff --git a/smf/wicketd/config.toml b/smf/wicketd/config.toml new file mode 100644 index 0000000000..703e871ba9 --- /dev/null +++ b/smf/wicketd/config.toml @@ -0,0 +1,11 @@ +# +# Example wicketd config file +# + +[log] +# Show log messages of this level and more severe +level = "debug" +# Example output to a terminal (with colors) +mode = "stderr-terminal" + + From 5a97e0c8440cf4718fdfe2dd7eb2c8188e170500 Mon Sep 17 00:00:00 2001 From: "Andrew J. Stone" Date: Sat, 28 Jan 2023 00:25:37 +0000 Subject: [PATCH 3/8] Change hardcoded wicketd port to match real sled-agent port --- wicket/src/dispatch.rs | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/wicket/src/dispatch.rs b/wicket/src/dispatch.rs index e9ad4d395b..b65d2237d9 100644 --- a/wicket/src/dispatch.rs +++ b/wicket/src/dispatch.rs @@ -38,7 +38,12 @@ impl WicketApp { /// Executes the command. pub fn exec(self) -> Result<()> { // TODO: make this configurable? - let wicketd_addr: SocketAddrV6 = "[::1]:8000".parse().unwrap(); + // To launch within the switch zone, and as part of a login shell, + // we likely have to store this in a config file, which may have to be written + // by sled-agent. + // + // We can't just use a command line-arg because we want to act as a login shells + let wicketd_addr: SocketAddrV6 = "[::1]:12226".parse().unwrap(); match self.shell_args { Some(shell_args) => { From 44b0a240263283bbc851ae07c3c960bdb9e55bdb Mon Sep 17 00:00:00 2001 From: "Andrew J. Stone" Date: Sat, 28 Jan 2023 01:09:47 +0000 Subject: [PATCH 4/8] uncomment smf for wicketd in package-manifest --- package-manifest.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package-manifest.toml b/package-manifest.toml index 4b61df88ee..844a734ebf 100644 --- a/package-manifest.toml +++ b/package-manifest.toml @@ -77,7 +77,7 @@ service_name = "wicketd" source.type = "local" source.rust.binary_names = ["wicketd"] source.rust.release = true -#source.paths = [ { from = "smf/mgs", to = "/var/svc/manifest/site/mgs" } ] +source.paths = [ { from = "smf/mgs", to = "/var/svc/manifest/site/mgs" } ] output.type = "zone" output.intermediate_only = true From fbd558cc57463b89c72932e3ff341d694e09c1c4 Mon Sep 17 00:00:00 2001 From: "Andrew J. Stone" Date: Mon, 30 Jan 2023 21:05:33 +0000 Subject: [PATCH 5/8] fix copy-pasta --- package-manifest.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package-manifest.toml b/package-manifest.toml index 844a734ebf..04833c10d8 100644 --- a/package-manifest.toml +++ b/package-manifest.toml @@ -77,7 +77,7 @@ service_name = "wicketd" source.type = "local" source.rust.binary_names = ["wicketd"] source.rust.release = true -source.paths = [ { from = "smf/mgs", to = "/var/svc/manifest/site/mgs" } ] +source.paths = [ { from = "smf/wicketd", to = "/var/svc/manifest/site/wicketd" } ] output.type = "zone" output.intermediate_only = true From d40a0cb6180bb0f828305f300266db8792ea5d14 Mon Sep 17 00:00:00 2001 From: "Andrew J. Stone" Date: Mon, 30 Jan 2023 23:22:52 +0000 Subject: [PATCH 6/8] Fix typos in wicketd smf manifest --- smf/wicketd/manifest.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/smf/wicketd/manifest.xml b/smf/wicketd/manifest.xml index aca347b11c..2987fe2a9c 100644 --- a/smf/wicketd/manifest.xml +++ b/smf/wicketd/manifest.xml @@ -23,7 +23,7 @@ - From 6c2888ad1a8e30fdab6c605ea82713e3831b1b46 Mon Sep 17 00:00:00 2001 From: "Andrew J. Stone" Date: Tue, 31 Jan 2023 01:19:18 +0000 Subject: [PATCH 7/8] more wicketd manifest fixes --- smf/wicketd/manifest.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/smf/wicketd/manifest.xml b/smf/wicketd/manifest.xml index 2987fe2a9c..c3bfad19cf 100644 --- a/smf/wicketd/manifest.xml +++ b/smf/wicketd/manifest.xml @@ -13,7 +13,7 @@ From ec4452f2f2d70a46eb042c6e7b88bf156948f5f9 Mon Sep 17 00:00:00 2001 From: "Andrew J. Stone" Date: Tue, 31 Jan 2023 01:20:25 +0000 Subject: [PATCH 8/8] Change artifact port name and run mgs and wicketd in switch stub zone --- common/src/address.rs | 2 +- sled-agent/src/services.rs | 10 +++++++--- 2 files changed, 8 insertions(+), 4 deletions(-) diff --git a/common/src/address.rs b/common/src/address.rs index 0bdbe91b9b..4cdc18eea5 100644 --- a/common/src/address.rs +++ b/common/src/address.rs @@ -40,7 +40,7 @@ pub const OXIMETER_PORT: u16 = 12223; pub const DENDRITE_PORT: u16 = 12224; pub const MGS_PORT: u16 = 12225; pub const WICKETD_PORT: u16 = 12226; -pub const WICKETD_ARTIFACT_PORT: u16 = 12227; +pub const BOOTSTRAP_ARTIFACT_PORT: u16 = 12227; pub const NEXUS_INTERNAL_PORT: u16 = 12221; diff --git a/sled-agent/src/services.rs b/sled-agent/src/services.rs index e20f3fc66c..fb9c885e91 100644 --- a/sled-agent/src/services.rs +++ b/sled-agent/src/services.rs @@ -38,13 +38,13 @@ use crate::params::{ use crate::smf_helper::SmfHelper; use crate::zone::Zones; use omicron_common::address::Ipv6Subnet; +use omicron_common::address::BOOTSTRAP_ARTIFACT_PORT; use omicron_common::address::DENDRITE_PORT; use omicron_common::address::MGS_PORT; use omicron_common::address::NEXUS_INTERNAL_PORT; use omicron_common::address::OXIMETER_PORT; use omicron_common::address::RACK_PREFIX; use omicron_common::address::SLED_PREFIX; -use omicron_common::address::WICKETD_ARTIFACT_PORT; use omicron_common::address::WICKETD_PORT; use omicron_common::nexus_config::{ self, DeploymentConfig as NexusDeploymentConfig, @@ -754,7 +754,7 @@ impl ServiceManager { // TODO: Use bootstrap address smfh.setprop( "config/artifact-address", - &format!("[::1]:{WICKETD_ARTIFACT_PORT}"), + &format!("[::1]:{BOOTSTRAP_ARTIFACT_PORT}"), )?; smfh.setprop( @@ -928,7 +928,11 @@ impl ServiceManager { let services = match self.inner.stub_scrimlet { Some(_) => { - vec![ServiceType::Dendrite { asic: DendriteAsic::TofinoStub }] + vec![ + ServiceType::Dendrite { asic: DendriteAsic::TofinoStub }, + ServiceType::ManagementGatewayService, + ServiceType::Wicketd, + ] } None => { vec![