Rename connection_lost
to answering_connection_lost
This commit is contained in:
parent
26b5653427
commit
456396ca6e
5 changed files with 10 additions and 9 deletions
|
@ -118,7 +118,7 @@ CREATE TABLE "room_participants" (
|
||||||
"user_id" INTEGER NOT NULL REFERENCES users (id),
|
"user_id" INTEGER NOT NULL REFERENCES users (id),
|
||||||
"answering_connection_id" INTEGER,
|
"answering_connection_id" INTEGER,
|
||||||
"answering_connection_epoch" TEXT,
|
"answering_connection_epoch" TEXT,
|
||||||
"connection_lost" BOOLEAN NOT NULL,
|
"answering_connection_lost" BOOLEAN NOT NULL,
|
||||||
"location_kind" INTEGER,
|
"location_kind" INTEGER,
|
||||||
"location_project_id" INTEGER,
|
"location_project_id" INTEGER,
|
||||||
"initial_project_id" INTEGER,
|
"initial_project_id" INTEGER,
|
||||||
|
|
|
@ -1,2 +1,2 @@
|
||||||
ALTER TABLE "room_participants"
|
ALTER TABLE "room_participants"
|
||||||
ADD "connection_lost" BOOLEAN NOT NULL DEFAULT FALSE;
|
ADD "answering_connection_lost" BOOLEAN NOT NULL DEFAULT FALSE;
|
||||||
|
|
|
@ -1034,7 +1034,7 @@ impl Database {
|
||||||
user_id: ActiveValue::set(user_id),
|
user_id: ActiveValue::set(user_id),
|
||||||
answering_connection_id: ActiveValue::set(Some(connection_id.0 as i32)),
|
answering_connection_id: ActiveValue::set(Some(connection_id.0 as i32)),
|
||||||
answering_connection_epoch: ActiveValue::set(Some(self.epoch)),
|
answering_connection_epoch: ActiveValue::set(Some(self.epoch)),
|
||||||
connection_lost: ActiveValue::set(false),
|
answering_connection_lost: ActiveValue::set(false),
|
||||||
calling_user_id: ActiveValue::set(user_id),
|
calling_user_id: ActiveValue::set(user_id),
|
||||||
calling_connection_id: ActiveValue::set(connection_id.0 as i32),
|
calling_connection_id: ActiveValue::set(connection_id.0 as i32),
|
||||||
calling_connection_epoch: ActiveValue::set(self.epoch),
|
calling_connection_epoch: ActiveValue::set(self.epoch),
|
||||||
|
@ -1061,7 +1061,7 @@ impl Database {
|
||||||
room_participant::ActiveModel {
|
room_participant::ActiveModel {
|
||||||
room_id: ActiveValue::set(room_id),
|
room_id: ActiveValue::set(room_id),
|
||||||
user_id: ActiveValue::set(called_user_id),
|
user_id: ActiveValue::set(called_user_id),
|
||||||
connection_lost: ActiveValue::set(false),
|
answering_connection_lost: ActiveValue::set(false),
|
||||||
calling_user_id: ActiveValue::set(calling_user_id),
|
calling_user_id: ActiveValue::set(calling_user_id),
|
||||||
calling_connection_id: ActiveValue::set(calling_connection_id.0 as i32),
|
calling_connection_id: ActiveValue::set(calling_connection_id.0 as i32),
|
||||||
calling_connection_epoch: ActiveValue::set(self.epoch),
|
calling_connection_epoch: ActiveValue::set(self.epoch),
|
||||||
|
@ -1180,13 +1180,13 @@ impl Database {
|
||||||
.and(
|
.and(
|
||||||
room_participant::Column::AnsweringConnectionId
|
room_participant::Column::AnsweringConnectionId
|
||||||
.is_null()
|
.is_null()
|
||||||
.or(room_participant::Column::ConnectionLost.eq(true)),
|
.or(room_participant::Column::AnsweringConnectionLost.eq(true)),
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
.set(room_participant::ActiveModel {
|
.set(room_participant::ActiveModel {
|
||||||
answering_connection_id: ActiveValue::set(Some(connection_id.0 as i32)),
|
answering_connection_id: ActiveValue::set(Some(connection_id.0 as i32)),
|
||||||
answering_connection_epoch: ActiveValue::set(Some(self.epoch)),
|
answering_connection_epoch: ActiveValue::set(Some(self.epoch)),
|
||||||
connection_lost: ActiveValue::set(false),
|
answering_connection_lost: ActiveValue::set(false),
|
||||||
..Default::default()
|
..Default::default()
|
||||||
})
|
})
|
||||||
.exec(&*tx)
|
.exec(&*tx)
|
||||||
|
@ -1387,7 +1387,7 @@ impl Database {
|
||||||
let room_id = participant.room_id;
|
let room_id = participant.room_id;
|
||||||
|
|
||||||
room_participant::Entity::update(room_participant::ActiveModel {
|
room_participant::Entity::update(room_participant::ActiveModel {
|
||||||
connection_lost: ActiveValue::set(true),
|
answering_connection_lost: ActiveValue::set(true),
|
||||||
..participant.into_active_model()
|
..participant.into_active_model()
|
||||||
})
|
})
|
||||||
.exec(&*tx)
|
.exec(&*tx)
|
||||||
|
|
|
@ -10,7 +10,7 @@ pub struct Model {
|
||||||
pub user_id: UserId,
|
pub user_id: UserId,
|
||||||
pub answering_connection_id: Option<i32>,
|
pub answering_connection_id: Option<i32>,
|
||||||
pub answering_connection_epoch: Option<Uuid>,
|
pub answering_connection_epoch: Option<Uuid>,
|
||||||
pub connection_lost: bool,
|
pub answering_connection_lost: bool,
|
||||||
pub location_kind: Option<i32>,
|
pub location_kind: Option<i32>,
|
||||||
pub location_project_id: Option<ProjectId>,
|
pub location_project_id: Option<ProjectId>,
|
||||||
pub initial_project_id: Option<ProjectId>,
|
pub initial_project_id: Option<ProjectId>,
|
||||||
|
|
|
@ -658,11 +658,12 @@ async fn sign_out(
|
||||||
.await
|
.await
|
||||||
.remove_connection(session.connection_id)?;
|
.remove_connection(session.connection_id)?;
|
||||||
|
|
||||||
if let Ok(mut left_projects) = session
|
if let Some(mut left_projects) = session
|
||||||
.db()
|
.db()
|
||||||
.await
|
.await
|
||||||
.connection_lost(session.connection_id)
|
.connection_lost(session.connection_id)
|
||||||
.await
|
.await
|
||||||
|
.trace_err()
|
||||||
{
|
{
|
||||||
for left_project in mem::take(&mut *left_projects) {
|
for left_project in mem::take(&mut *left_projects) {
|
||||||
project_left(&left_project, &session);
|
project_left(&left_project, &session);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue