aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCara Salter <cara@devcara.com>2022-06-09 15:17:17 -0400
committerCara Salter <cara@devcara.com>2022-06-09 15:17:17 -0400
commit03989d646ee3fd74536d420860e9f5bcf58937af (patch)
tree439e8f164d2c4f1a8068b31ce77fa5d2e203b8c8
parentb81eaf785286519b9e5b7725cc4d4dd66175a892 (diff)
downloadsolard-03989d646ee3fd74536d420860e9f5bcf58937af.tar.gz
solard-03989d646ee3fd74536d420860e9f5bcf58937af.zip
state: Reboot
Issue #1
-rw-r--r--Cargo.lock4
-rw-r--r--src/handlers/planets.rs12
-rw-r--r--src/main.rs3
3 files changed, 16 insertions, 3 deletions
diff --git a/Cargo.lock b/Cargo.lock
index b7b1e17..3f449e1 100644
--- a/Cargo.lock
+++ b/Cargo.lock
@@ -862,8 +862,8 @@ dependencies = [
[[package]]
name = "solarlib"
-version = "1.4.0"
-source = "git+https://git.carathe.dev/muirrum/solarlib?branch=master#137ec4c34aa962b11148cfad443a4c88035e3d87"
+version = "1.4.1"
+source = "git+https://git.carathe.dev/muirrum/solarlib?branch=master#f73eb90d830df1a0881447d918985e315aed6fb7"
dependencies = [
"mac_address",
"rand",
diff --git a/src/handlers/planets.rs b/src/handlers/planets.rs
index a57f605..ede7b2b 100644
--- a/src/handlers/planets.rs
+++ b/src/handlers/planets.rs
@@ -64,3 +64,15 @@ pub async fn pause(Path(uuid): Path<String>) -> NoneResult {
Ok(())
}
+
+pub async fn reboot(Path(uuid): Path<String>) -> NoneResult {
+ let mut s = get_star()?;
+
+ if let Ok(p) = s.find_planet(uuid) {
+ p.reboot()?;
+ } else {
+ return Err(ServiceError::NotFound);
+ }
+
+ Ok(())
+}
diff --git a/src/main.rs b/src/main.rs
index 28036d4..b962764 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -27,7 +27,7 @@ async fn main() {
tracing_subscriber::registry()
.with(tracing_subscriber::EnvFilter::new(
std::env::var("RUST_LOG")
- .unwrap_or_else(|_| "waifud=info,tower_http=debug".into()),
+ .unwrap_or_else(|_| "solard=info,tower_http=debug".into()),
))
.with(tracing_subscriber::fmt::layer())
.init();
@@ -39,6 +39,7 @@ async fn main() {
.route("/planets/:uuid/shutdown", post(handlers::planets::shutdown))
.route("/planets/:uuid/start", post(handlers::planets::start))
.route("/planets/:uuid/pause", post(handlers::planets::pause))
+ .route("/planets/:uuid/reboot", post(handlers::planets::reboot))
.layer( ServiceBuilder::new()
.layer(HandleErrorLayer::new(|error: BoxError| async move {
if error.is::<tower::timeout::error::Elapsed>() {