|
@ -44,15 +44,15 @@ export class ChatController { |
|
|
} |
|
|
} |
|
|
const dms = channels.filter((channel: Channel) => { |
|
|
const dms = channels.filter((channel: Channel) => { |
|
|
return ( |
|
|
return ( |
|
|
(channel.name === (user.ftId + '&' + other.ftId) || |
|
|
(channel.name === user.ftId + '&' + other.ftId || |
|
|
channel.name === (other.ftId + '&' + user.ftId)) && |
|
|
channel.name === other.ftId + '&' + user.ftId) && |
|
|
channel.isPrivate && |
|
|
channel.isPrivate && |
|
|
(channel.password === undefined || channel.password === '') |
|
|
(channel.password === undefined || channel.password === '') |
|
|
) |
|
|
) |
|
|
}) |
|
|
}) |
|
|
dms.forEach((c) => { |
|
|
dms.forEach((c) => { |
|
|
c.users.forEach((u) => u.socketKey = '') |
|
|
c.users.forEach((u) => (u.socketKey = '')) |
|
|
c.admins.forEach((u) => u.socketKey = '') |
|
|
c.admins.forEach((u) => (u.socketKey = '')) |
|
|
c.owner.socketKey = '' |
|
|
c.owner.socketKey = '' |
|
|
}) |
|
|
}) |
|
|
return dms |
|
|
return dms |
|
@ -112,10 +112,12 @@ export class ChatController { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Get(':id/users') |
|
|
@Get(':id/users') |
|
|
async getUsersOfChannel (@Param('id', ParseIntPipe) id: number): Promise<User[]> { |
|
|
async getUsersOfChannel ( |
|
|
let users = (await this.channelService.getFullChannel(id)).users |
|
|
@Param('id', ParseIntPipe) id: number |
|
|
users.forEach((u) => u.socketKey = '') |
|
|
): Promise<User[]> { |
|
|
return users; |
|
|
const users = (await this.channelService.getFullChannel(id)).users |
|
|
|
|
|
users.forEach((u) => (u.socketKey = '')) |
|
|
|
|
|
return users |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Post(':id/admin') |
|
|
@Post(':id/admin') |
|
@ -165,6 +167,7 @@ export class ChatController { |
|
|
async addBan ( |
|
|
async addBan ( |
|
|
@Param('id', ParseIntPipe) id: number, |
|
|
@Param('id', ParseIntPipe) id: number, |
|
|
@Body() target: IdDto, |
|
|
@Body() target: IdDto, |
|
|
|
|
|
@Body() duration: number, |
|
|
@Profile42() profile: Profile |
|
|
@Profile42() profile: Profile |
|
|
): Promise<void> { |
|
|
): Promise<void> { |
|
|
const channel = await this.channelService.getFullChannel(id) |
|
|
const channel = await this.channelService.getFullChannel(id) |
|
@ -183,7 +186,7 @@ export class ChatController { |
|
|
if (await this.channelService.isBanned(channel.id, target.id)) { |
|
|
if (await this.channelService.isBanned(channel.id, target.id)) { |
|
|
throw new BadRequestException('User is already banned from this channel') |
|
|
throw new BadRequestException('User is already banned from this channel') |
|
|
} |
|
|
} |
|
|
channel.banned.push(user) |
|
|
channel.banned.push([user.id, duration]) |
|
|
await this.channelService.save(channel) |
|
|
await this.channelService.save(channel) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -245,7 +248,7 @@ export class ChatController { |
|
|
@Param('id', ParseIntPipe) id: number |
|
|
@Param('id', ParseIntPipe) id: number |
|
|
): Promise<void> { |
|
|
): Promise<void> { |
|
|
if (await this.channelService.isOwner(id, +profile.id)) { |
|
|
if (await this.channelService.isOwner(id, +profile.id)) { |
|
|
this.channelService.removeChannel(id) // -> verify that the deletion the break others users behaviors.
|
|
|
await this.channelService.removeChannel(id) // -> verify that the deletion the break others users behaviors.
|
|
|
} |
|
|
} |
|
|
const channel = await this.channelService.getFullChannel(id) |
|
|
const channel = await this.channelService.getFullChannel(id) |
|
|
channel.users = channel.users.filter((usr: User) => { |
|
|
channel.users = channel.users.filter((usr: User) => { |
|
@ -256,16 +259,16 @@ export class ChatController { |
|
|
|
|
|
|
|
|
@Get() |
|
|
@Get() |
|
|
async getChannelsForUser (@Profile42() profile: Profile): Promise<Channel[]> { |
|
|
async getChannelsForUser (@Profile42() profile: Profile): Promise<Channel[]> { |
|
|
let chan = await this.channelService.getChannelsForUser(+profile.id) |
|
|
const chan = await this.channelService.getChannelsForUser(+profile.id) |
|
|
return chan; |
|
|
return chan |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Post() |
|
|
@Post() |
|
|
async createChannel (@Body() channel: CreateChannelDto): Promise<Channel> { |
|
|
async createChannel (@Body() channel: CreateChannelDto): Promise<Channel> { |
|
|
let chan = await this.channelService.createChannel(channel) |
|
|
const chan = await this.channelService.createChannel(channel) |
|
|
chan.users.forEach((u) => u.socketKey = '') |
|
|
chan.users.forEach((u) => (u.socketKey = '')) |
|
|
chan.admins.forEach((u) => u.socketKey = '') |
|
|
chan.admins.forEach((u) => (u.socketKey = '')) |
|
|
chan.owner.socketKey = '' |
|
|
chan.owner.socketKey = '' |
|
|
return chan; |
|
|
return chan |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|