FreeSWITCH package for pfSense 1.2.1 and 2.0 released. PBX or Proxy
-
Found a bug in the IVR (Auto Attendant). Its now fixed in version 0.5.7. If you will be using the IVR then please upgrade to 0.5.7 or higher.
-
mcrane, thx for your great work!
I need a litte help.
How to connect a softphone from WAN to a fs at my LAN. (soft – NAT -- WAN -- NAT -- LAN)
A B
I think, in A use stun, in B nated ports 5060-5090 and rtp port to my pfsense
In A, sjphone in htc touch pda
Rules in Wan / Lan permit traffic SIP / RTP / STUN
No firewall in OS Ubuntu1.- i create extension 1000, 1001 in context default
2.- i create extension 1003 in context public
3.- step 1 ok, calls ok, sofphones can register, but 1003 can't register to fs
I view freeswitch wiki, but i can't find the solution
there is not much information in the web
I modify the external profile, the parameters of sip_port,... no register
I create doublenat.xml... no register
At logs no info from attempts to connect.
Any idea?Un saludo from Spain!
-
Here's some thoughts.
I think they should all be context of default.
Make an extension 1003 in default and try it on the lan. When you know it works; apply the same configuration to your softphone.
Also; check the logs immediately after it registers (or fails to register) and see if there are any clues there.
I hope this helps; I am sure someone else will correct me if I am wrong.
-
For extensions that are on the LAN or the WAN 'User Context' should be set to 'default'. It is there as an option for advanced cases. If you have extensions that are coming in from the WAN the only additional thing you need to do this is to set an allow rule to open up the SIP TCP/UDP 5060 - 5090 and RTP UDP 16384 - 32768 ports for the WAN interface.
In the past week Sloan Miller started documentation of the FreeSWITCH package at:
http://doc.pfsense.org/index.php/FreeSWITCHOver the last three days I've helped add additional documentation to the wiki. Today I've added info on using Video calling between xlite extensions.
http://doc.pfsense.org/index.php/FreeSWITCH#Video -
I’ve built a TFTP pfSense package for pfSense 1.2.1 and higher. Still need to implement the DHCP TFTP option. I have some code to do that will likely carefully add it to the package.
-
I've got some code for the DHCP option I can PM you if you're interested
-
Sure pm it to me. I will compare it with have I have and use the best combination of both.
Best Regards!
-
If you need a TFTP Server for your phone configuration then install the pfSense TFTP package The following adds a TFTP DHCP option. The manual patch is designed for pfSense 1.2.1 full release.
Download the two attached files and then remove the .txt file extension. Then you should have one file named services.inc and the other named services_dhcp.php.
Go to the PFSense Menu then Diagnostics -> Command and upload both files. The files will upload to the /tmp/ directory.
Run the following shell commands to copy the files to the correct location.
cp /tmp/services.inc /etc/inc/services.inc
cp /tmp/services_dhcp.php /usr/local/www/services_dhcp.phpYou can now go to Services -> DHCP Server and set the TFTP Server address.
-
Great work on the tftp, I don't personally require it at this time, but for people who need it this will be a lifesaver.
Are there a list of steps I can follow to get an IVR working?
I added the IVR in the gui with extension 5002 but I'm not sure what else needs to be done. It doesn't answer or even recognize the extension 5002 I gave the new IVR.
I tried looking at the example IVR but isn't making any sense yet. Not looking for hand-holding, just a quick push in the direction of the correct place to start would be great.
-
[IVR Instructions]
When you create an IVR of 5002 you it will automatically add a dialplan entry on the 'Dialplan' tab for the extension. First you need to make some recordings for the IVR to use. You make the recordings on the 'Rec' tab by calling 732673 (record) it will ask for a pin number which is the 'admin pin' that is defined on the 'Settings' tab. After you make the recording edit it to give it an intuitive name. Then the recording will be available show up in the menu on the 'IVR' tab. The 'timeout' is how long to wait for key presses (DTMF) after the recording has finished playing. The 'Recording Action' drop down is the recording that will be played if the 'Javascript Condition' is true. If the condition is false then it will play the recording that is chosen in the Recording Anti-Action. For most systems the 'Javascript Condition' will a good start and work for most systems. It checks to see if the time is between 9-5pm, and that is Monday - Friday, and not one of the predefined holidays.
Now you need to add the auto attendant 'options.' Start with the 'Action' options first. If my recording said the following: "Thank you for calling press 1 for Sales 2 for Support 3 to hear the options again." Then the first 'Option Number' would be '1' set the drop down 'Type' to 'extension' then the destination could be the extension for the Sales person. If you have more than one Sales person you might want to setup a group and transfer the call to the group. For more information on the groups look at the wiki at: http://doc.pfsense.org/index.php/FreeSWITCH click on 'Save.' Now add the 2. The third option to hear the options again can be done with 'Type' extension and a 'Destination' of 5002. There is special option number 't' it is what will happen when the timeout is reached. The timeout could be redirected back to 5002 or to a specific extension, or omitted and the call will end. With the default condition the 'Action' options are 'Office Hours' and the Anti-Action options are the 'After Hours'. However you can replace the 'Javascript Condition' with the following: condition=true; in this case the Anti-Action options will never be used. This is useful for sub IVR menus such as a Directory. A directory would not make sense to use a time condition. You can access sub IVR by creating an option such as 4 and then creating an IVR at extension 5003. Point the option 4 to use a Type of 'extension' then '5003'.
Calls are directed to the 'Anti-Action' options when the condition does not match. The process for adding them is the same as the 'Action' options.
After setting up the IVR and you have called it at extension 5002 then you can direct inbound calls to it from the 'Public' tab.
Let me know if you have any further questions.
Best Regards,
Mark J Crane -
New updates to the FreeSWITCH package 0.5.8.3 and 0.5.8.4.
1. Exposed more paths on the pages that were not showing a file system path.
2. Fixed 'realm' on the gateways tab so that it saves the realm correctly.
3. Clarified wording on the extensions edit page to give more direct instructions on how to enable 3 digit extensions. -
Just for information:
Got the following notification message at the bottom when installing the FreeSWITCH package on top of PF1.2.1
"Warning: fclose(): supplied argument is not a valid stream resource in /usr/local/pkg/freeswitch.inc on line 1821"The package installed fine though…
Best regards
Dan Lundqvist
Stockholm, SwedenNote: tried to reinstall to latest version today 6 Jan -09 and also got the following: (but still not a failed install)
Warning: fclose(): supplied argument is not a valid stream resource in /usr/local/pkg/freeswitch.inc on line 1821
Warning: fsockopen(): unable to connect to xx.xx.165.51:8021 in /usr/local/pkg/freeswitch.inc on line 92
Warning: socket_set_blocking(): supplied argument is not a valid stream resource in /usr/local/pkg/freeswitch.inc on line 93 -
Having trouble getting past go on the IVR, not sure if I've messed up something else or if I'm missing a step.
I can create the recording and the IVR gui part seems to work as expected. I can't get my internal phone to reach anything but the pre-existing 5000 IVR which doesn't even show on the IVR menu.
This is what I see from the freeswitch console:
2009-01-04 17:34:01 [INFO] mod_dialplan_xml.c:233 dialplan_hunt() Processing Adrian Hensler->5002 in context default 2009-01-04 17:34:01 [ERR] ivr_DA5F6494-9E2F-4607-B0D4-73D3DBACA666.js:160 mod_spidermonkey() near SyntaxError: syntax error else { 2009-01-04 17:34:01 [NOTICE] switch_core_state_machine.c:168 switch_core_standard_on_execute() Hangup sofia/internal/2000@adrian.testing.com [CS_EXECUTE] [NORMAL_CLEARING] 2009-01-04 17:34:01 [NOTICE] switch_core_session.c:956 switch_core_session_thread() Session 3 (sofia/internal/2000@adrian.testing.com) Ended 2009-01-04 17:34:01 [NOTICE] switch_core_session.c:958 switch_core_session_thread() Close Channel sofia/internal/2000@adrian.testing.com [CS_HANGUP]
Line 160 in that javascript file is just an else line and seems to have nothing to do with the monkey recording?
-
The default IVR on extension 5000 is written in XML. The IVR in this package creates them in javascript. That is why you don't see extension 5000 in the package.
The console information shows that you are getting to the 5002 recording but for some reason it has an error. To know why you are getting an error you need to provide more information.
1. Did you provide action and anti-action options?
2. What numbers did you use for the the options?
3. What kind of actions did you give the options?
4. What version of the package are you running? -
Hi mcrane, thanks for the reply.
1. I had 4 actions but no anti actions. press 1 2 3 4. I was just trying to get it to answer first, I was going to worry about details later.
2. As above - options were just going to be 1,2,3 or 4.
3. Actions were just going to send to extensions 2000, 2001, 1718, 9656 (one extension points to my cell phone, the other to my parents - the numbers just match the alst 4 digits of their numbers and it's easy to remember)
4. The newest package at this time.I was confused with the xml versus javascript bit - your statement clears up a lot of that confusion. I was sort of looking for my created IVR to show up looking like the example one.
Unless something jumps out at you don't worry about it - I'll clear out my xml and try it again, I'm worried that it's something that I've messed up while tooling around the config files and I really don't want to waste your time looking for something I've done wrong.
Thanks!
-
Nice mention of the freeswitch pfSense package in the freeswitch 1.02 announcement:
http://freeswitch.org/node/157
There are two specific projects that are a part of the ecosystem to keep an eye on. The first is TCAPI - an ambitious project that aims to provide a comprehensive Web-based front-end to FreeSWITCH. The second is pfSense. The pfSense project has incorporated FreeSWITCH as an optional package. This allows pfSense users to set up an appliance that can be a PBX or soft-switch. pfSense and FreeSWITCH user Mark Crane has also added a simple GUI to the pfSense/FreeSWITCH package. Look for more interesting things to come from both of these projects.
-
I still can't get the ivr to work. I can send an incoming call to the pre-existing ivr at extension 5000 so I can validate the process works at least that much. I can also dial the 5000 IVR from my internal voip phone.
It doesn't seem to like the IVR I make at ext 1999 (for example). I tried deleting all three of my (not working) test IVR's and then adding a new one, just condition=true, using one of the existing recordings for testing; context=default. The action is 1 / extension / 2000 (if 1 is pressed go to extension 2000)
I have no anti-action.
I'm sure it is something I'm not understanding. It keeps returning javascript errors in the log:
2009-01-06 00:16:39 [ERR] ivr_D8DE6EA5-D512-39E8-C88A-52CF71C7245E.js:128 mod_spidermonkey() near SyntaxError: syntax error else {
-
I did some more testing on the IVR (auto attendant) and found a bug. When no anti-actions where defined the result would be a javascript error as you reported. I have fixed this problem in the FreeSWITCH package version 0.5.8.5.
Please backup your files using the 'backup' button on the 'Status' tab. Then remove the FreeSWITCH package and then reinstall it.
I have also fixed a minor bug for the anti-actions correctly on and edit for the dialplan and public tabs.
In addition to fixing what was mentioned above I have also added a new feature to the IVR (auto attendant). One of the special option numbers that could be done was 't' for timeout which was the length of time to wait for dtmf until proceeding with the timeout option. There is now a new special option 'n' which routes the call now and doesn't wait for dtmf. This new option is useful for office hours IVRs where during the day the call goes to a live person directly and at night the call is directed to an after hours IVR.
-
I can confirm that the changes to the IVR are now allowing me to create an IVR as expected!
Great work.
I did try to help by poking around the code, but I didn't find anything. Hopefully reporting the errors I was seeing helped.
-
Am I dense or is the wiki locked from creating accounts?
I just wanted to add that if you are enabling intercom and you've changed your extensions you want to edit the line in default.xml that reads:
<condition field="destination_number" expression="^8(10[01][0-9])$">^M</condition> ``` … to match what is required.