freepbx

19
### Installing FreePBX ### Important Warning! FreePBX _will_ overwrite any exisiting asterisk configurations you may have. This project attempts to manage as much of asterisk as it can, and this means lots of automatically generated dialplans. Please visit the Documentation site (http://www.freepbx.org/support/documentation) for instructions, hints and tips. As a rule of thumb, any existing sip, iax, or extensions files can be copied to the same name with _custom.conf appended, and things will continue to work as before. ##################################################################### ########################## ##################################################################### ########################## ### THESE INSTRUCTIONS ARE OUTDATED!!!!! (JULY, 2008) ### ### PLEASE VISIT: ### ### http://www.freepbx.org/support/documentation/installation

Transcript of freepbx

Page 1: freepbx

###

Installing FreePBX

###

Important Warning!

FreePBX _will_ overwrite any exisiting asterisk configurations you may have. This project attempts

to manage as much of asterisk as it can, and this means lots of automatically generated dialplans.

Please visit the Documentation site (http://www.freepbx.org/support/documentation) for instructions,

hints and tips. As a rule of thumb, any existing sip, iax, or extensions files can be

copied to the same name with _custom.conf appended, and things will continue to work as before.

###############################################################################################

###############################################################################################

### THESE INSTRUCTIONS ARE OUTDATED!!!!! (JULY, 2008) ###

### PLEASE VISIT: ###

### http://www.freepbx.org/support/documentation/installation ###

### ###

### FOR UP TO DATE INSTRUCTIONS ###

###############################################################################################

###############################################################################################

###

Page 2: freepbx

FreePBX has several requirements, including the following packages (names may vary based on distro):

libxml2

libxml2-devel

libtiff

libtiff-devel

lame

httpd (or Apache2)

mysql (or mysql-client)

mysql-devel (or libmysqlclient10-dev)

mysql-server

php (or php4) NOTE!!! Only standard php is supported, hardened PHP projects are NOT supported!!

(on debian, also install libapache2-mod-php4)

php4-pear (if pear is not included with your php)

php-mysql

(on SUSE, also install php4-gettext and php4-session)

php-gd

openssl

openssl-devel (or libssl-dev)

kernel-devel (or linux-source)

perl

perl-CPAN

bison

Page 3: freepbx

ncurses-devel (or libncurses5-dev)

audiofile-devel (or libaudiofile-devel)

curl

sox

###

FreePBX requires the following changes to php and apache for uploading new MOH files:

(Note: Thise are reasonably distro specifc. Check http://www.aussievoip.com/wiki/FreePBX

for more documentation)

- vi +482 /etc/php.ini (or /etc/php4/apache2/php.ini)

upload_max_filesize=20M

- vi +14 /etc/httpd/conf.d/php.conf (if you have it)

LimitRequestBody 20000000

###

Download the latest FreePBX files:

- download the latest FreePBX tarball to /usr/src

- tar -zxvf freepbx<version>.tar.gz

###

Getting Asterisk and Zaptel from SVN or download the latest Asterisk and Zaptel source archives

Page 4: freepbx

(FreePBX uses the v2.0 branch)

- cd /usr/src

- svn checkout http://svn.digium.com/svn/asterisk/branches/1.2 asterisk-1.2

- svn checkout http://svn.digium.com/svn/zaptel/branches/1.2 zaptel-1.2

- svn checkout http://svn.digium.com/svn/libpri/branches/1.2 libpri-1.2

###

For TDM zap devices (FXO/FXS):

- cd /usr/src/zaptel

- make && make install

If you will be using a Digium telephony card that supports T1/E1 signaling do this step as well:

- cd /usr/src/libpri

- make && make install

###

Patching Asterisk with softfax/spandsp.

- Download the latest 0.2 spandsp files from http://www.soft-switch.org

- cd /usr/src/spandsp-xxx

- ./configure

- make && make install

Page 5: freepbx

The spandsp libraries are installed to /usr/local/lib. Therefore /usr/local/lib must be added to the LD_LIBRARY_PATH environment variable of the user that starts the asterisk process. To be safe, also add it to /etc/ld.so.conf and run ldconfig.

Copy the following files (from soft-switch.org) to /usr/src/asterisk/apps/ :

- cp app_rxfax.c /usr/src/asterisk/apps/

- cp app_txfax.c /usr/src/asterisk/apps/

- cp apps_makefile.patch /usr/src/asterisk/apps/

- cd /usr/src/asterisk/apps

- patch < apps_makefile.patch

###

Create a group and non-root user:

- groupadd asterisk

- useradd -c "asterisk PBX" -d /var/lib/asterisk -g asterisk asterisk

###

Building Asterisk and configuring it to run as a non-root user

- mkdir /var/run/asterisk

Page 6: freepbx

- cd /usr/src/asterisk

- make clean && make && make install

###

Get and build cdr_mysql module for asterisk

- cd /usr/src/asterisk-addons

- perl -p -i.bak -e 's/CFLAGS.*D_GNU_SOURCE/CFLAGS+=-D_GNU_SOURCE\nCFLAGS+=-DMYSQL_LOGUNIQUEID/' Makefile

- make clean && make && make install

###

Install asterisk-sounds

- cd /usr/src/asterisk-sounds

- make install

###

Setting up MySQL for CDR and FreePBX web interface

- /usr/bin/mysql_install_db

- /etc/init.d/mysqld start (or /etc/init.d/mysql start)

- mysqladmin -u root password 'db_root_pwd'

- mysqladmin create asteriskcdrdb -p

Page 7: freepbx

- mysql --user=root --password=db_root_pwd asteriskcdrdb < /usr/src/freepbx<version>/SQL/cdr_mysql_table.sql

- mysqladmin create asterisk -p

- mysql --user root -p asterisk < /usr/src/freepbx<version>/SQL/newinstall.sql

###

Grant access to these two databases you just created

**Note the default mysql username/password is asteriskuser/amp109.

**If you change either of these, you will be prompted for them while running ./install below

- mysql --user root -p

mysql> GRANT ALL PRIVILEGES ON asteriskcdrdb.* TO asteriskuser@localhost IDENTIFIED BY 'amp109';

Query OK, 0 rows affected (0.00 sec)

mysql> GRANT ALL PRIVILEGES ON asterisk.* TO asteriskuser@localhost IDENTIFIED BY 'amp109';

Query OK, 0 rows affected (0.00 sec)

mysql> quit

###

Page 8: freepbx

Run the "install" script to install all the FreePBX files:

- /usr/src/FreePBX/install_amp

###

Configure zaptel driver:

a. Edit /etc/zaptel.conf to reflect installed Digium telephony card(s).

Only the parameters/values relevant to a TDM400P with 4 FXO modules are included below:

fxsks=1-4

loadzone=us

defaultzone=us

Only the parameters/values relevant to a TE110P (T1 configuration) are included below:

span=1,1,0,esf,b8zs

bchan=1-23

dchan=24

loadzone=us

defaultzone=us

b. ztcfg -v

Page 9: freepbx

Zaptel Configuration

======================

1 channels configured.

If you get a warning about unable to open master device /dev/zap/ctl, that's ok. It's a result

of the zaptel module(s) not loaded yet.

Detailed information with regard to Asterisk's configuration files can be found here:

http://voip-info.org/wiki-Asterisk+config+files

###

Configure zapata module in asterisk config.

- edit /etc/asterisk/zapata.conf to reflect installed digium interfaces (see zapata.conf.template)

Only the parameters/values relevant to a TDM400P with 4 FXO modules are included below:

[channels]

language=en

#include zapata_additional.conf

context=from-pstn

signalling=fxs_ks

faxdetect=incoming

Page 10: freepbx

usecallerid=yes

callerid=asreceived

echocancel=yes

callprogress=no

busydetect=no

echocancelwhenbridged=no

echotraining=800

group=0

channel=1-4

Only the parameters/values relevant to a TE110P (T1 configuration) are included below:

[channels]

language=en

#include zapata_additional.conf

context=from-pstn

switchtype=national

pridialplan=national

signalling=pri_cpe

faxdetect=incoming

usecallerid=yes

echocancel=yes

callerid=asreceived

Page 11: freepbx

echocancelwhenbridged=no

echotraining=800

group=0

channel=1-23

Note: if your configuration is using zap channels as FXS endpoints, zapata.conf must

contain the following line in order to provision these endpoints in FreePBX's Extensions admin:

#include zapata_additional.conf

Detailed information with regard to Asterisk's configuration files can be found here:

http://voip-info.org/wiki-Asterisk+config+files

###

httpd (Apache) configuration

- Edit /etc/httpd/conf/httpd.conf (or /etc/apache2/apache2.conf) so that:

User asterisk

Group asterisk

###

Chown the PHP session.save_path directory:

- chown asterisk /var/lib/php/session

Page 12: freepbx

###

Amportal Control Script

FreePBX's amportal control script starts, stops or kills services in the FreePBX environment, and sets permissions on directories/files in the

FreePBX environment:

[root@pbx root]# amportal

----------AMP Control Script-----------

Usage: amportal start|stop|kill|chown

start: Starts Asterisk and Flash Operator Panel server

stop: Gracefully stops Asterisk and the FOP server

kill: Kills Asterisk and the FOP server

chown: Sets appropriate permissions on files

The amportal script is the recommended way to stop and start asterisk:

[root@pbx root]# /usr/sbin/amportal stop

[root@pbx root]# /usr/sbin/amportal start

###

Auto Start

Page 13: freepbx

The module/driver that you load at boot time depends upon whether you are using a

TDM400P or TE110P. The wcfxs module should be loaded for the former and the wcte11xp

module should be loaded for the latter.

The following scripts are for RedHat and derivatives that use an rc.local:

Edit /etc/rc.d/rc.local to include the following for the TDM400P:

#!/bin/sh

#

# This script will be executed *after* all the other init scripts.

# You can put your own initialization stuff in here if you don't

# want to do the full Sys V style init stuff.

touch /var/lock/subsys/local

echo Loading wcfxs

/sbin/modprobe wcfxs

/usr/sbin/amportal start

Edit /etc/rc.d/rc.local to include the following for the TE110P:

#!/bin/sh

#

# This script will be executed *after* all the other init scripts.

# You can put your own initialization stuff in here if you don't

Page 14: freepbx

# want to do the full Sys V style init stuff.

touch /var/lock/subsys/local

echo Loading wcte11xp

/sbin/modprobe wcte11xp

/usr/sbin/amportal start

For Debian and others (?), you'll have to add startup script(s) to /etc/init.d and link them

to the appropriate rc?.d runlevel.

Also ensure that mysql and apache are set to start at bootup. For RedHat-based systems do the following:

- chkconfig --level 3 httpd on

- chkconfig --level 3 mysqld on

###

Start everything (or reboot and it should start automagically):

- As root run:

service httpd restart

(or /etc/init.d/apache2 restart)

- As root run:

Page 15: freepbx

amportal start

- Point your browser to:

http://[ip address] (default login is admin/admin)

If you notice any errors or updates that are needed to this document, please e-mail:

[email protected]