Asterisk: Difference between revisions

From Wildsong
Jump to navigationJump to search
Brian Wilson (talk | contribs)
Brian Wilson (talk | contribs)
 
(36 intermediate revisions by the same user not shown)
Line 1: Line 1:
See also [[Otter]]
See also the VOIP category and [[Asterisk debugging]].


== Overview ==
== Overview ==


[[Bellman]] is a Via C7 Mini-ITX system running Ubuntu Linux that acts as my firewall / router.
2022-May-13 Asterisk is not just for phones, it's also for ham radio. It's called AllStarLink, which I am using for the [[Repeater linking]] project.  


Aug 08 I just upgraded from using [[Otter]], a Toshiba Magnia SG20 server
2019-Nov-01 I ran a Vastra (Asterisk + Twilio) phone system at home for a few years but I am tired of it now, so I am shutting it down and forwarding the number to my cellphone.


== Goal: Reduce the bottom line ==
I merged together Twilio and Asterisk for a home phone system. I spent 1000 hours developing a commercial grade small buiness Asterisk based system but my business partner and I got cold feet and we quit.


Replace a $30 / month Packet8 phone with a more flexible system that allows me to use cheaper services.
Back story:  I used Packet8 ($30/month) then Les.net (gone) then Grandcentral + GISMO5 (free!) then Google ate Grandcentral AND GISMO5 and gutted them. Then I used only mobile phones for years.


It is working now!
Right now for Asterisk, I am using MySQL not PostgreSQL, it's simpler and gets the job done for phone systems.
I have to update the sections below from PG to MySQL.


We use at most 2 to 3 hours of outbound call services a month. The standard Packet8 service for $30 included unlimited outbound calling which was a waste for us. I reduced this to $20/month by changing to a 400 minute / month plan. ($15 + taxes) but that's still more than we needed.
=== Incoming calls ===
 
People can dial in to a Google Voice number and it will hit the PBX and 2 mobiles. I am moving away from that.
 
They can also dial in to a Twilio number and it will hit the PBX, which then dials out to my mobile.  
I want to set up some TWIML to handle the follow me thing in Twilio instead of having it come through the Asterisk PBX.
I'd kind of like the PBX to go away and just use Twilio. [[Replacing Asterisk with Twilio]]


I changed over to use a Grandcentral number for incoming calls (free), which forwards to a Gizmo project number (free) and a Les.net per-minute service for outbound calls. That translates to a whopping $2.70 per month if we talk for 3 hours outbound.
=== Outgoing calls ===


We now are saving at least $17.30 per month. This makes the exorbitant $50 Comcast Broadband bill more bearable.
Again, using Twilio for outgoing calls too.


=== Incoming calls ===
== Business Asterisk system ==
 
=== BLF tip ===
 
If you are working with BLF (the "Busy Lamp Field" lights on phone) (for example on the sidecar for the GXV3240),
and you make changes in Asterisk, the hints and the phone can get out of sync. Lights seem to freeze up or not change.
Don't tear your hair out! Reboot the phone first and see if things start working again.
 
=== Grandstream GXV3240 phone ===
 
For business systems, I am working with these phones right now, along with the optional button modules (which I call "sidecars" for some reason.)
 
I have a separate page for them, see [[Grandstream GXV3240]].
 
=== Grandstream GXW4104 ===
 
Used to connect up to four POTS lines.
 
Buggy firmware... bad documentation... avoid.
 
check and update firmware
set hostname
set up syslog
adjust rings before pickup
set time zone and ntp
 
=== Setting up PostgreSQL ===
 
When building Asterisk from source, you must have the postgres dev package installed before you do ./configure.
Asterisk build is not good about telling you what is available when ./configure completes. You can do 'make menuselect'
and see what will be available.
 
CEL = Channel Event Log, more details than CDR (CDR = Call Detail Record)
 
In cel.conf
enable=yes
 
In cel_pgsql.conf, at the bottom
hostname=localhost
port=5432
dbname=asterisk
password=yoursecretpasswordhere
user=asterisk
table=cel          ; SQL table where CEL's will be inserted                                                       
appname=asterisk  ; Postgres application_name support (optional). Whitespace not allowed.                           


