Hi Salvatore,
Be careful with SIP softphones. I've seen them do weird stuff with AMI
commands (i.e.: Commands received are messed up/cut-out in parts),
especially when it comes to DTMFs. I've found SFLphone (not Ring) to
work the best, but even it had issues. In the end I opted for Digium
cards (analog and PRI work best) and hardware SIP devices.
Sorry, I don't really have any experience using queues and even less
with ARI (like I said, I went pure AMI from a C-application and I've
never tried controlling/handling a call via a web interface). I learnt
a few queue dialplan concepts years ago, but don't recall the details.
In all of this you didn't mention how you were trying to answer the
calls. Have you used the AddQueueMember application (with no members
defined in queues.conf, as specified within the "Return codes" section
of http://www.voip-info.org/wiki/view/Asterisk+cmd+Queue) to add someone
with whom to receive/answer calls? If not, that might be something to
read up on..
To answer your question, I imagine either you need to use Asterisk
queue's or write your own queue. I mean, there has to be some way of
tracking all the calls and allowing you to select one to deal with at a
time.
Here's a tutorial on queues which I came across. Maybe you could try
following along with it and see if it helps you progress with queues:
http://www.orderlyq.com/asterisk-queues-tutorial/
Hope this helps,
Daniel
On 11/23/2016 03:24 AM, Salvatore Franco wrote:
Hi Daniel,
the Queue works well if I use a SIP Client (Zoiper) but if I try to
answer using AMI i receive that error :(
ARI command ANSWER only works if I use it on a single channel, the
queue is a strange application that cannot be in Stasis directly.
Is writing my own queue the only way to handle calls via http in queue?
Thanks
Regards
*Salvatore Franco*
------------------------------------------------------------------------
Da: [email protected]
A: "Asterisk Developers Mailing List" [email protected]
Cc:
Data: Tue, 22 Nov 2016 12:33:38 -0500
Oggetto: Re: [asterisk-dev] AGI:async
Hi,
Unfortunately, I wish I had a simple queue to share but my
implementation is quite complex due to how I control the call on a
per-operation basis. If you choose this route then perhaps you can
use store your channel/queue name(s) within simple storage elements
such as a stack, array, or even a hashtable (although the last may not
be ideal for retrieving calls in order) and then use AMI to control
the calls from there. Sorry I can't be more helpful in providing you
an example.
I imagine Asterisk queue's work though, so perhaps it might be worth
your while to pursue that approach a bit more (unfortunately I've
never tried them, so I can't tell you how it's done!). That being
said, perhaps getting Asterisk Queue's going will require a more
step-by-step approach to figure out why it's not working for you.
Here are my suggestions:
Have you tried the exact dialplans in the examples within
http://www.voip-info.org/wiki/view/Asterisk+cmd+Queue ? i.e.: Have
you been able to get Asterisk queue's working without AMI? If not,
that might be where to start and then add AMI in afterward..
Another suggestion I have is to use the QueueAdd AMI command, rather
then calling Queue within your dialplan. If you have success on doing
something like an Answer/Playback via AMI, then you will probably have
no issues with the QueueAdd AMI command. Please try that and maybe
you'll have more luck. Here's the API reference:
http://www.voip-info.org/wiki/view/Asterisk+Manager+API+Action+QueueAdd
Hope this helps & good luck,
Daniel
On 11/22/2016 10:35 AM, Salvatore Franco wrote:
Hi,
Thanks for your suggestions.
The comma was an error in my email, not in my dialplan.
Even if i use Answer command before Queue i received the same error
back, so i think the best way is to have my own queue.
Have you got any example of how to implement a simple queue that use
the "fewestcalls" strategy?
Best Regards
Salvatore
------------------------------------------------------------------------
Da: [email protected]
A: "Asterisk Developers Mailing List" [email protected]
Cc:
Data: Tue, 22 Nov 2016 10:04:58 -0500
Oggetto: Re: [asterisk-dev] AGI:async
Hi Salvatore,
I don't have any experience with the "Queue" command, as I basically
pass the call directly to agi:async and control the call every step
of the way from my C program (where I've implemented my own
queue/call tracking).
However, here are my suggestions:
1) Upon taking a quick look at
http://www.voip-info.org/wiki/view/Asterisk+cmd+Queue, I think your
"failed to add agi command to channel.." error may be since the call
is not answered yet. You'll notice on that web page that the dial
plan calls "Answer" before Queue in example 1, and Playback (which
itself internally answers the call to be able to then play the
announcement) before Queue in example 3 (I'm skipping example 2, as
it's a link to a German site and not directly on the page). Please
try one of those commands, before calling your Queue command, and I
think you'll get better results.
2) You are correct that AGI(agi:async) stops execution of the
dialplan. In your attempt to execute AGI(agi:async) before Queue,
that's exactly what happened. The call entered agi:async mode and
from that point on you are supposed to issue commands to control the
call from your AGI program.
That's probably the reason you don't hear ringing on the phone, as
(in your AGI call on priority 1 example) your inbound call never
reached the "Queue" dialplan priority.
3) This is a minor detail, but I'm not sure your syntax is correct.
Try removing the comma before the "n", so that you have the following
in your dial plan: "same => n,AGI(agi:async)"
Hope this helps,
Daniel
On 11/22/2016 05:03 AM, Salvatore Franco wrote:
Hi,
I'm trying to answer a call that is in Queue through AMI, launching
AGI command ANSWER.
I read about putting AGI(agi:async) in extensions.conf dialplan but
if i set in this order:
exten=> 1000,1,Queue(queuename)
same=> ,n,AGI(agi:async)
and try to answer using AMI the response is : failed to add agi
command to channel XXX queue.
Else if i set the dial plan in this order:
exten=>1000,1,AGI(agi:async)
same=> ,n,Queue(queuename)
the phone doesn't ring and the command execute successful, but
nothing happens. Isn't agi:async "really" async but stops execution
of the dialplan?
Any suggestions?
Thanks
Best Regards
*Salvatore Franco*
--
Daniel McFarlane
Szeto Technologies Inc.
885 Ellingham Ave
Pointe Claire, Québec
Canada, H9R 5E8
tel: (514) 630-7878
fax: (514) 630-6394
http://www.szeto.ca
--
Daniel McFarlane
Szeto Technologies Inc.
885 Ellingham Ave
Pointe Claire, Québec
Canada, H9R 5E8
tel: (514) 630-7878
fax: (514) 630-6394
http://www.szeto.ca
--
_____________________________________________________________________
-- Bandwidth and Colocation Provided by http://www.api-digital.com --
asterisk-dev mailing list
To UNSUBSCRIBE or update options visit:
http://lists.digium.com/mailman/listinfo/asterisk-dev