Flujos de Campañas


Salientes

Desde Agente con hardphone

${OUTGUID}: GUID de la llamada que se genera. ${OUTAGENT}: Nombre del agente que realiza la llamada. ${OUTQUEUE}: Nombre de la campaña por la que sale la llamada. ${OUTDID}: DID número callerid para usar al salir, corresponde al de la campaña. ${OUDIDALED}: Número marcado.

Con teléfono Webrtc

La llamada se realiza directamente. El nombre de la campaña, GUID y DID se pueden obtener desde un SIP Header, el resto de las variables son obtenidas directamente desde donde corresponden.

${SIP_HEADER(OUTGUID)}: GUID de la llamada que se genera. ${CDR(accountcode)}: Nombre del agente que realiza la llamada. ${SIP_HEADER(OUTQUEUE)}: Nombre de la campaña. ${SIP_HEADER(OUTDID)}: DID número callerid para usar al salir corresponde al de la campaña. ${EXTEN}: Número marcado.


Ejemplo completo de ambos casos

Podemos ver las variables que se ejecutan y como se toman en cuenta las que llegan, dependiendo del modo en el que se ejecute el agente.

Es importante usar __Ani para poder buscar en Logs.

El QueueUpdate en el Hangup es fundamenta por temas de estadísticas de campañas salientes.

En Hangup también agregar Set(CDR(userfield)=${userfield}) para marcar la grabación. 

Es posible ejecutar en el Dial un Macro para enviar datos al cliente una vez la llamada es atendida.

