Compare commits
3 commits
9823511b62
...
74a70406e3
Author | SHA1 | Date | |
---|---|---|---|
74a70406e3 | |||
8616c70f21 | |||
02c613e0fd |
10 changed files with 149 additions and 186 deletions
|
@ -5,19 +5,16 @@ on:
|
||||||
jobs:
|
jobs:
|
||||||
build-artifacts:
|
build-artifacts:
|
||||||
runs-on: docker
|
runs-on: docker
|
||||||
|
container:
|
||||||
|
image: registry.serguzim.me/emgauwa/runner
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
arch:
|
arch:
|
||||||
#- x86_64-unknown-linux-musl # for docker
|
- x86_64-unknown-linux-gnu # for "standard" systems
|
||||||
|
- x86_64-unknown-linux-musl # for docker
|
||||||
- arm-unknown-linux-gnueabihf # for raspberry pi
|
- arm-unknown-linux-gnueabihf # for raspberry pi
|
||||||
steps:
|
steps:
|
||||||
- uses: https://code.forgejo.org/actions/checkout@v3
|
- uses: https://code.forgejo.org/actions/checkout@v3
|
||||||
- name: Set up Docker Buildx
|
|
||||||
uses: docker/setup-buildx-action@v3
|
|
||||||
- id: install-dependencies
|
|
||||||
run: |
|
|
||||||
curl https://sh.rustup.rs -sSf | sh -s -- -y
|
|
||||||
shell: bash
|
|
||||||
- id: cargo-build-release
|
- id: cargo-build-release
|
||||||
run: |
|
run: |
|
||||||
source "$HOME/.cargo/env"
|
source "$HOME/.cargo/env"
|
||||||
|
@ -27,7 +24,3 @@ jobs:
|
||||||
with:
|
with:
|
||||||
name: emgauwa-core_${{ matrix.arch }}
|
name: emgauwa-core_${{ matrix.arch }}
|
||||||
path: ${{ github.workspace }}/target/${{ matrix.arch }}/release/emgauwa-core
|
path: ${{ github.workspace }}/target/${{ matrix.arch }}/release/emgauwa-core
|
||||||
- uses: https://code.forgejo.org/actions/upload-artifact@v3
|
|
||||||
with:
|
|
||||||
name: emgauwa-controller_${{ matrix.arch }}
|
|
||||||
path: ${{ github.workspace }}/target/${{ matrix.arch }}/release/emgauwa-controller
|
|
||||||
|
|
|
@ -63,10 +63,9 @@ impl AppState {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_relays(&self) -> Result<Vec<Relay>, EmgauwaError> {
|
fn get_relays(&self) -> Result<Vec<Relay>, EmgauwaError> {
|
||||||
let mut tx = block_on(self.pool.begin())?;
|
let mut pool_conn = block_on(self.pool.acquire())?;
|
||||||
let db_controllers = block_on(DbController::get_all(&mut tx))?;
|
let db_controllers = block_on(DbController::get_all(&mut pool_conn))?;
|
||||||
let mut controllers: Vec<Controller> = convert_db_list(&mut tx, db_controllers)?;
|
let mut controllers: Vec<Controller> = convert_db_list(&mut pool_conn, db_controllers)?;
|
||||||
block_on(tx.commit())?;
|
|
||||||
|
|
||||||
self.connected_controllers
|
self.connected_controllers
|
||||||
.iter()
|
.iter()
|
||||||
|
@ -114,11 +113,11 @@ impl Handler<DisconnectController> for AppState {
|
||||||
type Result = Result<(), EmgauwaError>;
|
type Result = Result<(), EmgauwaError>;
|
||||||
|
|
||||||
fn handle(&mut self, msg: DisconnectController, _ctx: &mut Self::Context) -> Self::Result {
|
fn handle(&mut self, msg: DisconnectController, _ctx: &mut Self::Context) -> Self::Result {
|
||||||
let mut tx = block_on(self.pool.begin())?;
|
let mut pool_conn = block_on(self.pool.acquire())?;
|
||||||
|
|
||||||
if let Some((controller, address)) = self.connected_controllers.remove(&msg.controller_uid)
|
if let Some((controller, address)) = self.connected_controllers.remove(&msg.controller_uid)
|
||||||
{
|
{
|
||||||
if let Err(err) = block_on(controller.c.update_active(&mut tx, false)) {
|
if let Err(err) = block_on(controller.c.update_active(&mut pool_conn, false)) {
|
||||||
log::error!(
|
log::error!(
|
||||||
"Failed to mark controller {} as inactive: {:?}",
|
"Failed to mark controller {} as inactive: {:?}",
|
||||||
controller.c.uid,
|
controller.c.uid,
|
||||||
|
@ -129,7 +128,6 @@ impl Handler<DisconnectController> for AppState {
|
||||||
//block_on(address.send(ControllerWsAction::Disconnect))??;
|
//block_on(address.send(ControllerWsAction::Disconnect))??;
|
||||||
address.do_send(ControllerWsAction::Disconnect);
|
address.do_send(ControllerWsAction::Disconnect);
|
||||||
}
|
}
|
||||||
block_on(tx.commit())?;
|
|
||||||
self.notify_relay_clients();
|
self.notify_relay_clients();
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,13 +11,12 @@ use crate::app_state::AppState;
|
||||||
|
|
||||||
#[get("/controllers")]
|
#[get("/controllers")]
|
||||||
pub async fn index(pool: web::Data<Pool<Sqlite>>) -> Result<HttpResponse, EmgauwaError> {
|
pub async fn index(pool: web::Data<Pool<Sqlite>>) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let db_controllers = DbController::get_all(&mut tx).await?;
|
let db_controllers = DbController::get_all(&mut pool_conn).await?;
|
||||||
|
|
||||||
let controllers: Vec<Controller> = convert_db_list(&mut tx, db_controllers)?;
|
let controllers: Vec<Controller> = convert_db_list(&mut pool_conn, db_controllers)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(controllers))
|
Ok(HttpResponse::Ok().json(controllers))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -26,18 +25,16 @@ pub async fn show(
|
||||||
pool: web::Data<Pool<Sqlite>>,
|
pool: web::Data<Pool<Sqlite>>,
|
||||||
path: web::Path<(String,)>,
|
path: web::Path<(String,)>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (controller_uid,) = path.into_inner();
|
let (controller_uid,) = path.into_inner();
|
||||||
let uid = EmgauwaUid::try_from(controller_uid.as_str())?;
|
let uid = EmgauwaUid::try_from(controller_uid.as_str())?;
|
||||||
|
|
||||||
let controller = DbController::get_by_uid(&mut tx, &uid)
|
let controller = DbController::get_by_uid(&mut pool_conn, &uid)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
let return_controller = Controller::from_db_model(&mut tx, controller)?;
|
let return_controller = Controller::from_db_model(&mut pool_conn, controller)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(return_controller))
|
Ok(HttpResponse::Ok().json(return_controller))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,20 +45,20 @@ pub async fn update(
|
||||||
path: web::Path<(String,)>,
|
path: web::Path<(String,)>,
|
||||||
data: web::Json<RequestControllerUpdate>,
|
data: web::Json<RequestControllerUpdate>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (controller_uid,) = path.into_inner();
|
let (controller_uid,) = path.into_inner();
|
||||||
let uid = EmgauwaUid::try_from(controller_uid.as_str())?;
|
let uid = EmgauwaUid::try_from(controller_uid.as_str())?;
|
||||||
|
|
||||||
let controller = DbController::get_by_uid(&mut tx, &uid)
|
let controller = DbController::get_by_uid(&mut pool_conn, &uid)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
let controller = controller
|
let controller = controller
|
||||||
.update(&mut tx, data.name.as_str(), controller.relay_count)
|
.update(&mut pool_conn, data.name.as_str(), controller.relay_count)
|
||||||
.await?;
|
.await?;
|
||||||
|
|
||||||
let return_controller = Controller::from_db_model(&mut tx, controller)?;
|
let return_controller = Controller::from_db_model(&mut pool_conn, controller)?;
|
||||||
|
|
||||||
app_state
|
app_state
|
||||||
.send(app_state::Action {
|
.send(app_state::Action {
|
||||||
|
@ -70,7 +67,6 @@ pub async fn update(
|
||||||
})
|
})
|
||||||
.await??;
|
.await??;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(return_controller))
|
Ok(HttpResponse::Ok().json(return_controller))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -80,7 +76,7 @@ pub async fn delete(
|
||||||
app_state: web::Data<Addr<AppState>>,
|
app_state: web::Data<Addr<AppState>>,
|
||||||
path: web::Path<(String,)>,
|
path: web::Path<(String,)>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (controller_uid,) = path.into_inner();
|
let (controller_uid,) = path.into_inner();
|
||||||
let uid = EmgauwaUid::try_from(controller_uid.as_str())?;
|
let uid = EmgauwaUid::try_from(controller_uid.as_str())?;
|
||||||
|
@ -91,8 +87,6 @@ pub async fn delete(
|
||||||
})
|
})
|
||||||
.await??;
|
.await??;
|
||||||
|
|
||||||
DbController::delete_by_uid(&mut tx, uid).await?;
|
DbController::delete_by_uid(&mut pool_conn, uid).await?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json("controller got deleted"))
|
Ok(HttpResponse::Ok().json("controller got deleted"))
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,25 +1,25 @@
|
||||||
use actix::Addr;
|
use actix::Addr;
|
||||||
use actix_web::{delete, get, post, put, web, HttpResponse};
|
use actix_web::{delete, get, HttpResponse, post, put, web};
|
||||||
|
use itertools::Itertools;
|
||||||
|
use sqlx::{Pool, Sqlite};
|
||||||
|
|
||||||
use emgauwa_common::db::DbMacro;
|
use emgauwa_common::db::DbMacro;
|
||||||
use emgauwa_common::errors::{DatabaseError, EmgauwaError};
|
use emgauwa_common::errors::{DatabaseError, EmgauwaError};
|
||||||
use emgauwa_common::models::{convert_db_list, FromDbModel, Macro, MacroAction, Relay};
|
use emgauwa_common::models::{convert_db_list, FromDbModel, Macro, MacroAction, Relay};
|
||||||
use emgauwa_common::types::{
|
use emgauwa_common::types::{
|
||||||
ControllerWsAction, EmgauwaUid, RequestMacroCreate, RequestMacroExecute, RequestMacroUpdate,
|
ControllerWsAction, EmgauwaUid, RequestMacroCreate, RequestMacroExecute, RequestMacroUpdate,
|
||||||
};
|
};
|
||||||
use itertools::Itertools;
|
|
||||||
use sqlx::{Pool, Sqlite};
|
|
||||||
|
|
||||||
use crate::app_state;
|
use crate::app_state;
|
||||||
use crate::app_state::AppState;
|
use crate::app_state::AppState;
|
||||||
|
|
||||||
#[get("/macros")]
|
#[get("/macros")]
|
||||||
pub async fn index(pool: web::Data<Pool<Sqlite>>) -> Result<HttpResponse, EmgauwaError> {
|
pub async fn index(pool: web::Data<Pool<Sqlite>>) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let db_macros = DbMacro::get_all(&mut tx).await?;
|
let db_macros = DbMacro::get_all(&mut pool_conn).await?;
|
||||||
let macros: Vec<Macro> = convert_db_list(&mut tx, db_macros)?;
|
let macros: Vec<Macro> = convert_db_list(&mut pool_conn, db_macros)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(macros))
|
Ok(HttpResponse::Ok().json(macros))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -28,18 +28,16 @@ pub async fn show(
|
||||||
pool: web::Data<Pool<Sqlite>>,
|
pool: web::Data<Pool<Sqlite>>,
|
||||||
path: web::Path<(String,)>,
|
path: web::Path<(String,)>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (macro_uid,) = path.into_inner();
|
let (macro_uid,) = path.into_inner();
|
||||||
let uid = EmgauwaUid::try_from(macro_uid.as_str())?;
|
let uid = EmgauwaUid::try_from(macro_uid.as_str())?;
|
||||||
|
|
||||||
let db_macro = DbMacro::get_by_uid(&mut tx, &uid)
|
let db_macro = DbMacro::get_by_uid(&mut pool_conn, &uid)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
let return_macro = Macro::from_db_model(&mut tx, db_macro)?;
|
let return_macro = Macro::from_db_model(&mut pool_conn, db_macro)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(return_macro))
|
Ok(HttpResponse::Ok().json(return_macro))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,17 +46,15 @@ pub async fn add(
|
||||||
pool: web::Data<Pool<Sqlite>>,
|
pool: web::Data<Pool<Sqlite>>,
|
||||||
data: web::Json<RequestMacroCreate>,
|
data: web::Json<RequestMacroCreate>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let new_macro = DbMacro::create(&mut tx, EmgauwaUid::default(), &data.name).await?;
|
let new_macro = DbMacro::create(&mut pool_conn, EmgauwaUid::default(), &data.name).await?;
|
||||||
|
|
||||||
new_macro
|
new_macro
|
||||||
.set_actions(&mut tx, data.actions.as_slice())
|
.set_actions(&mut pool_conn, data.actions.as_slice())
|
||||||
.await?;
|
.await?;
|
||||||
|
|
||||||
let return_macro = Macro::from_db_model(&mut tx, new_macro)?;
|
let return_macro = Macro::from_db_model(&mut pool_conn, new_macro)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Created().json(return_macro))
|
Ok(HttpResponse::Created().json(return_macro))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -68,28 +64,26 @@ pub async fn update(
|
||||||
path: web::Path<(String,)>,
|
path: web::Path<(String,)>,
|
||||||
data: web::Json<RequestMacroUpdate>,
|
data: web::Json<RequestMacroUpdate>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (macro_uid,) = path.into_inner();
|
let (macro_uid,) = path.into_inner();
|
||||||
let uid = EmgauwaUid::try_from(macro_uid.as_str())?;
|
let uid = EmgauwaUid::try_from(macro_uid.as_str())?;
|
||||||
|
|
||||||
let db_macro = DbMacro::get_by_uid(&mut tx, &uid)
|
let db_macro = DbMacro::get_by_uid(&mut pool_conn, &uid)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
if let Some(name) = &data.name {
|
if let Some(name) = &data.name {
|
||||||
db_macro.update(&mut tx, name).await?;
|
db_macro.update(&mut pool_conn, name).await?;
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Some(actions) = &data.actions {
|
if let Some(actions) = &data.actions {
|
||||||
db_macro
|
db_macro
|
||||||
.set_actions(&mut tx, actions.as_slice())
|
.set_actions(&mut pool_conn, actions.as_slice())
|
||||||
.await?;
|
.await?;
|
||||||
}
|
}
|
||||||
|
|
||||||
let return_macro = Macro::from_db_model(&mut tx, db_macro)?;
|
let return_macro = Macro::from_db_model(&mut pool_conn, db_macro)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(return_macro))
|
Ok(HttpResponse::Ok().json(return_macro))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -98,14 +92,12 @@ pub async fn delete(
|
||||||
pool: web::Data<Pool<Sqlite>>,
|
pool: web::Data<Pool<Sqlite>>,
|
||||||
path: web::Path<(String,)>,
|
path: web::Path<(String,)>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (macro_uid,) = path.into_inner();
|
let (macro_uid,) = path.into_inner();
|
||||||
let uid = EmgauwaUid::try_from(macro_uid.as_str())?;
|
let uid = EmgauwaUid::try_from(macro_uid.as_str())?;
|
||||||
|
|
||||||
DbMacro::delete_by_uid(&mut tx, uid).await?;
|
DbMacro::delete_by_uid(&mut pool_conn, uid).await?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json("macro got deleted"))
|
Ok(HttpResponse::Ok().json("macro got deleted"))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -116,27 +108,27 @@ pub async fn execute(
|
||||||
path: web::Path<(String,)>,
|
path: web::Path<(String,)>,
|
||||||
query: web::Query<RequestMacroExecute>,
|
query: web::Query<RequestMacroExecute>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (macro_uid,) = path.into_inner();
|
let (macro_uid,) = path.into_inner();
|
||||||
let uid = EmgauwaUid::try_from(macro_uid.as_str())?;
|
let uid = EmgauwaUid::try_from(macro_uid.as_str())?;
|
||||||
|
|
||||||
let db_macro = DbMacro::get_by_uid(&mut tx, &uid)
|
let db_macro = DbMacro::get_by_uid(&mut pool_conn, &uid)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
let actions_db = match query.weekday {
|
let actions_db = match query.weekday {
|
||||||
None => db_macro.get_actions(&mut tx).await?,
|
None => db_macro.get_actions(&mut pool_conn).await?,
|
||||||
Some(weekday) => {
|
Some(weekday) => {
|
||||||
db_macro
|
db_macro
|
||||||
.get_actions_weekday(&mut tx, weekday)
|
.get_actions_weekday(&mut pool_conn, weekday)
|
||||||
.await?
|
.await?
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
let mut actions: Vec<MacroAction> = convert_db_list(&mut tx, actions_db)?;
|
let mut actions: Vec<MacroAction> = convert_db_list(&mut pool_conn, actions_db)?;
|
||||||
|
|
||||||
for action in &actions {
|
for action in &actions {
|
||||||
action.execute(&mut tx).await?;
|
action.execute(&mut pool_conn).await?;
|
||||||
}
|
}
|
||||||
|
|
||||||
let affected_controller_uids: Vec<EmgauwaUid> = actions
|
let affected_controller_uids: Vec<EmgauwaUid> = actions
|
||||||
|
@ -150,10 +142,12 @@ pub async fn execute(
|
||||||
let mut affected_relay_ids: Vec<i64> = Vec::new();
|
let mut affected_relay_ids: Vec<i64> = Vec::new();
|
||||||
|
|
||||||
for action in actions.iter_mut() {
|
for action in actions.iter_mut() {
|
||||||
if affected_relay_ids.contains(&action.relay.r.id) {
|
if affected_relay_ids.contains(&action.relay.r.id)
|
||||||
|
|| action.relay.controller_id != controller_uid
|
||||||
|
{
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
action.relay.reload(&mut tx)?;
|
action.relay.reload(&mut pool_conn)?;
|
||||||
affected_relays.push(action.relay.clone());
|
affected_relays.push(action.relay.clone());
|
||||||
affected_relay_ids.push(action.relay.r.id);
|
affected_relay_ids.push(action.relay.r.id);
|
||||||
}
|
}
|
||||||
|
@ -166,6 +160,5 @@ pub async fn execute(
|
||||||
.await??;
|
.await??;
|
||||||
}
|
}
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().finish()) // TODO add a message?
|
Ok(HttpResponse::Ok().finish()) // TODO add a message?
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,13 +14,12 @@ use crate::app_state::AppState;
|
||||||
|
|
||||||
#[get("/relays")]
|
#[get("/relays")]
|
||||||
pub async fn index(pool: web::Data<Pool<Sqlite>>) -> Result<HttpResponse, EmgauwaError> {
|
pub async fn index(pool: web::Data<Pool<Sqlite>>) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let db_relays = DbRelay::get_all(&mut tx).await?;
|
let db_relays = DbRelay::get_all(&mut pool_conn).await?;
|
||||||
|
|
||||||
let relays: Vec<Relay> = convert_db_list(&mut tx, db_relays)?;
|
let relays: Vec<Relay> = convert_db_list(&mut pool_conn, db_relays)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(relays))
|
Ok(HttpResponse::Ok().json(relays))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,17 +28,16 @@ pub async fn tagged(
|
||||||
pool: web::Data<Pool<Sqlite>>,
|
pool: web::Data<Pool<Sqlite>>,
|
||||||
path: web::Path<(String,)>,
|
path: web::Path<(String,)>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (tag,) = path.into_inner();
|
let (tag,) = path.into_inner();
|
||||||
let tag_db = DbTag::get_by_tag(&mut tx, &tag)
|
let tag_db = DbTag::get_by_tag(&mut pool_conn, &tag)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
let db_relays = DbRelay::get_by_tag(&mut tx, &tag_db).await?;
|
let db_relays = DbRelay::get_by_tag(&mut pool_conn, &tag_db).await?;
|
||||||
let relays: Vec<Relay> = convert_db_list(&mut tx, db_relays)?;
|
let relays: Vec<Relay> = convert_db_list(&mut pool_conn, db_relays)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(relays))
|
Ok(HttpResponse::Ok().json(relays))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,20 +46,18 @@ pub async fn index_for_controller(
|
||||||
pool: web::Data<Pool<Sqlite>>,
|
pool: web::Data<Pool<Sqlite>>,
|
||||||
path: web::Path<(String,)>,
|
path: web::Path<(String,)>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (controller_uid,) = path.into_inner();
|
let (controller_uid,) = path.into_inner();
|
||||||
let uid = EmgauwaUid::try_from(controller_uid.as_str())?;
|
let uid = EmgauwaUid::try_from(controller_uid.as_str())?;
|
||||||
|
|
||||||
let controller = DbController::get_by_uid(&mut tx, &uid)
|
let controller = DbController::get_by_uid(&mut pool_conn, &uid)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
let db_relays = controller.get_relays(&mut tx).await?;
|
let db_relays = controller.get_relays(&mut pool_conn).await?;
|
||||||
|
|
||||||
let relays: Vec<Relay> = convert_db_list(&mut tx, db_relays)?;
|
let relays: Vec<Relay> = convert_db_list(&mut pool_conn, db_relays)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(relays))
|
Ok(HttpResponse::Ok().json(relays))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,22 +66,20 @@ pub async fn show_for_controller(
|
||||||
pool: web::Data<Pool<Sqlite>>,
|
pool: web::Data<Pool<Sqlite>>,
|
||||||
path: web::Path<(String, i64)>,
|
path: web::Path<(String, i64)>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (controller_uid, relay_num) = path.into_inner();
|
let (controller_uid, relay_num) = path.into_inner();
|
||||||
let uid = EmgauwaUid::try_from(controller_uid.as_str())?;
|
let uid = EmgauwaUid::try_from(controller_uid.as_str())?;
|
||||||
|
|
||||||
let controller = DbController::get_by_uid(&mut tx, &uid)
|
let controller = DbController::get_by_uid(&mut pool_conn, &uid)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
let relay = DbRelay::get_by_controller_and_num(&mut tx, &controller, relay_num)
|
let relay = DbRelay::get_by_controller_and_num(&mut pool_conn, &controller, relay_num)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
let return_relay = Relay::from_db_model(&mut tx, relay)?;
|
let return_relay = Relay::from_db_model(&mut pool_conn, relay)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(return_relay))
|
Ok(HttpResponse::Ok().json(return_relay))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,32 +90,32 @@ pub async fn update_for_controller(
|
||||||
path: web::Path<(String, i64)>,
|
path: web::Path<(String, i64)>,
|
||||||
data: web::Json<RequestRelayUpdate>,
|
data: web::Json<RequestRelayUpdate>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (controller_uid, relay_num) = path.into_inner();
|
let (controller_uid, relay_num) = path.into_inner();
|
||||||
let uid = EmgauwaUid::try_from(controller_uid.as_str())?;
|
let uid = EmgauwaUid::try_from(controller_uid.as_str())?;
|
||||||
|
|
||||||
let controller = DbController::get_by_uid(&mut tx, &uid)
|
let controller = DbController::get_by_uid(&mut pool_conn, &uid)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
let mut relay = DbRelay::get_by_controller_and_num(&mut tx, &controller, relay_num)
|
let mut relay = DbRelay::get_by_controller_and_num(&mut pool_conn, &controller, relay_num)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
if let Some(name) = &data.name {
|
if let Some(name) = &data.name {
|
||||||
relay = relay.update(&mut tx, name.as_str()).await?;
|
relay = relay.update(&mut pool_conn, name.as_str()).await?;
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Some(schedule_uids) = &data.schedules {
|
if let Some(schedule_uids) = &data.schedules {
|
||||||
if schedule_uids.len() == 7 {
|
if schedule_uids.len() == 7 {
|
||||||
let mut schedules = Vec::new();
|
let mut schedules = Vec::new();
|
||||||
for s_uid in schedule_uids {
|
for s_uid in schedule_uids {
|
||||||
schedules.push(s_uid.get_schedule(&mut tx).await?);
|
schedules.push(s_uid.get_schedule(&mut pool_conn).await?);
|
||||||
}
|
}
|
||||||
|
|
||||||
DbJunctionRelaySchedule::set_schedules(
|
DbJunctionRelaySchedule::set_schedules(
|
||||||
&mut tx,
|
&mut pool_conn,
|
||||||
&relay,
|
&relay,
|
||||||
schedules.iter().collect(),
|
schedules.iter().collect(),
|
||||||
)
|
)
|
||||||
|
@ -130,9 +124,9 @@ pub async fn update_for_controller(
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Some(s_uid) = &data.active_schedule {
|
if let Some(s_uid) = &data.active_schedule {
|
||||||
let schedule = s_uid.get_schedule(&mut tx).await?;
|
let schedule = s_uid.get_schedule(&mut pool_conn).await?;
|
||||||
DbJunctionRelaySchedule::set_schedule(
|
DbJunctionRelaySchedule::set_schedule(
|
||||||
&mut tx,
|
&mut pool_conn,
|
||||||
&relay,
|
&relay,
|
||||||
&schedule,
|
&schedule,
|
||||||
utils::get_weekday(),
|
utils::get_weekday(),
|
||||||
|
@ -141,12 +135,12 @@ pub async fn update_for_controller(
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Some(tags) = &data.tags {
|
if let Some(tags) = &data.tags {
|
||||||
relay.set_tags(&mut tx, tags.as_slice()).await?;
|
relay.set_tags(&mut pool_conn, tags.as_slice()).await?;
|
||||||
}
|
}
|
||||||
|
|
||||||
let relay = relay.reload(&mut tx).await?;
|
let relay = relay.reload(&mut pool_conn).await?;
|
||||||
|
|
||||||
let return_relay = Relay::from_db_model(&mut tx, relay)?;
|
let return_relay = Relay::from_db_model(&mut pool_conn, relay)?;
|
||||||
|
|
||||||
app_state
|
app_state
|
||||||
.send(app_state::Action {
|
.send(app_state::Action {
|
||||||
|
@ -155,7 +149,6 @@ pub async fn update_for_controller(
|
||||||
})
|
})
|
||||||
.await??;
|
.await??;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(return_relay))
|
Ok(HttpResponse::Ok().json(return_relay))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -166,16 +159,16 @@ pub async fn pulse(
|
||||||
path: web::Path<(String, i64)>,
|
path: web::Path<(String, i64)>,
|
||||||
data: web::Json<RequestRelayPulse>,
|
data: web::Json<RequestRelayPulse>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (controller_uid, relay_num) = path.into_inner();
|
let (controller_uid, relay_num) = path.into_inner();
|
||||||
let uid = EmgauwaUid::try_from(controller_uid.as_str())?;
|
let uid = EmgauwaUid::try_from(controller_uid.as_str())?;
|
||||||
|
|
||||||
let controller = DbController::get_by_uid(&mut tx, &uid)
|
let controller = DbController::get_by_uid(&mut pool_conn, &uid)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
let relay = DbRelay::get_by_controller_and_num(&mut tx, &controller, relay_num)
|
let relay = DbRelay::get_by_controller_and_num(&mut pool_conn, &controller, relay_num)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
|
@ -188,6 +181,5 @@ pub async fn pulse(
|
||||||
})
|
})
|
||||||
.await??;
|
.await??;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().finish()) // TODO add a message?
|
Ok(HttpResponse::Ok().finish()) // TODO add a message?
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,7 @@ use emgauwa_common::types::{
|
||||||
ControllerWsAction, RequestScheduleCreate, RequestScheduleUpdate, ScheduleUid,
|
ControllerWsAction, RequestScheduleCreate, RequestScheduleUpdate, ScheduleUid,
|
||||||
};
|
};
|
||||||
use itertools::Itertools;
|
use itertools::Itertools;
|
||||||
use sqlx::Transaction;
|
use sqlx::pool::PoolConnection;
|
||||||
use sqlx::{Pool, Sqlite};
|
use sqlx::{Pool, Sqlite};
|
||||||
|
|
||||||
use crate::app_state;
|
use crate::app_state;
|
||||||
|
@ -15,12 +15,11 @@ use crate::app_state::AppState;
|
||||||
|
|
||||||
#[get("/schedules")]
|
#[get("/schedules")]
|
||||||
pub async fn index(pool: web::Data<Pool<Sqlite>>) -> Result<HttpResponse, EmgauwaError> {
|
pub async fn index(pool: web::Data<Pool<Sqlite>>) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let db_schedules = DbSchedule::get_all(&mut tx).await?;
|
let db_schedules = DbSchedule::get_all(&mut pool_conn).await?;
|
||||||
let schedules: Vec<Schedule> = convert_db_list(&mut tx, db_schedules)?;
|
let schedules: Vec<Schedule> = convert_db_list(&mut pool_conn, db_schedules)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(schedules))
|
Ok(HttpResponse::Ok().json(schedules))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,17 +28,16 @@ pub async fn tagged(
|
||||||
pool: web::Data<Pool<Sqlite>>,
|
pool: web::Data<Pool<Sqlite>>,
|
||||||
path: web::Path<(String,)>,
|
path: web::Path<(String,)>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (tag,) = path.into_inner();
|
let (tag,) = path.into_inner();
|
||||||
let tag_db = DbTag::get_by_tag(&mut tx, &tag)
|
let tag_db = DbTag::get_by_tag(&mut pool_conn, &tag)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
let db_schedules = DbSchedule::get_by_tag(&mut tx, &tag_db).await?;
|
let db_schedules = DbSchedule::get_by_tag(&mut pool_conn, &tag_db).await?;
|
||||||
let schedules: Vec<Schedule> = convert_db_list(&mut tx, db_schedules)?;
|
let schedules: Vec<Schedule> = convert_db_list(&mut pool_conn, db_schedules)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(schedules))
|
Ok(HttpResponse::Ok().json(schedules))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,18 +46,16 @@ pub async fn show(
|
||||||
pool: web::Data<Pool<Sqlite>>,
|
pool: web::Data<Pool<Sqlite>>,
|
||||||
path: web::Path<(String,)>,
|
path: web::Path<(String,)>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (schedule_uid,) = path.into_inner();
|
let (schedule_uid,) = path.into_inner();
|
||||||
let uid = ScheduleUid::try_from(schedule_uid.as_str())?;
|
let uid = ScheduleUid::try_from(schedule_uid.as_str())?;
|
||||||
|
|
||||||
let schedule = DbSchedule::get_by_uid(&mut tx, &uid)
|
let schedule = DbSchedule::get_by_uid(&mut pool_conn, &uid)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
let return_schedule = Schedule::from_db_model(&mut tx, schedule)?;
|
let return_schedule = Schedule::from_db_model(&mut pool_conn, schedule)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(return_schedule))
|
Ok(HttpResponse::Ok().json(return_schedule))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -68,10 +64,10 @@ pub async fn add(
|
||||||
pool: web::Data<Pool<Sqlite>>,
|
pool: web::Data<Pool<Sqlite>>,
|
||||||
data: web::Json<RequestScheduleCreate>,
|
data: web::Json<RequestScheduleCreate>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let new_schedule = DbSchedule::create(
|
let new_schedule = DbSchedule::create(
|
||||||
&mut tx,
|
&mut pool_conn,
|
||||||
ScheduleUid::default(),
|
ScheduleUid::default(),
|
||||||
&data.name,
|
&data.name,
|
||||||
&data.periods,
|
&data.periods,
|
||||||
|
@ -80,22 +76,20 @@ pub async fn add(
|
||||||
|
|
||||||
if let Some(tags) = &data.tags {
|
if let Some(tags) = &data.tags {
|
||||||
new_schedule
|
new_schedule
|
||||||
.set_tags(&mut tx, tags.as_slice())
|
.set_tags(&mut pool_conn, tags.as_slice())
|
||||||
.await?;
|
.await?;
|
||||||
}
|
}
|
||||||
|
|
||||||
let return_schedule = Schedule::from_db_model(&mut tx, new_schedule)?;
|
let return_schedule = Schedule::from_db_model(&mut pool_conn, new_schedule)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Created().json(return_schedule))
|
Ok(HttpResponse::Created().json(return_schedule))
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn add_list_single(
|
async fn add_list_single(
|
||||||
tx: &mut Transaction<'_, Sqlite>,
|
conn: &mut PoolConnection<Sqlite>,
|
||||||
request_schedule: &RequestScheduleCreate,
|
request_schedule: &RequestScheduleCreate,
|
||||||
) -> Result<DbSchedule, DatabaseError> {
|
) -> Result<DbSchedule, DatabaseError> {
|
||||||
let new_schedule = DbSchedule::create(
|
let new_schedule = DbSchedule::create(
|
||||||
tx,
|
conn,
|
||||||
ScheduleUid::default(),
|
ScheduleUid::default(),
|
||||||
&request_schedule.name,
|
&request_schedule.name,
|
||||||
&request_schedule.periods,
|
&request_schedule.periods,
|
||||||
|
@ -103,7 +97,7 @@ async fn add_list_single(
|
||||||
.await?;
|
.await?;
|
||||||
|
|
||||||
if let Some(tags) = &request_schedule.tags {
|
if let Some(tags) = &request_schedule.tags {
|
||||||
new_schedule.set_tags(tx, tags.as_slice()).await?;
|
new_schedule.set_tags(conn, tags.as_slice()).await?;
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(new_schedule)
|
Ok(new_schedule)
|
||||||
|
@ -114,17 +108,15 @@ pub async fn add_list(
|
||||||
pool: web::Data<Pool<Sqlite>>,
|
pool: web::Data<Pool<Sqlite>>,
|
||||||
data: web::Json<Vec<RequestScheduleCreate>>,
|
data: web::Json<Vec<RequestScheduleCreate>>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let mut db_schedules: Vec<DbSchedule> = Vec::new();
|
let mut db_schedules: Vec<DbSchedule> = Vec::new();
|
||||||
for s in data.iter() {
|
for s in data.iter() {
|
||||||
let new_s = add_list_single(&mut tx, s).await?;
|
let new_s = futures::executor::block_on(add_list_single(&mut pool_conn, s))?;
|
||||||
db_schedules.push(new_s);
|
db_schedules.push(new_s);
|
||||||
}
|
}
|
||||||
|
|
||||||
let schedules: Vec<Schedule> = convert_db_list(&mut tx, db_schedules)?;
|
let schedules: Vec<Schedule> = convert_db_list(&mut pool_conn, db_schedules)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Created().json(schedules))
|
Ok(HttpResponse::Created().json(schedules))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -135,12 +127,12 @@ pub async fn update(
|
||||||
path: web::Path<(String,)>,
|
path: web::Path<(String,)>,
|
||||||
data: web::Json<RequestScheduleUpdate>,
|
data: web::Json<RequestScheduleUpdate>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (schedule_uid,) = path.into_inner();
|
let (schedule_uid,) = path.into_inner();
|
||||||
let uid = ScheduleUid::try_from(schedule_uid.as_str())?;
|
let uid = ScheduleUid::try_from(schedule_uid.as_str())?;
|
||||||
|
|
||||||
let schedule = DbSchedule::get_by_uid(&mut tx, &uid)
|
let schedule = DbSchedule::get_by_uid(&mut pool_conn, &uid)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
|
@ -154,13 +146,13 @@ pub async fn update(
|
||||||
Some(period) => period,
|
Some(period) => period,
|
||||||
};
|
};
|
||||||
|
|
||||||
let schedule = schedule.update(&mut tx, name, periods).await?;
|
let schedule = schedule.update(&mut pool_conn, name, periods).await?;
|
||||||
|
|
||||||
if let Some(tags) = &data.tags {
|
if let Some(tags) = &data.tags {
|
||||||
schedule.set_tags(&mut tx, tags.as_slice()).await?;
|
schedule.set_tags(&mut pool_conn, tags.as_slice()).await?;
|
||||||
}
|
}
|
||||||
|
|
||||||
let controller_ids: Vec<i64> = DbJunctionRelaySchedule::get_relays(&mut tx, &schedule)
|
let controller_ids: Vec<i64> = DbJunctionRelaySchedule::get_relays(&mut pool_conn, &schedule)
|
||||||
.await?
|
.await?
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.map(|r| r.controller_id)
|
.map(|r| r.controller_id)
|
||||||
|
@ -168,7 +160,7 @@ pub async fn update(
|
||||||
.collect();
|
.collect();
|
||||||
|
|
||||||
for controller_id in controller_ids {
|
for controller_id in controller_ids {
|
||||||
let controller = DbController::get(&mut tx, controller_id)
|
let controller = DbController::get(&mut pool_conn, controller_id)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
app_state
|
app_state
|
||||||
|
@ -179,9 +171,7 @@ pub async fn update(
|
||||||
.await??;
|
.await??;
|
||||||
}
|
}
|
||||||
|
|
||||||
let return_schedule = Schedule::from_db_model(&mut tx, schedule)?;
|
let return_schedule = Schedule::from_db_model(&mut pool_conn, schedule)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(return_schedule))
|
Ok(HttpResponse::Ok().json(return_schedule))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -190,6 +180,8 @@ pub async fn delete(
|
||||||
pool: web::Data<Pool<Sqlite>>,
|
pool: web::Data<Pool<Sqlite>>,
|
||||||
path: web::Path<(String,)>,
|
path: web::Path<(String,)>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (schedule_uid,) = path.into_inner();
|
let (schedule_uid,) = path.into_inner();
|
||||||
let uid = ScheduleUid::try_from(schedule_uid.as_str())?;
|
let uid = ScheduleUid::try_from(schedule_uid.as_str())?;
|
||||||
|
|
||||||
|
@ -197,9 +189,7 @@ pub async fn delete(
|
||||||
ScheduleUid::Off => Err(EmgauwaError::from(ApiError::ProtectedSchedule)),
|
ScheduleUid::Off => Err(EmgauwaError::from(ApiError::ProtectedSchedule)),
|
||||||
ScheduleUid::On => Err(EmgauwaError::from(ApiError::ProtectedSchedule)),
|
ScheduleUid::On => Err(EmgauwaError::from(ApiError::ProtectedSchedule)),
|
||||||
ScheduleUid::Any(_) => {
|
ScheduleUid::Any(_) => {
|
||||||
let mut tx = pool.begin().await?;
|
DbSchedule::delete_by_uid(&mut pool_conn, uid).await?;
|
||||||
DbSchedule::delete_by_uid(&mut tx, uid).await?;
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json("schedule got deleted"))
|
Ok(HttpResponse::Ok().json("schedule got deleted"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,13 +7,12 @@ use sqlx::{Pool, Sqlite};
|
||||||
|
|
||||||
#[get("/tags")]
|
#[get("/tags")]
|
||||||
pub async fn index(pool: web::Data<Pool<Sqlite>>) -> Result<HttpResponse, EmgauwaError> {
|
pub async fn index(pool: web::Data<Pool<Sqlite>>) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let db_tags = DbTag::get_all(&mut tx).await?;
|
let db_tags = DbTag::get_all(&mut pool_conn).await?;
|
||||||
|
|
||||||
let tags: Vec<String> = db_tags.iter().map(|t| t.tag.clone()).collect();
|
let tags: Vec<String> = db_tags.iter().map(|t| t.tag.clone()).collect();
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(tags))
|
Ok(HttpResponse::Ok().json(tags))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -22,17 +21,15 @@ pub async fn show(
|
||||||
pool: web::Data<Pool<Sqlite>>,
|
pool: web::Data<Pool<Sqlite>>,
|
||||||
path: web::Path<(String,)>,
|
path: web::Path<(String,)>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (tag_name,) = path.into_inner();
|
let (tag_name,) = path.into_inner();
|
||||||
|
|
||||||
let tag = DbTag::get_by_tag(&mut tx, &tag_name)
|
let tag = DbTag::get_by_tag(&mut pool_conn, &tag_name)
|
||||||
.await?
|
.await?
|
||||||
.ok_or(DatabaseError::NotFound)?;
|
.ok_or(DatabaseError::NotFound)?;
|
||||||
|
|
||||||
let return_tag = Tag::from_db_model(&mut tx, tag)?;
|
let return_tag = Tag::from_db_model(&mut pool_conn, tag)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json(return_tag))
|
Ok(HttpResponse::Ok().json(return_tag))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -41,13 +38,11 @@ pub async fn delete(
|
||||||
pool: web::Data<Pool<Sqlite>>,
|
pool: web::Data<Pool<Sqlite>>,
|
||||||
path: web::Path<(String,)>,
|
path: web::Path<(String,)>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let (tag_name,) = path.into_inner();
|
let (tag_name,) = path.into_inner();
|
||||||
|
|
||||||
DbTag::delete_by_tag(&mut tx, &tag_name).await?;
|
DbTag::delete_by_tag(&mut pool_conn, &tag_name).await?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Ok().json("tag got deleted"))
|
Ok(HttpResponse::Ok().json("tag got deleted"))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -56,13 +51,11 @@ pub async fn add(
|
||||||
pool: web::Data<Pool<Sqlite>>,
|
pool: web::Data<Pool<Sqlite>>,
|
||||||
data: web::Json<RequestTagCreate>,
|
data: web::Json<RequestTagCreate>,
|
||||||
) -> Result<HttpResponse, EmgauwaError> {
|
) -> Result<HttpResponse, EmgauwaError> {
|
||||||
let mut tx = pool.begin().await?;
|
let mut pool_conn = pool.acquire().await?;
|
||||||
|
|
||||||
let new_tag = DbTag::create(&mut tx, &data.tag).await?;
|
let new_tag = DbTag::create(&mut pool_conn, &data.tag).await?;
|
||||||
|
|
||||||
let cache = (Vec::new(), Vec::new()); // a new tag can't have any relays or schedules
|
let cache = (Vec::new(), Vec::new()); // a new tag can't have any relays or schedules
|
||||||
let return_tag = Tag::from_db_model_cache(&mut tx, new_tag, cache)?;
|
let return_tag = Tag::from_db_model_cache(&mut pool_conn, new_tag, cache)?;
|
||||||
|
|
||||||
tx.commit().await?;
|
|
||||||
Ok(HttpResponse::Created().json(return_tag))
|
Ok(HttpResponse::Created().json(return_tag))
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,6 +5,8 @@ use emgauwa_common::models::{Controller, FromDbModel};
|
||||||
use emgauwa_common::types::{ControllerWsAction, EmgauwaUid, RelayStates};
|
use emgauwa_common::types::{ControllerWsAction, EmgauwaUid, RelayStates};
|
||||||
use emgauwa_common::utils;
|
use emgauwa_common::utils;
|
||||||
use futures::executor::block_on;
|
use futures::executor::block_on;
|
||||||
|
use sqlx::pool::PoolConnection;
|
||||||
|
use sqlx::Sqlite;
|
||||||
|
|
||||||
use crate::app_state::{Action, ConnectController, UpdateRelayStates};
|
use crate::app_state::{Action, ConnectController, UpdateRelayStates};
|
||||||
use crate::handlers::v1::ws::controllers::ControllersWs;
|
use crate::handlers::v1::ws::controllers::ControllersWs;
|
||||||
|
@ -12,6 +14,7 @@ use crate::handlers::v1::ws::controllers::ControllersWs;
|
||||||
impl ControllersWs {
|
impl ControllersWs {
|
||||||
pub fn handle_register(
|
pub fn handle_register(
|
||||||
&mut self,
|
&mut self,
|
||||||
|
conn: &mut PoolConnection<Sqlite>,
|
||||||
ctx: &mut <ControllersWs as Actor>::Context,
|
ctx: &mut <ControllersWs as Actor>::Context,
|
||||||
controller: Controller,
|
controller: Controller,
|
||||||
) -> Result<(), EmgauwaError> {
|
) -> Result<(), EmgauwaError> {
|
||||||
|
@ -20,19 +23,16 @@ impl ControllersWs {
|
||||||
controller.c.name,
|
controller.c.name,
|
||||||
controller.c.uid
|
controller.c.uid
|
||||||
);
|
);
|
||||||
|
|
||||||
let mut tx = block_on(self.pool.begin())?;
|
|
||||||
|
|
||||||
let c = &controller.c;
|
let c = &controller.c;
|
||||||
let controller_db = block_on(DbController::get_by_uid_or_create(
|
let controller_db = block_on(DbController::get_by_uid_or_create(
|
||||||
&mut tx,
|
conn,
|
||||||
&c.uid,
|
&c.uid,
|
||||||
&c.name,
|
&c.name,
|
||||||
c.relay_count,
|
c.relay_count,
|
||||||
))?;
|
))?;
|
||||||
block_on(controller_db.update_active(&mut tx, true))?;
|
block_on(controller_db.update_active(conn, true))?;
|
||||||
// update only the relay count
|
// update only the relay count
|
||||||
block_on(controller_db.update(&mut tx, &controller_db.name, c.relay_count))?;
|
block_on(controller_db.update(conn, &controller_db.name, c.relay_count))?;
|
||||||
|
|
||||||
for relay in &controller.relays {
|
for relay in &controller.relays {
|
||||||
log::debug!(
|
log::debug!(
|
||||||
|
@ -45,7 +45,7 @@ impl ControllersWs {
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
let (new_relay, created) = block_on(DbRelay::get_by_controller_and_num_or_create(
|
let (new_relay, created) = block_on(DbRelay::get_by_controller_and_num_or_create(
|
||||||
&mut tx,
|
conn,
|
||||||
&controller_db,
|
&controller_db,
|
||||||
relay.r.number,
|
relay.r.number,
|
||||||
&relay.r.name,
|
&relay.r.name,
|
||||||
|
@ -54,7 +54,7 @@ impl ControllersWs {
|
||||||
let mut relay_schedules = Vec::new();
|
let mut relay_schedules = Vec::new();
|
||||||
for schedule in &relay.schedules {
|
for schedule in &relay.schedules {
|
||||||
let (new_schedule, _) = block_on(DbSchedule::get_by_uid_or_create(
|
let (new_schedule, _) = block_on(DbSchedule::get_by_uid_or_create(
|
||||||
&mut tx,
|
conn,
|
||||||
schedule.uid.clone(),
|
schedule.uid.clone(),
|
||||||
&schedule.name,
|
&schedule.name,
|
||||||
&schedule.periods,
|
&schedule.periods,
|
||||||
|
@ -63,7 +63,7 @@ impl ControllersWs {
|
||||||
}
|
}
|
||||||
|
|
||||||
block_on(DbJunctionRelaySchedule::set_schedules(
|
block_on(DbJunctionRelaySchedule::set_schedules(
|
||||||
&mut tx,
|
conn,
|
||||||
&new_relay,
|
&new_relay,
|
||||||
relay_schedules.iter().collect(),
|
relay_schedules.iter().collect(),
|
||||||
))?;
|
))?;
|
||||||
|
@ -71,9 +71,9 @@ impl ControllersWs {
|
||||||
}
|
}
|
||||||
|
|
||||||
let controller_uid = &controller.c.uid;
|
let controller_uid = &controller.c.uid;
|
||||||
let controller_db = block_on(DbController::get_by_uid(&mut tx, controller_uid))?
|
let controller_db = block_on(DbController::get_by_uid(conn, controller_uid))?
|
||||||
.ok_or(DatabaseError::InsertGetError)?;
|
.ok_or(DatabaseError::InsertGetError)?;
|
||||||
let controller = Controller::from_db_model(&mut tx, controller_db)?;
|
let controller = Controller::from_db_model(conn, controller_db)?;
|
||||||
|
|
||||||
let addr = ctx.address();
|
let addr = ctx.address();
|
||||||
self.controller_uid = Some(controller_uid.clone());
|
self.controller_uid = Some(controller_uid.clone());
|
||||||
|
@ -91,7 +91,6 @@ impl ControllersWs {
|
||||||
action: ControllerWsAction::Relays(controller.relays),
|
action: ControllerWsAction::Relays(controller.relays),
|
||||||
}))??;
|
}))??;
|
||||||
|
|
||||||
block_on(tx.commit())?;
|
|
||||||
log::debug!("Done registering controller");
|
log::debug!("Done registering controller");
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,6 +9,7 @@ use emgauwa_common::constants::{HEARTBEAT_INTERVAL, HEARTBEAT_TIMEOUT};
|
||||||
use emgauwa_common::errors::EmgauwaError;
|
use emgauwa_common::errors::EmgauwaError;
|
||||||
use emgauwa_common::types::{ControllerWsAction, EmgauwaUid};
|
use emgauwa_common::types::{ControllerWsAction, EmgauwaUid};
|
||||||
use futures::executor::block_on;
|
use futures::executor::block_on;
|
||||||
|
use sqlx::pool::PoolConnection;
|
||||||
use sqlx::{Pool, Sqlite};
|
use sqlx::{Pool, Sqlite};
|
||||||
use ws::Message;
|
use ws::Message;
|
||||||
|
|
||||||
|
@ -47,11 +48,12 @@ impl Actor for ControllersWs {
|
||||||
impl ControllersWs {
|
impl ControllersWs {
|
||||||
pub fn handle_action(
|
pub fn handle_action(
|
||||||
&mut self,
|
&mut self,
|
||||||
|
conn: &mut PoolConnection<Sqlite>,
|
||||||
ctx: &mut <ControllersWs as Actor>::Context,
|
ctx: &mut <ControllersWs as Actor>::Context,
|
||||||
action: ControllerWsAction,
|
action: ControllerWsAction,
|
||||||
) {
|
) {
|
||||||
let action_res = match action {
|
let action_res = match action {
|
||||||
ControllerWsAction::Register(controller) => self.handle_register(ctx, controller),
|
ControllerWsAction::Register(controller) => self.handle_register(conn, ctx, controller),
|
||||||
ControllerWsAction::RelayStates((controller_uid, relay_states)) => {
|
ControllerWsAction::RelayStates((controller_uid, relay_states)) => {
|
||||||
self.handle_relay_states(controller_uid, relay_states)
|
self.handle_relay_states(controller_uid, relay_states)
|
||||||
}
|
}
|
||||||
|
@ -101,6 +103,15 @@ impl Handler<ControllerWsAction> for ControllersWs {
|
||||||
|
|
||||||
impl StreamHandler<Result<Message, ProtocolError>> for ControllersWs {
|
impl StreamHandler<Result<Message, ProtocolError>> for ControllersWs {
|
||||||
fn handle(&mut self, msg: Result<Message, ProtocolError>, ctx: &mut Self::Context) {
|
fn handle(&mut self, msg: Result<Message, ProtocolError>, ctx: &mut Self::Context) {
|
||||||
|
let mut pool_conn = match block_on(self.pool.acquire()) {
|
||||||
|
Ok(conn) => conn,
|
||||||
|
Err(err) => {
|
||||||
|
log::error!("Failed to acquire database connection: {:?}", err);
|
||||||
|
ctx.stop();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
let msg = match msg {
|
let msg = match msg {
|
||||||
Err(_) => {
|
Err(_) => {
|
||||||
ctx.stop();
|
ctx.stop();
|
||||||
|
@ -119,7 +130,7 @@ impl StreamHandler<Result<Message, ProtocolError>> for ControllersWs {
|
||||||
}
|
}
|
||||||
Message::Text(text) => match serde_json::from_str(&text) {
|
Message::Text(text) => match serde_json::from_str(&text) {
|
||||||
Ok(action) => {
|
Ok(action) => {
|
||||||
self.handle_action(ctx, action);
|
self.handle_action(&mut pool_conn, ctx, action);
|
||||||
}
|
}
|
||||||
Err(e) => {
|
Err(e) => {
|
||||||
log::error!("Error deserializing action: {:?}", e);
|
log::error!("Error deserializing action: {:?}", e);
|
||||||
|
|
|
@ -28,11 +28,11 @@ async fn main() -> Result<(), std::io::Error> {
|
||||||
|
|
||||||
let pool = emgauwa_common::db::init(&settings.database).await?;
|
let pool = emgauwa_common::db::init(&settings.database).await?;
|
||||||
|
|
||||||
let mut tx = pool.begin().await.map_err(EmgauwaError::from)?;
|
let mut conn = pool.acquire().await.map_err(EmgauwaError::from)?;
|
||||||
DbController::all_inactive(&mut tx)
|
DbController::all_inactive(&mut conn)
|
||||||
.await
|
.await
|
||||||
.map_err(EmgauwaError::from)?;
|
.map_err(EmgauwaError::from)?;
|
||||||
tx.commit().await.map_err(EmgauwaError::from)?;
|
conn.close().await.map_err(EmgauwaError::from)?;
|
||||||
|
|
||||||
let app_state_arbiter = Arbiter::with_tokio_rt(|| {
|
let app_state_arbiter = Arbiter::with_tokio_rt(|| {
|
||||||
tokio::runtime::Builder::new_multi_thread()
|
tokio::runtime::Builder::new_multi_thread()
|
||||||
|
|
Loading…
Reference in a new issue