The VOIP service providers I have connected to my FusionPBX server give me better rates than that. They also only charge in 1 second increments. Therefore I saw an opportunity...
So my goal was to create a voicemail setup on my FusionPBX server that worked well as a replacement for my mobile phone providers' voicemail service.
1. it needs to take the message for me
2. I need to know if a person has left me a message or not
3. I need to be able to retrieve the messages
4. I need to be able to do all of this cheaply
1 and 3 are easy. 2 is more complicated. Ideally I'd send an SMS to my phone, like the mobile phone provider does, to tell me the number of messages there. Well I don't have SMS sending capability on my FusionPBX server at this point so there has to be another way. The way I decided is this - I get a missed call message whenever someone calls but is diverted to voicemail - so after getting one of those (or after my phone has been switched off or not in a mobile area) I'll phone a number on my FusionPBX server and if it rejects my call then I'll know I have voicemails to listen to, if it rings indefinitely then there are no voicemails to listen to (this was my initial plan anyway, but as you will see below I have now decided to use early media to indicate whether there are messages present or not). This might not make sense yet but go with me on it.
To address 4. I'm going to divert the calls to my FusionPBX voicemail box. Then, to retrieve the calls I will phone FusionPBX and it will reject my call. I'll hangup and then it will call me back. That way I'll listen to my voicemails using the rates that my VOIP provider gives rather than the rates my mobile phone company gives.
Testing shows that my mobile phone company delivers diverted calls to my FusionPBX VOIP number as if the caller had been calling that number in the first place. In other words, the caller id is the original caller's caller ID rather than anything different. There is no other data provided with the call apart from the max-forwards being 1 lower than a usual incoming call, so although we can tell that this call has been forwarded we cannot determine who it was forwarded for. So this means we need to dedicate a landing number to each mobile we use this solution with. Fortunately I have a few spare incoming lines at the moment so we can do this.
So how do we go about doing this?
We're going to use vm_boxcount to tell us if there are any messages waiting (to know how to handle an incoming call from the mobile phone) - http://wiki.freeswitch.org/wiki/Mod_voicemail#vm_boxcount
We're going to use the voicemail application to check our voicemail messages - http://wiki.freeswitch.org/wiki/Mod_voicemail#Check_Voice_Mail
And we're going to use the api_hangup_hook - http://wiki.freeswitch.org/wiki/Variable_api_hangup_hook - to do an originate - http://wiki.freeswitch.org/wiki/Mod_commands#originate - from the dial plan so that we can make a call to the mobile and connect it to our dialplan that plays back the voicemail messages.
We're going to use early media to provide message counts (alternatively if your VOIP provider doesn't support the use of early media (apparently it is not mandatory) we could use ring_ready, followed by sleep 15000 to cause the phone to ring for 15 seconds before answering if there are no messages - that way it doesn't waste money as the call hasn't been answered). To use early media we use playback before answering the call, this automatically puts it in early media mode, then we hangup at the end rather than answering the call. (note that pre_answer is not necessary as playback automatically puts the call into early media when it happens)
First we identify the incoming number that will be allocated to mobile phone voicemail. You will also have to setup an extension on FusionPBX that will be used for your mobile phone voicemail. Then we define an incoming route for this number that will handle the call if there are NO voicemails waiting:
You will see that we check that the call is for this inbound number, then we check if it is from your mobile, then we check if there are voicemails waiting for you in your voicemail box. Then if there are no messages we use early media to inform the caller that there are no messages for them and then we play a ringing sound and hang up. You don't need to play the ringing sound - I just wanted to end that way. Because we use early media the caller isn't charged for the call as it works in the same way as the messages from your service provider that say the number you called isn't connected.
You need to replace:
- your_destination_number_goes_here
- your_mobile_number_goes_here
- vm_extension
- your_domain
with appropriate values for your implementation.
Next we define an incoming route for this number that will handle the call if there ARE voicemails waiting:
This route differs from the last one in that it sets the api_hangup_hook to originate a new call back to the mobile after this call hangs up. Again, using early media it indicates this time that there are voicemails available. Note that if the call is not from the mobile phone we send it to your voicemail box - therefore when you divert your mobile phone you divert it to the same number you use to check your voicemails with.
You need to replace:
- your_destination_number_goes_here
- your_mobile_number_goes_here
- vm_extension
with appropriate values for your implementation.
If you want to use a different extension to handle the call back instructions then replace 888888 with that, otherwise use 888888 for the next dialplan entry.
Next we define a dialplan entry for the callback feature:
Tag | Type | Data | Order | |
---|---|---|---|---|
condition | destination_number | ^(888888)$ | 1 | |
action | sleep | 500 | 3 | |
action | answer | 3 | ||
action | set | voicemail_authorized=true | 6 | |
action | voicemail | check auth default $${domain} vm_extension | 7 |
You need to replace:
- vm_extension
with an appropriate value for your implementation.
With that you are all done. Now divert your mobile phone on busy, no answer, and off/no coverage to the number you setup on your fusionpbx server. What happens now is that incoming calls on your mobile that are not answered go to FusionPBX and are answered there by your voicemail. If you see a missed call indicator on your phone you call the number you setup on your fusionpbx server and it will tell you either "sorry you have no more messages" or "you have messages" and it will then hangup (or you can hangup - either way is good). If you have messages then after you hang up it will call you straight back and you can answer the call and will hear your voicemails.
Hopefully you find this as useful as I do to keep costs down from your mobile provider.
No comments:
Post a Comment