exten=> _9XXXXXXX.,1,Set(VOLUME(TX)=2) exten=> _9XXXXXXX.,2,Set(VOLUME(RX)=2) exten=> _9XXXXXXX.,3,GotoIf($[${EXTEN:0:3}= 900]?62:4) exten=> _9XXXXXXX.,4,GotoIf($["${OUTQUEUE}"= ""]?47:5) exten=> _9XXXXXXX.,5,Set(__OUTQUEUE=${OUTQUEUE}) exten=> _9XXXXXXX.,6,Set(__DIALED=${OUTDIALED}) exten=> _9XXXXXXX.,7,Set(__AGENT=${OUTAGENT}) exten=> _9XXXXXXX.,8,Set(CALLERID(num)=${OUTDID}) exten=> _9XXXXXXX.,9,Set(CALLERID(name-pres)=allowed_passed_screen) exten=> _9XXXXXXX.,10,Set(HASH(Result)=${ODBC_Data(select did\,name\,dialstring from queues where name in (select queue_name from queue_members where membername = '${CHANNEL(accountcode)}') and direction = 'Outbound' and name ='${OUTQUEUE}')}) exten=> _9XXXXXXX.,11,Set(CALLERID(name)=${OUTQUEUE}) exten=> _9XXXXXXX.,12,Set(event=${ODBC_Data(select event from queue_log where agent = '${AGENT}' and queuename= '${OUTQUEUE}' and event in ('PAUSE', 'UNPAUSE') ORDER BY id DESC LIMIT 1)}) exten=> _9XXXXXXX.,13,GotoIf($["${event}" = "PAUSE"]?45:14) exten=> _9XXXXXXX.,14,GotoIf($["${OUTGUID}" = ""]?40:15) exten=> _9XXXXXXX.,15,Set(__guid=${OUTGUID}) exten=> _9XXXXXXX.,16,Set(CDR(guid)=${guid}) exten=> _9XXXXXXX.,17,Set(CDR(type)=record) exten=> _9XXXXXXX.,18,MixMonitor(${guid}.gsm,b,) exten=> _9XXXXXXX.,19,Set(CDR(campaign)=${OUTQUEUE}) exten=> _9XXXXXXX.,20,Set(CHANNEL(accountcode)=${AGENT}) exten=> _9XXXXXXX.,21,Set(__idLlamada=${guid}) exten=> _9XXXXXXX.,22,Set(__REALDIALED=${EXTEN:1}) exten=> _9XXXXXXX.,23,Set(existeNum=${ODBC_Data(SELECT COUNT(*) FROM black_list WHERE (campaign like '${OUTQUEUE}%' || campaign ='*') AND phone ='${EXTEN}')}) exten=> _9XXXXXXX.,24,GotoIf($["${existeNum}"!= "0"]?37:25) exten=> _9XXXXXXX.,25,Dial(${HASH(Result,dialstring)}/${EXTEN:1},180,TKkc,) exten=> _9XXXXXXX.,26,Set(CDR(causecode)=${HANGUPCAUSE}) exten=> _9XXXXXXX.,27,NoOp(${DIALSTATUS} - ${HANGUPCAUSE}) exten=> _9XXXXXXX.,28,GotoIf($["${DIALSTATUS}" = "BUSY"]?35:29) exten=> _9XXXXXXX.,29,GotoIf($["${DIALSTATUS}" = "CONGESTION"]?35:30) exten=> _9XXXXXXX.,30,GotoIf($["${DIALSTATUS}" = "CHANUNAVAIL"]?33:31) exten=> _9XXXXXXX.,31,GotoIf($["${DIALSTATUS}" = "CANCEL"]?33:32) exten=> _9XXXXXXX.,32,Hangup() exten=> _9XXXXXXX.,33,Playback(outofservice,) exten=> _9XXXXXXX.,34,Goto(agentes,${EXTEN},32) exten=> _9XXXXXXX.,35,Playback(busy,) exten=> _9XXXXXXX.,36,Goto(agentes,${EXTEN},32) exten=> _9XXXXXXX.,37,Set(dummy=${ODBC_Repo(INSERT INTO black_list_history(calldate\,src\,dst) VALUES (now()\,'${AGENT}'\,'${EXTEN}'))}) exten=> _9XXXXXXX.,38,Playback(DNCRaudio,) exten=> _9XXXXXXX.,39,Goto(agentes,${EXTEN},32) exten=> _9XXXXXXX.,40,GotoIf($["${SIP_HEADER(OUTGUID)}" = ""]?43:41) exten=> _9XXXXXXX.,41,Set(__guid=${SIP_HEADER(OUTGUID)}) exten=> _9XXXXXXX.,42,Goto(agentes,${EXTEN},16) exten=> _9XXXXXXX.,43,GUID(__guid) exten=> _9XXXXXXX.,44,Goto(agentes,${EXTEN},16) exten=> _9XXXXXXX.,45,Playback(pausaerror,) exten=> _9XXXXXXX.,46,Hangup() exten=> _9XXXXXXX.,47,GotoIf($[$["${SIP_HEADER(OUTQUEUE)}"= ""]|$["${SIP_HEADER(OUTQUEUE)}"= "null"]]?53:48) exten=> _9XXXXXXX.,48,Set(__AGENT=${CHANNEL(accountcode)}) exten=> _9XXXXXXX.,49,Set(__DIALED=${EXTEN}) exten=> _9XXXXXXX.,50,Set(__OUTQUEUE=${SIP_HEADER(OUTQUEUE)}) exten=> _9XXXXXXX.,51,Set(CALLERID(num)=${SIP_HEADER(OUTDID)}) exten=> _9XXXXXXX.,52,Goto(agentes,${EXTEN},9) exten=> _9XXXXXXX.,53,Set(HASH(Result)=${ODBC_Data(select did\,name\,dialstring from queues where name in (select queue_name from queue_members where membername = '${CHANNEL(accountcode)}') and direction = 'Outbound')}) exten=> _9XXXXXXX.,54,GotoIf($["${HASH(Result,name)}"= ""]?60:55) exten=> _9XXXXXXX.,55,Set(__AGENT=${CHANNEL(accountcode)}) exten=> _9XXXXXXX.,56,Set(__DIALED=${EXTEN}) exten=> _9XXXXXXX.,57,Set(__OUTQUEUE=${HASH(Result,name)}) exten=> _9XXXXXXX.,58,Set(CALLERID(num)=${HASH(Result,did)}) exten=> _9XXXXXXX.,59,Goto(agentes,${EXTEN},9) exten=> _9XXXXXXX.,60,Background(llamadasincola,,,) exten=> _9XXXXXXX.,61,Hangup() exten=> _9XXXXXXX.,62,Set(inter-var=${DB(${CALLERID(num)}/INTER)}) exten=> _9XXXXXXX.,63,GotoIf($["${inter-var}" = "TRUE"]?4:64) exten=> _9XXXXXXX.,64,Playback(disabled-INTER,) exten=> _9XXXXXXX.,65,Hangup() exten=> h,1,Set(HASH(rates)=${ODBC_Data(select rates.gateway\, rates.rate\, rates.cost\, rates.note FROM rates LEFT JOIN provider ON provider.name=rates.gateway WHERE provider.status = 'true' AND substring( '${EXTEN}'\, 1\, length( prefix_regexp ) ) REGEXP prefix_regexp ORDER BY length(prefix_regexp) DESC\,rates.rate ASC)}) exten=> h,2,Set(talkedminutes=${MATH(${CDR(billsec)} / 60,f)}) exten=> h,3,Set(talkedminutes=$[CEIL(${talkedminutes})]) exten=> h,4,Set(chargedbalance=${MATH(${talkedminutes} * ${HASH(rates,rate)},f)}) exten=> h,5,Set(realbalance=${MATH(${talkedminutes} * ${HASH(rates,cost)},f)}) exten=> h,6,Set(CDR(charged_balance)=${chargedbalance}) exten=> h,7,Set(CDR(real_balance)=${realbalance}) exten=> h,8,Set(CDR(note)=${HASH(rates,note)}) exten=> h,9,Set(CDR(carrier)=${HASH(rates,gateway)}) exten=> h,10,Set(CDR(userfield)=${userfield}) exten=> h,11,Set(CDR(direction)=outgoing) exten=> h,12,Set(CDR(causecode)=${HANGUPCAUSE}) exten=> h,13,QueueUpdate(${OUTQUEUE},${UNIQUEID},${AGENT},${DIALSTATUS},${ANSWEREDTIME},${DIALEDTIME}|${DIALED}|${idLlamada})

 

