Start Typebot com opção de ativar chatbot ou nãoUpdate typebot.service.ts

- Foi criada a variável enabled_typebot (não obrigatória) 
- Com ela será possível disparar chatbots ou apenas mensagens.
- Se omitida essa variável no comando start Typebot, não obrigatoriedade permitida para efeitos de compatiblidade com o formato nas versões anteriores,  enabled_typebot será assumida como true, ou seja, start typebot com o chatbot ativado.
-  Se setada como true, o flow disparado é ativado como chatbot , como sao os fluxos originais do typebot, porém se marcada como false,  dispara apenas como notificação e não ativa o bot.
This commit is contained in:
Francis Breit 2023-10-01 20:23:44 -03:00 committed by GitHub
parent bddd6408ac
commit c1e7b65a54
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -99,6 +99,8 @@ export class TypebotService {
const remoteJid = data.remoteJid;
const url = data.url;
const typebot = data.typebot;
// linha incluida por Francis:
const enabled_typebot = data.enabled_typebot;
const variables = data.variables;
const findTypebot = await this.find(instance);
const sessions = (findTypebot.sessions as Session[]) ?? [];
@ -115,9 +117,16 @@ export class TypebotService {
variables.forEach((variable) => {
prefilledVariables[variable.name] = variable.value;
});
// linha incluida por Francis:
if (enabled_typebot !== false ) {
let enabled_typebot = true;
const response = await this.createNewSession(instance, {
const response = await this.createNewSession(instance, {
url: url,
// linha incluida por Francis:
enabled_typebot: enabled_typebot,
typebot: typebot,
remoteJid: remoteJid,
expire: expire,
@ -141,6 +150,8 @@ export class TypebotService {
this.waMonitor.waInstances[instance.instanceName].sendDataWebhook(Events.TYPEBOT_START, {
remoteJid: remoteJid,
url: url,
// linha incluida por Francis:
enabled_typebot: enabled_typebot,
typebot: typebot,
prefilledVariables: prefilledVariables,
sessionId: `${response.sessionId}`,
@ -148,11 +159,50 @@ export class TypebotService {
} else {
throw new Error("Session ID not found in response");
}
} else {
const id = Math.floor(Math.random() * 10000000000).toString();
const reqData = {
sessionId: id,
startParams: {
typebot: data.typebot,
prefilledVariables: prefilledVariables,
},
};
const request = await axios.post(data.url + '/api/v1/sendMessage', reqData);
await this.sendWAMessage(
instance,
remoteJid,
request.data.messages,
request.data.input,
request.data.clientSideActions,
);
this.waMonitor.waInstances[instance.instanceName].sendDataWebhook(Events.TYPEBOT_START, {
remoteJid: remoteJid,
url: url,
typebot: typebot,
variables: variables,
sessionId: id,
});
}
// ate aqui
return {
typebot: {
...instance,
typebot: {
// linha incluida por Francis:
enabled_typebot: enabled_typebot,
url: url,
remoteJid: remoteJid,
typebot: typebot,
@ -231,7 +281,8 @@ export class TypebotService {
});
const typebotData = {
enabled: true,
// linha incluida por Francis:
enabled: data.enabled_typebot,
url: data.url,
typebot: data.typebot,
expire: data.expire,
@ -469,7 +520,6 @@ export class TypebotService {
});
const typebotData = {
enabled: true,
url: url,
typebot: typebot,
expire: expire,
@ -504,7 +554,6 @@ export class TypebotService {
sessions.splice(sessions.indexOf(session), 1);
const typebotData = {
enabled: true,
url: url,
typebot: typebot,
expire: expire,