Update WhatsappDirectLine.ts

This commit is contained in:
Rodrigo Rodriguez 2019-06-22 07:51:04 -03:00 committed by GitHub
parent bba6299db1
commit 065d0fa2f7
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -104,6 +104,12 @@ export class WhatsappDirectLine extends GBService {
}); });
} }
public static async asyncForEach(array, callback) {
for (let index = 0; index < array.length; index++) {
await callback(array[index], index, array);
}
}
public received(req, res) { public received(req, res) {
const text = req.body.messages[0].body; const text = req.body.messages[0].body;
const from = req.body.messages[0].author.split('@')[0]; const from = req.body.messages[0].author.split('@')[0];
@ -183,8 +189,8 @@ export class WhatsappDirectLine extends GBService {
.catch(err => { .catch(err => {
GBLog.error(`Error calling Conversations_GetActivities on Whatsapp channel ${err.data}`); GBLog.error(`Error calling Conversations_GetActivities on Whatsapp channel ${err.data}`);
}) })
.then(activities => { .then(async activities => {
this.printMessages(activities, conversationId, from, fromName); await this.printMessages(activities, conversationId, from, fromName);
}) })
.catch(err => { .catch(err => {
GBLog.error(`Error calling printMessages on Whatsapp channel ${err.data}`); GBLog.error(`Error calling printMessages on Whatsapp channel ${err.data}`);
@ -195,7 +201,7 @@ export class WhatsappDirectLine extends GBService {
task = setInterval(worker, this.pollInterval); task = setInterval(worker, this.pollInterval);
} }
public printMessages(activities, conversationId, from, fromName) { public async printMessages(activities, conversationId, from, fromName) {
if (activities && activities.length) { if (activities && activities.length) {
// Ignore own messages. // Ignore own messages.
@ -204,18 +210,18 @@ export class WhatsappDirectLine extends GBService {
if (activities.length) { if (activities.length) {
// Print other messages. // Print other messages.
activities.forEach(activity => { await WhatsappDirectLine.asyncForEach(activities, async activity => {
this.printMessage(activity, conversationId, from, fromName); await this.printMessage(activity, conversationId, from, fromName);
}); });
} }
} }
} }
public printMessage(activity, conversationId, from, fromName) { public async printMessage(activity, conversationId, from, fromName) {
let output = ''; let output = '';
if (activity.text) { if (activity.text) {
GBLog.info(`GBWhatsapp: SND ${from}(fromName): ${activity.text}`); GBLog.info(`GBWhatsapp: SND ${from}(${fromName}): ${activity.text}`);
output = activity.text; output = activity.text;
} }
@ -236,7 +242,7 @@ export class WhatsappDirectLine extends GBService {
}); });
} }
this.sendToDevice(from, output); await this.sendToDevice(from, output);
} }
public renderHeroCard(attachment) { public renderHeroCard(attachment) {