Fix timeout for chat rooms
This commit is contained in:
parent
638b3e0750
commit
5b8d000856
@ -31,11 +31,12 @@ export class ChatRoomGateway implements OnGatewayInit, OnGatewayConnection, OnGa
|
|||||||
) {
|
) {
|
||||||
setInterval(async () => {
|
setInterval(async () => {
|
||||||
const inactiveRooms = await chatRoomService.inactiveRooms();
|
const inactiveRooms = await chatRoomService.inactiveRooms();
|
||||||
|
console.log(inactiveRooms);
|
||||||
inactiveRooms.forEach((room) => {
|
inactiveRooms.forEach((room) => {
|
||||||
this.server.to(room.id).emit('inactive', room.id);
|
this.server.to(room.id).emit('inactive', room.id);
|
||||||
chatRoomService.remove(room);
|
chatRoomService.remove(room);
|
||||||
});
|
});
|
||||||
}, 5 * (1000 * 60));
|
}, 1000 * 60 * 5);
|
||||||
}
|
}
|
||||||
|
|
||||||
afterInit(server: Server) {
|
afterInit(server: Server) {
|
||||||
|
@ -4,6 +4,8 @@ import { Repository, LessThan } from 'typeorm';
|
|||||||
import { ChatRoom } from 'server/entities/chat_room.entity';
|
import { ChatRoom } from 'server/entities/chat_room.entity';
|
||||||
import { User } from 'server/entities/user.entity';
|
import { User } from 'server/entities/user.entity';
|
||||||
import { ChatRoomConnection } from 'server/entities/chat_room_connection.entity';
|
import { ChatRoomConnection } from 'server/entities/chat_room_connection.entity';
|
||||||
|
import { UsersService } from './users.service';
|
||||||
|
import { RoleKey } from 'server/entities/role.entity';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class ChatRoomService {
|
export class ChatRoomService {
|
||||||
@ -12,6 +14,7 @@ export class ChatRoomService {
|
|||||||
private chatRoomRepository: Repository<ChatRoom>,
|
private chatRoomRepository: Repository<ChatRoom>,
|
||||||
@InjectRepository(ChatRoomConnection)
|
@InjectRepository(ChatRoomConnection)
|
||||||
private connectedUsersRepository: Repository<ChatRoomConnection>,
|
private connectedUsersRepository: Repository<ChatRoomConnection>,
|
||||||
|
private usersService: UsersService,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
create(chatRoom: ChatRoom) {
|
create(chatRoom: ChatRoom) {
|
||||||
@ -75,13 +78,19 @@ export class ChatRoomService {
|
|||||||
|
|
||||||
async inactiveRooms() {
|
async inactiveRooms() {
|
||||||
const inactiveRooms = await this.chatRoomRepository.find({
|
const inactiveRooms = await this.chatRoomRepository.find({
|
||||||
|
relations: ['user'],
|
||||||
where: {
|
where: {
|
||||||
lastModified: LessThan(new Date(Date.now() - 2 * 60 * (1000 * 60))),
|
lastModified: LessThan(new Date(Date.now() - 1000 * 60 * 60 * 2)),
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
return inactiveRooms.filter(async (room) => {
|
const isInactivePromises = inactiveRooms.map(async (room) => {
|
||||||
return !(await this.connectedUsers(room)).length;
|
const isAdmin = await this.usersService.hasRootRole(room.user.id, RoleKey.ADMIN);
|
||||||
|
const hasMoreThanOneConnections = (await this.connectedUsers(room)).length > 1;
|
||||||
|
return !isAdmin && !hasMoreThanOneConnections;
|
||||||
});
|
});
|
||||||
|
const results = await Promise.all(isInactivePromises);
|
||||||
|
|
||||||
|
return inactiveRooms.filter((_, index) => results[index]);
|
||||||
}
|
}
|
||||||
|
|
||||||
save(chatRoom: ChatRoom) {
|
save(chatRoom: ChatRoom) {
|
||||||
|
Loading…
Reference in New Issue
Block a user