Skip to content

Commit

Permalink
Merge pull request #1009 from yousseefspires/fix/chats-messages
Browse files Browse the repository at this point in the history
fix: received messages but chat doesnt exists
  • Loading branch information
DavidsonGomes authored Oct 28, 2024
2 parents 0fdc47e + 11d3112 commit e22ff6c
Show file tree
Hide file tree
Showing 2 changed files with 40 additions and 1 deletion.
2 changes: 1 addition & 1 deletion src/api/controllers/instance.controller.ts
Original file line number Diff line number Diff line change
Expand Up @@ -382,7 +382,7 @@ export class InstanceController {
return this.waMonitor.instanceInfoById(instanceId, number);
}

return this.waMonitor.instanceInfo(instanceName);
return this.waMonitor.instanceInfo([instanceName]);
}

public async setPresence({ instanceName }: InstanceDto, data: SetPresenceDto) {
Expand Down
39 changes: 39 additions & 0 deletions src/api/integrations/channel/whatsapp/whatsapp.baileys.service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1071,6 +1071,25 @@ export class BaileysStartupService extends ChannelStartupService {
if (settings?.groupsIgnore && received.key.remoteJid.includes('@g.us')) {
continue;
}
const existingChat = await this.prismaRepository.chat.findFirst({
where: { instanceId: this.instanceId, remoteJid: received.key.remoteJid },
});

if (!!existingChat) {
const chatToInsert = {
remoteJid: received.key.remoteJid,
instanceId: this.instanceId,
name: received.pushName || '',
unreadMessages: 0,
};

this.sendDataWebhook(Events.CHATS_UPSERT, [chatToInsert]);
if (this.configService.get<Database>('DATABASE').SAVE_DATA.CHATS) {
await this.prismaRepository.chat.create({
data: chatToInsert,
});
}
}

const messageRaw = this.prepareMessage(received);

Expand Down Expand Up @@ -1386,6 +1405,26 @@ export class BaileysStartupService extends ChannelStartupService {
await this.prismaRepository.messageUpdate.create({
data: message,
});

const existingChat = await this.prismaRepository.chat.findFirst({
where: { instanceId: this.instanceId, remoteJid: message.key.remoteJid },
});

if (!!existingChat) {
const chatToInsert = {
remoteJid: message.key.remoteJid,
instanceId: this.instanceId,
name: message.pushName || '',
unreadMessages: 0,
};

this.sendDataWebhook(Events.CHATS_UPSERT, [chatToInsert]);
if (this.configService.get<Database>('DATABASE').SAVE_DATA.CHATS) {
await this.prismaRepository.chat.create({
data: chatToInsert,
});
}
}
}
}

Expand Down

0 comments on commit e22ff6c

Please sign in to comment.