Update room deletion helper

And remove etherpad groups when the corresponding room is deleted
master
Daniel Berteaud 11 years ago
parent 8378ddb78a
commit 6416c8ac6a
  1. 50
      public/vroom.pl

@ -334,21 +334,35 @@ helper has_joined => sub {
helper delete_rooms => sub { helper delete_rooms => sub {
my $self = shift; my $self = shift;
$self->app->log->debug('Removing unused rooms'); $self->app->log->debug('Removing unused rooms');
eval { my $timeout = time()-$config->{inactivityTimeout};
my $timeout = time()-$config->{inactivityTimeout}; my $sth = eval { $self->db->prepare("SELECT `id` FROM rooms WHERE `activity_timestamp` < $timeout AND `persistent`='0';") } || return undef;
$self->db->do("DELETE FROM `participants` WHERE `id` IN (SELECT `id` FROM `rooms` WHERE `activity_timestamp` < $timeout AND `persistent`='0');"); $sth->execute();
$self->db->do("DELETE FROM `notifications` WHERE `id` IN (SELECT `id` FROM `rooms` WHERE `activity_timestamp` < $timeout AND `persistent`='0');"); my @toDelete = $sth->fetchrow_array;
$self->db->do("DELETE FROM `invitations` WHERE `id` IN (SELECT `id` FROM `rooms` WHERE `activity_timestamp` < $timeout AND `persistent`='0');"); if ($config->{persistentInactivityTimeout} > 0){
$self->db->do("DELETE FROM `rooms` WHERE `activity_timestamp` < $timeout AND `persistent`='0';"); $timeout = time()-$config->{persistentInactivityTimeout};
} || return undef; $sth = eval { $self->db->prepare("SELECT `id` FROM rooms WHERE `activity_timestamp` < $timeout AND `persistent`='1';") } || return undef;
if ($config->{persistentInactivityTimeout} && $config->{persistentInactivityTimeout} > 0){ $sth->execute();
eval { push @toDelete, $sth->fetchrow_array;
my $timeout = time()-$config->{persistentInactivityTimeout}; }
$self->db->do("DELETE FROM `participants` WHERE `id` IN (SELECT `id` FROM `rooms` WHERE `activity_timestamp` < $timeout AND `persistent`='1');"); foreach my $room (@toDelete){
$self->db->do("DELETE FROM `notifications` WHERE `id` IN (SELECT `id` FROM `rooms` WHERE `activity_timestamp` < $timeout AND `persistent`='1');"); my $data = $self->get_room($room);
$self->db->do("DELETE FROM `invitations` WHERE `id` IN (SELECT `id` FROM `rooms` WHERE `activity_timestamp` < $timeout AND `persistent`='1');"); $self->app->log->debug("Room " . $data->{name} . " will be deleted");
$self->db->do("DELETE FROM `rooms` WHERE `activity_timestamp` < $timeout AND `persistent`='1';"); # Remove Etherpad group
} || return undef; if ($ec){
$ec->delete_group($data->{etherpad_group});
}
}
# Now remove rooms
if (scalar @toDelete > 0){
foreach my $table (qw(participants notifications invitations rooms)){
$sth = eval {
$self->db->prepare("DELETE FROM `$table` WHERE `id` IN (" . join( ",", map { "?" } @toDelete ) . ")");
} || return undef;
$sth->execute(@toDelete) || return undef;
}
}
else{
$self->app->log->debug('No rooms deleted, as none has expired');
} }
return 1; return 1;
}; };
@ -835,9 +849,9 @@ get '/(*room)' => sub {
# Create etherpad session if needed # Create etherpad session if needed
if ($ec && !$self->session($room)->{etherpadSession}){ if ($ec && !$self->session($room)->{etherpadSession}){
my $id = $ec->create_author_if_not_exists_for($self->session('name')); my $id = $ec->create_author_if_not_exists_for($self->session('name'));
$self->session($room => {etherpadAuthorId => $id}); $self->session($room)->{etherpadAuthorId} = $id;
my $etherpadSession = $ec->create_session($data->{etherpad_group}, $id, time+86400); my $etherpadSession = $ec->create_session($data->{etherpad_group}, $id, time + 86400);
$self->session($room => {etherpadSessionId => $etherpadSession}); $self->session($room)->{etherpadSessionId} = $etherpadSession;
$self->cookie(sessionID => $etherpadSession); $self->cookie(sessionID => $etherpadSession);
} }
# Short life cookie to negociate a session with the signaling server # Short life cookie to negociate a session with the signaling server

Loading…
Cancel
Save