[http://grandcentral.com/ Grand Central] provides me with a free local phone number (DID) for incoming calls. They route the calls to a [http://gizmoproject.com Gizmo Project] SIP account.
If you wish, follow suit and fix up res_pgsql.conf and cdr_pgsql.conf too.


I used to have a [Freeworld Dialup] account but no one ever used it so when they went to a subscription service I let it expire.
Create the database, user and appropriate permission
su - postgres
createdb asterisk
echo "CREATE USER asterisk WITH PASSWORD 'yoursecretpasswordhere';" | psql
echo "GRANT ALL ON DATABASE asterisk TO asterisk;" | psql


I have a Stanaphone number in New York but don't have forwarding on it right now.
I got this code from voipinfo.org
I had an IPKall number in Seattle but it has expired.
http://www.voip-info.org/wiki/view/Asterisk+cdr+odbc


=== Outgoing calls ===
CREATE TABLE cel (
  id serial,
  eventtime timestamp with time zone NOT NULL DEFAULT now(),
  eventtype character varying(80) NOT NULL DEFAULT ''::character varying,
  userdeftype character varying(80) NOT NULL DEFAULT ''::character varying,
  cid_name character varying(80) NOT NULL DEFAULT ''::character varying,
  cid_num character varying(80) NOT NULL DEFAULT ''::character varying,
  cid_ani character varying(80) NOT NULL DEFAULT ''::character varying,
  cid_rdnis character varying(80) NOT NULL DEFAULT ''::character varying,
  cid_dnid character varying(80) NOT NULL DEFAULT ''::character varying,
  exten character varying(80) NOT NULL DEFAULT ''::character varying,
  context character varying(80) NOT NULL DEFAULT ''::character varying,
  channame character varying(80) NOT NULL DEFAULT ''::character varying,
  appname character varying(80) NOT NULL DEFAULT ''::character varying,
  appdata character varying(80) NOT NULL DEFAULT ''::character varying,
  accountcode character varying(20) NOT NULL DEFAULT ''::character varying,
  peeraccount character varying(80) NOT NULL DEFAULT ''::character varying,
  uniqueid character varying(32) NOT NULL DEFAULT ''::character varying,
  linkedid character varying(80) NOT NULL DEFAULT ''::character varying,
  amaflags integer NOT NULL DEFAULT 0,
  userfield character varying(255) NOT NULL DEFAULT ''::character varying,
  peer character varying(80) NOT NULL DEFAULT ''::character varying,
  CONSTRAINT cel_pkey PRIMARY KEY (id)
);


Updated 24-Nov-2008
See also source code contrib/scripts/realtime/postgresql/


For several months now I have been using [http://les.net Les.net] for outgoing calls, but we have been experiencing audio drop outs in the outbound calls; the person at the other end hears dead air for 1 or 2 seconds at a time. This is very irritating, so I am going to try using the [http://www.gizmoproject.com Gizmo Project] CallOut service. They've been providing me a free incoming number, I figured why not try their outbound service as well.


When I signed on with Les.Net I put $25 in credit. I use their pay-by-minute with no monthly fee. I still have $21 left after several months. Rates are about $.015 / minute.
for tbl in `psql -qAt -c "select tablename from pg_tables where schemaname = 'public';" asterisk` ; do  psql -c "alter table $tbl owner to asterisk" asterisk ; done


Another good provider is voipjet.com. I use them for my employer's business phone system.
Sequences:


=== Hardware available ===
for tbl in `psql -qAt -c "select sequence_name from information_schema.sequences where sequence_schema = 'public';" asterisk` ; do  psql -c "alter table $tbl owner to asterisk" asterisk ; done


1 Grandstream Budgetone phone
Views:


1 Sipura SPA2000 ATA (Can't find it. Geez my life is full of boxes of gadgets!)
for tbl in `psql -qAt -c "select table_name from information_schema.views where table_schema = 'public';" asterisk` ; do  psql -c "alter table $tbl owner to asterisk" asterisk ; done


1 Desktop running Ubuntu on the LAN with Ekiga softphone installed
== Auto-attendant set up ==


1 Laptop running Windows XP on WiFi
== Intercom style paging ==


1 Packet8 DTA-310, reflashed to be a Leadtek BVA8051. See http://www.voip-info.org/wiki-Packet8+DTA310+and+Asterisk and http://www.stromcarlson.com/projects/dta-310/
# Set up an extension eg "499" that will call Page() with a list of phones, eg. Page(SIP/100&SIP/101&SIP/102,s,120)
# Tell the Grandstream that it's okay to be paged, Account->Account 1->Call Settings->Auto Answer=Enable Intercom/Paging
# Set up an MPK button to page. Advanced Settings->MPK EXT1 Settings->Key mode=Call Intercom,User=499


=== Softphone ===
== Hardware ==


Using Ekiga on the same system that has Asterisk installed on it meant I had to run gconf-editor (apps->Ekiga->Protocols) to change the SIP listen port from 5060 to 5061 since Asterisk was already using 5060.
Not using at the moment: 1 Packet8 DTA-310, reflashed to be a Leadtek BVA8051. See http://www.voip-info.org/wiki-Packet8+DTA310+and+Asterisk and http://www.stromcarlson.com/projects/dta-310/


Ekiga is the softphone installed by default with Ubuntu 8.10 Hardy Heron. I've seen softphones I like more but it works for testing and I use hard phones most of the time.
I need to plug in my rotary dial and push button phones to this thing.


== Implementation ==
== Implementation ==


I am using the generic asterisk package that is pulled from the Ubuntu repository. To this I make the following configuration changes.
=== Customizations ===


As much as possible I keep general changes out of main config files by using include files. This makes updates much simpler. In sip.conf add this line: #include sip-wildsong.conf and in extensions.conf add this: #include extensions-wildsong.conf The voicemail.conf file warns agains this approach so I edit it directly.
As much as possible I keep general changes out of main config files by using include files. This makes updates much simpler. In sip.conf add this line: #include sip-wildsong.conf and in extensions.conf add this: #include extensions-wildsong.conf The voicemail.conf file warns agains this approach so I edit it directly.
Line 68: Line 147:
That's about it.
That's about it.


=== Les.net connection ===
[[Category: Telephones]][[Category:Network]]
 
I used the well-written instructions with the les.net account to set up iax.conf
and extensions.conf files.
 
Update 24-Nov-2008: I can't find any docs, well written or otherwise, on the Les.Net site.
 
=== Gizmo connection ===
 
Getting Gizmo to work was probably the hardest part. It has to be set to forward calls to my Asterisk system.
 
[http://support.gizmoproject.com/index.php?_a=knowledgebase&_j=questiondetails&_i=201 Set up Asterisk to use Gizmo for incoming calls]

Latest revision as of 15:47, 31 August 2022

See also the VOIP category and Asterisk debugging.

Overview

2022-May-13 Asterisk is not just for phones, it's also for ham radio. It's called AllStarLink, which I am using for the Repeater linking project.

2019-Nov-01 I ran a Vastra (Asterisk + Twilio) phone system at home for a few years but I am tired of it now, so I am shutting it down and forwarding the number to my cellphone.

I merged together Twilio and Asterisk for a home phone system. I spent 1000 hours developing a commercial grade small buiness Asterisk based system but my business partner and I got cold feet and we quit.

Back story: I used Packet8 ($30/month) then Les.net (gone) then Grandcentral + GISMO5 (free!) then Google ate Grandcentral AND GISMO5 and gutted them. Then I used only mobile phones for years.

Right now for Asterisk, I am using MySQL not PostgreSQL, it's simpler and gets the job done for phone systems. I have to update the sections below from PG to MySQL.

Incoming calls

People can dial in to a Google Voice number and it will hit the PBX and 2 mobiles. I am moving away from that.

They can also dial in to a Twilio number and it will hit the PBX, which then dials out to my mobile. I want to set up some TWIML to handle the follow me thing in Twilio instead of having it come through the Asterisk PBX. I'd kind of like the PBX to go away and just use Twilio. Replacing Asterisk with Twilio

Outgoing calls

Again, using Twilio for outgoing calls too.

Business Asterisk system

BLF tip

If you are working with BLF (the "Busy Lamp Field" lights on phone) (for example on the sidecar for the GXV3240), and you make changes in Asterisk, the hints and the phone can get out of sync. Lights seem to freeze up or not change. Don't tear your hair out! Reboot the phone first and see if things start working again.

Grandstream GXV3240 phone

For business systems, I am working with these phones right now, along with the optional button modules (which I call "sidecars" for some reason.)

I have a separate page for them, see Grandstream GXV3240.

Grandstream GXW4104

Used to connect up to four POTS lines.

Buggy firmware... bad documentation... avoid.

check and update firmware
set hostname
set up syslog
adjust rings before pickup
set time zone and ntp

Setting up PostgreSQL

When building Asterisk from source, you must have the postgres dev package installed before you do ./configure. Asterisk build is not good about telling you what is available when ./configure completes. You can do 'make menuselect' and see what will be available.

CEL = Channel Event Log, more details than CDR (CDR = Call Detail Record)

In cel.conf

enable=yes

In cel_pgsql.conf, at the bottom

hostname=localhost
port=5432
dbname=asterisk
password=yoursecretpasswordhere
user=asterisk
table=cel          ; SQL table where CEL's will be inserted                                                        
appname=asterisk   ; Postgres application_name support (optional). Whitespace not allowed.                             

If you wish, follow suit and fix up res_pgsql.conf and cdr_pgsql.conf too.

Create the database, user and appropriate permission

su - postgres
createdb asterisk
echo "CREATE USER asterisk WITH PASSWORD 'yoursecretpasswordhere';" | psql
echo "GRANT ALL ON DATABASE asterisk TO asterisk;" | psql

I got this code from voipinfo.org http://www.voip-info.org/wiki/view/Asterisk+cdr+odbc

CREATE TABLE cel (
 id serial,
 eventtime timestamp with time zone NOT NULL DEFAULT now(),
 eventtype character varying(80) NOT NULL DEFAULT ::character varying,
 userdeftype character varying(80) NOT NULL DEFAULT ::character varying,
 cid_name character varying(80) NOT NULL DEFAULT ::character varying,
 cid_num character varying(80) NOT NULL DEFAULT ::character varying,
 cid_ani character varying(80) NOT NULL DEFAULT ::character varying,
 cid_rdnis character varying(80) NOT NULL DEFAULT ::character varying,
 cid_dnid character varying(80) NOT NULL DEFAULT ::character varying,
 exten character varying(80) NOT NULL DEFAULT ::character varying,
 context character varying(80) NOT NULL DEFAULT ::character varying,
 channame character varying(80) NOT NULL DEFAULT ::character varying,
 appname character varying(80) NOT NULL DEFAULT ::character varying,
 appdata character varying(80) NOT NULL DEFAULT ::character varying,
 accountcode character varying(20) NOT NULL DEFAULT ::character varying,
 peeraccount character varying(80) NOT NULL DEFAULT ::character varying,
 uniqueid character varying(32) NOT NULL DEFAULT ::character varying,
 linkedid character varying(80) NOT NULL DEFAULT ::character varying,
 amaflags integer NOT NULL DEFAULT 0,
 userfield character varying(255) NOT NULL DEFAULT ::character varying,
 peer character varying(80) NOT NULL DEFAULT ::character varying,
 CONSTRAINT cel_pkey PRIMARY KEY (id)
);

See also source code contrib/scripts/realtime/postgresql/


for tbl in `psql -qAt -c "select tablename from pg_tables where schemaname = 'public';" asterisk` ; do  psql -c "alter table $tbl owner to asterisk" asterisk ; done

Sequences:

for tbl in `psql -qAt -c "select sequence_name from information_schema.sequences where sequence_schema = 'public';" asterisk` ; do  psql -c "alter table $tbl owner to asterisk" asterisk ; done

Views:

for tbl in `psql -qAt -c "select table_name from information_schema.views where table_schema = 'public';" asterisk` ; do  psql -c "alter table $tbl owner to asterisk" asterisk ; done

Auto-attendant set up

Intercom style paging

  1. Set up an extension eg "499" that will call Page() with a list of phones, eg. Page(SIP/100&SIP/101&SIP/102,s,120)
  2. Tell the Grandstream that it's okay to be paged, Account->Account 1->Call Settings->Auto Answer=Enable Intercom/Paging
  3. Set up an MPK button to page. Advanced Settings->MPK EXT1 Settings->Key mode=Call Intercom,User=499

Hardware

Not using at the moment: 1 Packet8 DTA-310, reflashed to be a Leadtek BVA8051. See http://www.voip-info.org/wiki-Packet8+DTA310+and+Asterisk and http://www.stromcarlson.com/projects/dta-310/

I need to plug in my rotary dial and push button phones to this thing.

Implementation

Customizations

As much as possible I keep general changes out of main config files by using include files. This makes updates much simpler. In sip.conf add this line: #include sip-wildsong.conf and in extensions.conf add this: #include extensions-wildsong.conf The voicemail.conf file warns agains this approach so I edit it directly.

For each of the extensions, I then add entries in sip-wildsong.conf and extensions-wildsong.conf and voicemail.conf.

I edit the web settings for the hard phones and the configuration settings for the Ekiga softphones.

That's about it.