En la creación de campañas se define el Form o la URL que hay que desplegar al hacer clic en el botón de formularios de esta.

Opción 1:  uContact Form: Solo nombre del form, Nombre del form y | true (para desplegar la cruz del form y poder cerrarlo).

Ejemplos:  Códigos | true

                  Códigos

Opcion 2: uContact URL:  URL bien formada y | nombre a mostrar en Tab o URL bien formada | nombre del tab  | true (esto para desplegar la cruz del form y poder cerrarlo)

Ejemplos:   http://www.observador.com.uy | Observa

                   http://www.observador.com.uy | Observa | true


Entrantes

Podemos ver el workflow de ejecución.

Es fundamental utilizar __Ani para poder buscar en Logs.

Ya no empleamos más MACRO para pasar datos de CTI, sino SIP HEADER. Esta se persiste durante toda la llamada, si es una transferencia también debería pasar los datos, también es posible eliminar el HEADER.

Ejemplo:

 

Si se quiere autoanswer para hardphones, setear el SIP Header: P-Auto-Answer: normal.

 

En el SIPAddHeader setear form o URL que hay que desplegar al entrar una llamada.

Opción 1:  uContact Form:  Solo nombre del Form, Nombre del Form y | true (para desplegar la cruz del form y poder cerrarlo).

Ejemplos:  Códigos 

                  Códigos | true

 



Opcion 2: uContact URL: URL bien formada y | nombre a mostrar en tab o URL bien formada | nombre del tab  | true (para desplegar la cruz del form y poder cerrarlo).

Ejemplos:   http://www.observador.com.uy | Observa

                  http://www.observador.com.uy | Observa | true

 


Avanzadas

Ir primero a un agente

  •  Setear en los agentes diferentes números de penalización (número de teléfono del agente).

  •  Setear en la campaña la estrategia wrandom.

  •  En el workflow setear las variables con el mismo número (el de la penalización del agente por el que se quiere comenzar), y en el workflow en la actividad de campaña setear la regla que se quiera o sea la que está entre [] en el archivo queuerules.conf.

     

  • En /etc/asterisk/queuerules.conf agregar una regla que después de X tiempo si no lo pudo contactar comience a saltar por los agentes disponibles.

 

Significa: 

 

Ejemplo