first pass at phone GUI
authordrowe67 <drowe67@01035d8c-6547-0410-b346-abe4f91aad63>
Tue, 5 Jan 2010 08:09:04 +0000 (08:09 +0000)
committerdrowe67 <drowe67@01035d8c-6547-0410-b346-abe4f91aad63>
Tue, 5 Jan 2010 08:09:04 +0000 (08:09 +0000)
git-svn-id: https://svn.code.sf.net/p/freetel/code@95 01035d8c-6547-0410-b346-abe4f91aad63

13 files changed:
easy-asterisk-gui/Makefile
easy-asterisk-gui/dashboard.sh
easy-asterisk-gui/extensions.conf
easy-asterisk-gui/ipphone.png [new file with mode: 0644]
easy-asterisk-gui/menu.html
easy-asterisk-gui/network.sh
easy-asterisk-gui/phone.pl [new file with mode: 0755]
easy-asterisk-gui/phone.png [new file with mode: 0644]
easy-asterisk-gui/phone.sh
easy-asterisk-gui/phoneline.jpg [new file with mode: 0644]
easy-asterisk-gui/sip.conf [new file with mode: 0644]
easy-asterisk-gui/tooltips.html
easy-asterisk-gui/voipline.jpg [new file with mode: 0644]

index 9c0e4bfd2728f927ac70559507a1f63a11b29566..196a21e8808250f4aae568f599e4c07f74e36768 100644 (file)
@@ -9,5 +9,5 @@ TESTIP=192.168.1.150
 #      rcp index.html root@$(TESTIP):/var/lib/asterisk/static-http/
 
 test:
-       rcp tooltips.html phone.sh phone.js tick.png cross.png banner.html menu.html check_loggedin.sh logout.sh login.sh dashboard.sh dashboard.js network.sh network.js set_network.sh tooltip.js tooltip.css root@$(TESTIP):/www/cgi-bin
-       rcp extensions.conf root@$(TESTIP):/etc/asterisk
+       rcp voipline.jpg phone.png phoneline.jpg ipphone.png phone.pl tooltips.html phone.sh phone.js tick.png cross.png banner.html menu.html check_loggedin.sh logout.sh login.sh dashboard.sh dashboard.js network.sh network.js set_network.sh tooltip.js tooltip.css root@$(TESTIP):/www/cgi-bin
+       rcp sip.conf extensions.conf root@$(TESTIP):/etc/asterisk
index 0b56f36eb9ff0b4f3615023f91902032831e5867..81daa21c838642c36cece4fb545ce769b1b29054 100644 (file)
@@ -34,7 +34,7 @@ cat << EOF
 EOF
 
 cat tooltips.html
-echo "<table align="center" width=800 border=0>"
+echo '<table align="center" width=800 border=0>'
 cat banner.html
 echo "    <tr>"
 cat menu.html    
@@ -44,7 +44,7 @@ cat <<EOF
 
     <form action="/cgi-bin/set_network.sh" onsubmit="return validate_form(this)" method="get">
     <table align="right" width=600 border=0>
-      <tr><td colspan="2" align="left" valign="top" ><h2>Dashboard</h2></td></tr>
+      <tr><td colspan="3" align="left" valign="top" ><h2>Dashboard</h2></td></tr>
       <tr onMouseOver="popUp(event,'network_internet')" onmouseout="popUp(event,'network_internet')">
          <td>Internet Connection:</td>
          <td><div id="internet" >
index d1012ab9e1ffd1726936fcc84e6ce12ce89340e4..48c59c1ff932bdde79916a249538b8f112995edf 100644 (file)
@@ -19,36 +19,36 @@ priorityjumping = no
 ; Pre-configured analog extensions, depends on IP0X model and what modules
 ; are installed.  Some of these may map to FXO ports
 
-exten => 6001,n,Dial(Zap/1)
-exten => 6002,n,Dial(Zap/2)
-exten => 6003,n,Dial(Zap/3)
-exten => 6004,n,Dial(Zap/4)
-exten => 6005,n,Dial(Zap/5)
-exten => 6006,n,Dial(Zap/6)
-exten => 6007,n,Dial(Zap/7)
-exten => 6008,n,Dial(Zap/8)
+exten => 6001,1,Dial(Zap/1)
+exten => 6002,1,Dial(Zap/2)
+exten => 6003,1,Dial(Zap/3)
+exten => 6004,1,Dial(Zap/4)
+exten => 6005,1,Dial(Zap/5)
+exten => 6006,1,Dial(Zap/6)
+exten => 6007,1,Dial(Zap/7)
+exten => 6008,1,Dial(Zap/8)
 
 ; Pre-configured SIP-phone extensions.  Primary use case is multiple SIP
 ; extensions and FXO analog Ports
 
-exten => 6011,n,Dial(SIP/6011)
-exten => 6012,n,Dial(SIP/6012)
-exten => 6013,n,Dial(SIP/6013)
-exten => 6014,n,Dial(SIP/6014)
-exten => 6015,n,Dial(SIP/6015)
-exten => 6016,n,Dial(SIP/6016)
-exten => 6017,n,Dial(SIP/6017)
-exten => 6018,n,Dial(SIP/6018)
-exten => 6019,n,Dial(SIP/6019)
-exten => 6020,n,Dial(SIP/6020)
-exten => 6021,n,Dial(SIP/6021)
-exten => 6022,n,Dial(SIP/6022)
-exten => 6023,n,Dial(SIP/6023)
-exten => 6024,n,Dial(SIP/6024)
-exten => 6025,n,Dial(SIP/6025)
-exten => 6026,n,Dial(SIP/6026)
-exten => 6027,n,Dial(SIP/6027)
-exten => 6028,n,Dial(SIP/6028)
-exten => 6029,n,Dial(SIP/6029)
-exten => 6020,n,Dial(SIP/6020)
+exten => 6011,1,Dial(SIP/6011)
+exten => 6012,1,Dial(SIP/6012)
+exten => 6013,1,Dial(SIP/6013)
+exten => 6014,1,Dial(SIP/6014)
+exten => 6015,1,Dial(SIP/6015)
+exten => 6016,1,Dial(SIP/6016)
+exten => 6017,1,Dial(SIP/6017)
+exten => 6018,1,Dial(SIP/6018)
+exten => 6019,1,Dial(SIP/6019)
+exten => 6020,1,Dial(SIP/6020)
+exten => 6021,1,Dial(SIP/6021)
+exten => 6022,1,Dial(SIP/6022)
+exten => 6023,1,Dial(SIP/6023)
+exten => 6024,1,Dial(SIP/6024)
+exten => 6025,1,Dial(SIP/6025)
+exten => 6026,1,Dial(SIP/6026)
+exten => 6027,1,Dial(SIP/6027)
+exten => 6028,1,Dial(SIP/6028)
+exten => 6029,1,Dial(SIP/6029)
+exten => 6030,1,Dial(SIP/6030)
 
diff --git a/easy-asterisk-gui/ipphone.png b/easy-asterisk-gui/ipphone.png
new file mode 100644 (file)
index 0000000..f9578db
Binary files /dev/null and b/easy-asterisk-gui/ipphone.png differ
index c4e6cc99609e4186ed7fb3ba394e7dfbee5f81ea..4eb1af07fa9bc9c487eb74c09e944974aec30033 100644 (file)
@@ -1,4 +1,4 @@
-    <div id="admin_tip" class="tip">Change your password, Reset the defaults, Install new software</div>
+    <div id="admin_tip" class="tip">Change your password, Time & time zone, Reset the defaults, Install new software</div>
     <div id="dashboard_tip" class="tip">Monitor the status of your phone system</div>
     <div id="network_tip" class="tip">Connect the phone system to your network and the Internet</div>
     <div id="phone_tip" class="tip">Set up your phones and phone calls</div>
index d8172a19341295fd669f10e759add2e1d7d14767..d57854cbddad29af1effb5b293dd41fee09dc310 100644 (file)
@@ -66,7 +66,7 @@ cat << EOF
 EOF
 
 cat tooltips.html
-echo "<table align="center" width=800 border=0>"
+echo '<table align="center" width=800 border=0>'
 cat banner.html
 echo "    <tr>"
 cat menu.html    
diff --git a/easy-asterisk-gui/phone.pl b/easy-asterisk-gui/phone.pl
new file mode 100755 (executable)
index 0000000..f540360
--- /dev/null
@@ -0,0 +1,121 @@
+#!/sbin/microperl
+# phone.pl
+# David Rowe 5 Jan 2010
+#
+# Extracts the phone extension infor from /etc/asterisk/extensions.conf
+# and generate html.  Perl used as faster than equivalent shell script
+
+$tool_tip = "onMouseOver=\"popUp(event,'network_internet')\" onmouseout=\"popUp(event,'network_internet')\"";
+
+my %analog = (); # analog extension keyed on zap port
+
+open EXT, "/etc/asterisk/extensions.conf";
+while (<EXT>) { 
+    if (/.*=>[ ]*([0-9]*),1.*Zap\/([0-9]*)\)/) {
+        $analog{$2} = $1;
+       #print "'$1' '$2' $analog{$2}\n";
+    }
+}
+close EXT;
+
+my %zap = (); # zaptel port type keyed on zap port 
+              # (fxs/fxo or no entry if not live)
+open ZAP, "/etc/zaptel.conf";
+while (<ZAP>) { 
+    if (/fxoks=([0-9]*)/) {
+        $zap{$1} = "fxs";
+    }
+    if (/fxsks=([0-9]*)/) {
+        $zap{$1} = "fxo";
+    }
+}
+close ZAP;
+
+my %ip = (); # ip extension keyed on sip.conf name
+
+open EXT, "/etc/asterisk/extensions.conf";
+while (<EXT>) { 
+    if (/.*=>[ ]*([0-9]*),1.*Sip\/([0-9]*)\)/) {
+        $ip{$2} = $1;
+       #print "'$1' '$2' $ip{$2}\n";
+    }
+}
+close EXT;
+
+my %sip = ();  # SIP IP phone status keyed on sip.conf names 
+               # if no entry we can't see IP phone device
+my %voip = (); # SIP trunks status keyed on sip.conf names 
+               # if no entry we can't see SIP trunk
+my %ipad = (); # IP address of SIP device keyed on sip.conf names
+
+open SIP, "sipshowpeers.txt";
+while (<SIP>) { 
+    if (/^([0-9]*)[\s\/].*(OK)/) {
+        $sip{$1} = $2;
+       #print "'$1' '$2' $sip{$1}\n";
+       $e = $1;
+       if (/\s([0-9]+\.[0-9]+\.[0-9]+\.[0-9]+)\s/) {
+           $ipad{$e} = $1;
+           #print "'$1'\n";
+       }
+    }
+    if (/^(voip[0-9]*)[\s\/].*(OK)/) {
+        $voip{$1} = $2;
+       #print "'$1' '$2' $voip{$1}\n";
+       $e = $1;
+       if (/\s([0-9]+\.[0-9]+\.[0-9]+\.[0-9]+)\s/) {
+           $ipad{$e} = $1;
+           #print "'$1'\n";
+       }
+    }
+}
+
+close SIP;
+
+# print list of analog phones
+
+$tool_tip = "onMouseOver=\"popUp(event,'phone_phone')\" onmouseout=\"popUp(event,'phone_phone')\"";
+
+foreach $a (sort keys %analog) {
+    if ($zap{$a} eq "fxs") {
+       $icon = "<img $tool_tip src=\"phone.png\" alt=\"Analog Phone\" />";
+       print "<tr><td>$analog{$a}</td><td>Port $a</td><td>$icon</td></tr>\n";
+    }
+}
+
+# print list of IP phones
+
+$tool_tip = "onMouseOver=\"popUp(event,'phone_ipphone')\" onmouseout=\"popUp(event,'phone_ipphone')\"";
+
+foreach $s (sort keys %sip) {
+    if ($sip{$s} eq "OK") {
+       $icon = "<img $tool_tip src=\"ipphone.png\" alt=\"IP Phone\" />";
+       print "<tr><td>$s</td><td>$ipad{$s}</td><td>$icon</td></tr>\n";
+    }
+}
+
+print '<tr><td colspan="2" align="left" valign="top" ><h2>Phone Lines</h2></td></tr>
+';
+
+# print list of analog phone lines
+
+$tool_tip = "onMouseOver=\"popUp(event,'phone_phoneline')\" onmouseout=\"popUp(event,'phone_phoneline')\"";
+
+foreach $a (sort keys %analog) {
+    if ($zap{$a} eq "fxo") {
+       $icon = "<img $tool_tip src=\"phoneline.jpg\" alt=\"Phone Line\" />";
+       print "<tr><td>$analog{$a}</td><td>Port $a</td><td>$icon</td></tr>\n";
+    }
+}
+
+# print list of SIP VOIP trunks
+
+$tool_tip = "onMouseOver=\"popUp(event,'phone_voipline')\" onmouseout=\"popUp(event,'phone_voipline')\"";
+
+foreach $s (sort keys %voip) {
+    if ($voip{$s} eq "OK") {
+       $icon = "<img $tool_tip src=\"voipline.jpg\" alt=\"VOIP Line\" />";
+       print "<tr><td>$s</td><td>$ipad{$s}</td><td>$icon</td></tr>\n";
+    }
+}
+
diff --git a/easy-asterisk-gui/phone.png b/easy-asterisk-gui/phone.png
new file mode 100644 (file)
index 0000000..9783372
Binary files /dev/null and b/easy-asterisk-gui/phone.png differ
index 1d3a5de9b5fb459b33799793ebb643af36f03aac..dc84c546231f48a2f5894d5d0fd6123ef6aa6b93 100644 (file)
@@ -23,30 +23,27 @@ cat << EOF
 <html>
 <title>Easy Asterisk - Phones</title>
 <body onload="localInit()">
-<div id="t1" class="tip">Tells you if I can reach the Internet.  If 
-                         not "Good" check your network settings, in 
-                         particular Gateway and DNS.</div>
-
-<table align="center" width=800>
 EOF
+
+cat tooltips.html
+echo '<table align="center" width=800>'
 cat banner.html
 echo "    <tr>"
 cat menu.html    
 cat <<EOF
 
-    <td>
+    <td valign="top">
 
-    <form action="/cgi-bin/set_phone.sh" onsubmit="return validate_form(this)" method="get">
     <table align="right" width=600>
-    <tr>
-      <tr><td colspan="2" align="left" valign="top" ><h2>Phones</h2></td>
-      <tr onMouseOver="popUp(event,'t1')" onmouseout="popUp(event,'t1')">
-         <td>Internet Connection:</td>
-         <td><div id="internet" >
-         <span style="margin-left: 4px;font-weight:bold">&nbsp;</span></div></td>
-      </tr>
+      <tr><td colspan="2" align="left" valign="top" ><h2>Phones</h2></td></tr>
+EOF
+
+# use perl to construct list of phones and phone lines for us
+asterisk "-rx sip show peers" 2>/dev/null > sipshowpeers.txt
+./phone.pl
+
+cat<<EOF
     </table>
-    </form>
 
     </td>
 
diff --git a/easy-asterisk-gui/phoneline.jpg b/easy-asterisk-gui/phoneline.jpg
new file mode 100644 (file)
index 0000000..21078c3
Binary files /dev/null and b/easy-asterisk-gui/phoneline.jpg differ
diff --git a/easy-asterisk-gui/sip.conf b/easy-asterisk-gui/sip.conf
new file mode 100644 (file)
index 0000000..3cd56ed
--- /dev/null
@@ -0,0 +1,546 @@
+;
+; SIP Configuration example for Asterisk
+;
+; Syntax for specifying a SIP device in extensions.conf is
+; SIP/devicename where devicename is defined in a section below.
+;
+; You may also use 
+; SIP/username@domain to call any SIP user on the Internet
+; (Don't forget to enable DNS SRV records if you want to use this)
+; 
+; If you define a SIP proxy as a peer below, you may call
+; SIP/proxyhostname/user or SIP/user@proxyhostname 
+; where the proxyhostname is defined in a section below 
+; 
+; Useful CLI commands to check peers/users:
+;   sip show peers             Show all SIP peers (including friends)
+;   sip show users             Show all SIP users (including friends)
+;   sip show registry          Show status of hosts we register with
+;
+;   sip debug                  Show all SIP messages
+;
+;   reload chan_sip.so         Reload configuration file
+;                              Active SIP peers will not be reconfigured
+;
+
+[general]
+context=default                        ; Default context for incoming calls
+;allowguest=no                 ; Allow or reject guest calls (default is yes, this can also be set to 'osp'
+                               ; if asterisk was compiled with OSP support.
+;realm=mydomain.tld            ; Realm for digest authentication
+                               ; defaults to "asterisk"
+                               ; Realms MUST be globally unique according to RFC 3261
+                               ; Set this to your host name or domain name
+bindport=5060                  ; UDP Port to bind to (SIP standard port is 5060)
+bindaddr=0.0.0.0               ; IP address to bind to (0.0.0.0 binds to all)
+srvlookup=yes                  ; Enable DNS SRV lookups on outbound calls
+                               ; Note: Asterisk only uses the first host 
+                               ; in SRV records
+                               ; Disabling DNS SRV lookups disables the 
+                               ; ability to place SIP calls based on domain 
+                               ; names to some other SIP users on the Internet
+                               
+;domain=mydomain.tld           ; Set default domain for this host
+                               ; If configured, Asterisk will only allow
+                               ; INVITE and REFER to non-local domains
+                               ; Use "sip show domains" to list local domains
+;domain=mydomain.tld,mydomain-incoming
+                               ; Add domain and configure incoming context
+                               ; for external calls to this domain
+;domain=1.2.3.4                        ; Add IP address as local domain
+                               ; You can have several "domain" settings
+;allowexternalinvites=no       ; Disable INVITE and REFER to non-local domains
+                               ; Default is yes
+;autodomain=yes                        ; Turn this on to have Asterisk add local host
+                               ; name and local IP to domain list.
+;pedantic=yes                  ; Enable slow, pedantic checking for Pingtel
+                               ; and multiline formatted headers for strict
+                               ; SIP compatibility (defaults to "no")
+;tos=184                       ; Set IP QoS to either a keyword or numeric val
+;tos=lowdelay                  ; lowdelay,throughput,reliability,mincost,none
+;maxexpiry=3600                        ; Max length of incoming registration we allow
+;defaultexpiry=120             ; Default length of incoming/outoing registration
+;notifymimetype=text/plain     ; Allow overriding of mime type in MWI NOTIFY
+;checkmwi=10                   ; Default time between mailbox checks for peers
+;vmexten=voicemail      ; dialplan extension to reach mailbox sets the 
+                                               ; Message-Account in the MWI notify message 
+                                               ; defaults to "asterisk"
+;videosupport=yes              ; Turn on support for SIP video
+;recordhistory=yes             ; Record SIP history by default 
+                               ; (see sip history / sip no history)
+
+;disallow=all                  ; First disallow all codecs
+;allow=ulaw                    ; Allow codecs in order of preference
+;allow=ilbc                    ; 
+;musicclass=default            ; Sets the default music on hold class for all SIP calls
+                               ; This may also be set for individual users/peers
+;language=en                   ; Default language setting for all users/peers
+                               ; This may also be set for individual users/peers
+;relaxdtmf=yes                 ; Relax dtmf handling
+;rtptimeout=60                 ; Terminate call if 60 seconds of no RTP activity
+                               ; when we're not on hold
+;rtpholdtimeout=300            ; Terminate call if 300 seconds of no RTP activity
+                               ; when we're on hold (must be > rtptimeout)
+;trustrpid = no                        ; If Remote-Party-ID should be trusted
+;sendrpid = yes                        ; If Remote-Party-ID should be sent
+;progressinband=never          ; If we should generate in-band ringing always
+                               ; use 'never' to never use in-band signalling, even in cases
+                               ; where some buggy devices might not render it
+;useragent=Asterisk PBX                ; Allows you to change the user agent string
+;promiscredir = no             ; If yes, allows 302 or REDIR to non-local SIP address
+                               ; Note that promiscredir when redirects are made to the
+                                       ; local system will cause loops since SIP is incapable
+                                       ; of performing a "hairpin" call.
+;usereqphone = no              ; If yes, ";user=phone" is added to uri that contains
+                               ; a valid phone number
+;dtmfmode = rfc2833            ; Set default dtmfmode for sending DTMF. Default: rfc2833
+                               ; Other options: 
+                               ; info : SIP INFO messages
+                               ; inband : Inband audio (requires 64 kbit codec -alaw, ulaw)
+                               ; auto : Use rfc2833 if offered, inband otherwise
+
+;compactheaders = yes          ; send compact sip headers.
+;sipdebug = yes                        ; Turn on SIP debugging by default, from
+                               ; the moment the channel loads this configuration
+;subscribecontext = default    ; Set a specific context for SUBSCRIBE requests
+                               ; Useful to limit subscriptions to local extensions
+                               ; Settable per peer/user also
+;notifyringing = yes           ; Notify subscriptions on RINGING state
+
+;
+; If regcontext is specified, Asterisk will dynamically create and destroy a
+; NoOp priority 1 extension for a given peer who registers or unregisters with
+; us.  The actual extension is the 'regexten' parameter of the registering
+; peer or its name if 'regexten' is not provided.  More than one regexten may
+; be supplied if they are separated by '&'.  Patterns may be used in regexten.
+;
+;regcontext=sipregistrations
+;
+; Asterisk can register as a SIP user agent to a SIP proxy (provider)
+; Format for the register statement is:
+;       register => user[:secret[:authuser]]@host[:port][/extension]
+;
+; If no extension is given, the 's' extension is used. The extension needs to
+; be defined in extensions.conf to be able to accept calls from this SIP proxy
+; (provider).
+;
+; host is either a host name defined in DNS or the name of a section defined
+; below.
+;
+; Examples:
+;
+;register => 1234:password@mysipprovider.com   
+;
+;     This will pass incoming calls to the 's' extension
+;
+;
+;register => 2345:password@sip_proxy/1234
+;
+;    Register 2345 at sip provider 'sip_proxy'.  Calls from this provider
+;    connect to local extension 1234 in extensions.conf, default context,
+;    unless you configure a [sip_proxy] section below, and configure a
+;    context.
+;    Tip 1: Avoid assigning hostname to a sip.conf section like [provider.com]
+;    Tip 2: Use separate type=peer and type=user sections for SIP providers
+;           (instead of type=friend) if you have calls in both directions
+  
+;registertimeout=20            ; retry registration calls every 20 seconds (default)
+;registerattempts=10           ; Number of registration attempts before we give up
+                               ; 0 = continue forever, hammering the other server until it 
+                               ; accepts the registration
+                               ; Default is 0 tries, continue forever
+;callevents=no                 ; generate manager events when sip ua performs events (e.g. hold)
+
+;----------------------------------------- NAT SUPPORT ------------------------
+; The externip, externhost and localnet settings are used if you use Asterisk
+; behind a NAT device to communicate with services on the outside.
+
+;externip = 200.201.202.203    ; Address that we're going to put in outbound SIP messages
+                               ; if we're behind a NAT
+
+                               ; The externip and localnet is used
+                               ; when registering and communicating with other proxies
+                               ; that we're registered with
+;externhost=foo.dyndns.net     ; Alternatively you can specify an 
+                               ; external host, and Asterisk will 
+                               ; perform DNS queries periodically.  Not
+                               ; recommended for production 
+                               ; environments!  Use externip instead
+;externrefresh=10              ; How often to refresh externhost if 
+                               ; used
+                               ; You may add multiple local networks.  A reasonable set of defaults
+                               ; are:
+;localnet=192.168.0.0/255.255.0.0; All RFC 1918 addresses are local networks
+;localnet=10.0.0.0/255.0.0.0   ; Also RFC1918
+;localnet=172.16.0.0/12                ; Another RFC1918 with CIDR notation
+;localnet=169.254.0.0/255.255.0.0 ;Zero conf local network
+
+; The nat= setting is used when Asterisk is on a public IP, communicating with
+; devices hidden behind a NAT device (broadband router).  If you have one-way
+; audio problems, you usually have problems with your NAT configuration or your
+; firewall's support of SIP+RTP ports.  You configure Asterisk choice of RTP
+; ports for incoming audio in rtp.conf
+;
+;nat=no                                ; Global NAT settings  (Affects all peers and users)
+                                ; yes = Always ignore info and assume NAT
+                                ; no = Use NAT mode only according to RFC3581 
+                                ; never = Never attempt NAT mode or RFC3581 support
+                               ; route = Assume NAT, don't send rport 
+                               ; (work around more UNIDEN bugs)
+
+;rtcachefriends=yes            ; Cache realtime friends by adding them to the internal list
+                               ; just like friends added from the config file only on a
+                               ; as-needed basis? (yes|no)
+
+;rtupdate=yes                  ; Send registry updates to database using realtime? (yes|no)
+                               ; If set to yes, when a SIP UA registers successfully, the ip address,
+                               ; the origination port, the registration period, and the username of
+                               ; the UA will be set to database via realtime. If not present, defaults to 'yes'.
+
+;rtautoclear=yes               ; Auto-Expire friends created on the fly on the same schedule
+                               ; as if it had just registered? (yes|no|<seconds>)
+                               ; If set to yes, when the registration expires, the friend will vanish from
+                               ; the configuration until requested again. If set to an integer,
+                               ; friends expire within this number of seconds instead of the
+                               ; registration interval.
+
+;ignoreregexpire=yes           ; Enabling this setting has two functions:
+                               ;
+                               ; For non-realtime peers, when their registration expires, the information
+                               ; will _not_ be removed from memory or the Asterisk database; if you attempt
+                               ; to place a call to the peer, the existing information will be used in spite
+                               ; of it having expired
+                               ;
+                               ; For realtime peers, when the peer is retrieved from realtime storage,
+                               ; the registration information will be used regardless of whether
+                               ; it has expired or not; if it expires while the realtime peer is still in
+                               ; memory (due to caching or other reasons), the information will not be
+                               ; removed from realtime storage
+
+; Incoming INVITE and REFER messages can be matched against a list of 'allowed'
+; domains, each of which can direct the call to a specific context if desired.
+; By default, all domains are accepted and sent to the default context or the
+; context associated with the user/peer placing the call.
+; Domains can be specified using:
+; domain=<domain>[,<context>]
+; Examples:
+; domain=myasterisk.dom
+; domain=customer.com,customer-context
+;
+; In addition, all the 'default' domains associated with a server should be
+; added if incoming request filtering is desired.
+; autodomain=yes
+;
+; To disallow requests for domains not serviced by this server:
+; allowexternaldomains=no
+
+; fromdomain=mydomain.tld ; When making outbound SIP INVITEs to
+                          ; non-peers, use your primary domain "identity"
+                          ; for From: headers instead of just your IP
+                          ; address. This is to be polite and
+                          ; it may be a mandatory requirement for some
+                          ; destinations which do not have a prior
+                          ; account relationship with your server. 
+
+[authentication]
+; Global credentials for outbound calls, i.e. when a proxy challenges your
+; Asterisk server for authentication. These credentials override
+; any credentials in peer/register definition if realm is matched.
+;
+; This way, Asterisk can authenticate for outbound calls to other
+; realms. We match realm on the proxy challenge and pick an set of 
+; credentials from this list
+; Syntax:
+;      auth = <user>:<secret>@<realm>
+;      auth = <user>#<md5secret>@<realm>
+; Example:
+;auth=mark:topsecret@digium.com
+; 
+; You may also add auth= statements to [peer] definitions 
+; Peer auth= override all other authentication settings if we match on realm
+
+;------------------------------------------------------------------------------
+; Users and peers have different settings available. Friends have all settings,
+; since a friend is both a peer and a user
+;
+; User config options:        Peer configuration:
+; --------------------        -------------------
+; context                     context
+; permit                      permit
+; deny                        deny
+; secret                      secret
+; md5secret                   md5secret
+; dtmfmode                    dtmfmode
+; canreinvite                 canreinvite
+; nat                         nat
+; callgroup                   callgroup
+; pickupgroup                 pickupgroup
+; language                    language
+; allow                       allow
+; disallow                    disallow
+; insecure                    insecure
+; trustrpid                   trustrpid
+; progressinband              progressinband
+; promiscredir                promiscredir
+; useclientcode               useclientcode
+; accountcode                 accountcode
+; setvar                      setvar
+; callerid                   callerid
+; amaflags                   amaflags
+; call-limit                 call-limit
+; restrictcid                restrictcid
+; subscribecontext           subscribecontext
+; videosupport               videosupport
+;                             mailbox
+;                             username
+;                             template
+;                             fromdomain
+;                             regexten
+;                             fromuser
+;                             host
+;                             port
+;                             qualify
+;                             defaultip
+;                             rtptimeout
+;                             rtpholdtimeout
+;                             sendrpid
+
+;[sip_proxy]
+; For incoming calls only. Example: FWD (Free World Dialup)
+; We match on IP address of the proxy for incoming calls 
+; since we can not match on username (caller id)
+;type=peer
+;context=from-fwd
+;host=fwd.pulver.com
+
+;[sip_proxy-out]
+;type=peer                     ; we only want to call out, not be called
+;secret=guessit
+;username=yourusername         ; Authentication user for outbound proxies
+;fromuser=yourusername         ; Many SIP providers require this!
+;fromdomain=provider.sip.domain        
+;host=box.provider.com
+;usereqphone=yes               ; This provider requires ";user=phone" on URI
+;call-limit=5                  ; permit only 5 simultaneous outgoing calls to this peer
+
+;------------------------------------------------------------------------------
+; Definitions of locally connected SIP phones
+;
+; type = user  a device that authenticates to us by "from" field to place calls
+; type = peer  a device we place calls to or that calls us and we match by host
+; type = friend two configurations (peer+user) in one
+;
+; For local phones, type=friend works most of the time
+;
+; If you have one-way audio, you propably have NAT problems. 
+; If Asterisk is on a public IP, and the phone is inside of a NAT device
+; you will need to configure nat option for those phones.
+; Also, turn on qualify=yes to keep the nat session open
+
+;[grandstream1]
+;type=friend                   
+;context=from-sip              ; Where to start in the dialplan when this phone calls
+;callerid=John Doe <1234>      ; Full caller ID, to override the phones config
+;host=192.168.0.23             ; we have a static but private IP address
+                               ; No registration allowed
+;nat=no                                ; there is not NAT between phone and Asterisk
+;canreinvite=yes               ; allow RTP voice traffic to bypass Asterisk
+;dtmfmode=info                 ; either RFC2833 or INFO for the BudgeTone
+;call-limit=1                  ; permit only 1 outgoing call and 1 incoming call at a time
+                               ; from the phone to asterisk
+                               ; (1 for the explicit peer, 1 for the explicit user,
+                               ; remember that a friend equals 1 peer and 1 user in
+                               ; memory)
+;mailbox=1234@default          ; mailbox 1234 in voicemail context "default"
+;disallow=all                  ; need to disallow=all before we can use allow=
+;allow=ulaw                    ; Note: In user sections the order of codecs
+                               ; listed with allow= does NOT matter!
+;allow=alaw
+;allow=g723.1                  ; Asterisk only supports g723.1 pass-thru!
+;allow=g729                    ; Pass-thru only unless g729 license obtained
+;astdb=chan2ext/SIP/grandstream1=1234  ; ensures an astDB entry exists
+
+
+;[xlite1]
+; Turn off silence suppression in X-Lite ("Transmit Silence"=YES)!
+; Note that Xlite sends NAT keep-alive packets, so qualify=yes is not needed
+;type=friend
+;regexten=1234                 ; When they register, create extension 1234
+;callerid="Jane Smith" <5678>
+;host=dynamic                  ; This device needs to register
+;nat=yes                       ; X-Lite is behind a NAT router
+;canreinvite=no                        ; Typically set to NO if behind NAT
+;disallow=all
+;allow=gsm                     ; GSM consumes far less bandwidth than ulaw
+;allow=ulaw
+;allow=alaw
+;mailbox=1234@default,1233@default     ; Subscribe to status of multiple mailboxes
+
+
+;[snom]
+;type=friend                   ; Friends place calls and receive calls
+;context=from-sip              ; Context for incoming calls from this user
+;secret=blah
+;subscribecontext=localextensions      ; Only allow SUBSCRIBE for local extensions
+;language=de                   ; Use German prompts for this user 
+;host=dynamic                  ; This peer register with us
+;dtmfmode=inband               ; Choices are inband, rfc2833, or info
+;defaultip=192.168.0.59                ; IP used until peer registers
+;mailbox=1234@context,2345      ; Mailbox(-es) for message waiting indicator
+;vmexten=voicemail      ; dialplan extension to reach mailbox 
+                        ; sets the Message-Account in the MWI notify message
+                        ; defaults to global vmexten which defaults to "asterisk"
+;restrictcid=yes               ; To have the callerid restriced -> sent as ANI
+;disallow=all
+;allow=ulaw                    ; dtmfmode=inband only works with ulaw or alaw!
+
+
+;[polycom]
+;type=friend                   ; Friends place calls and receive calls
+;context=from-sip              ; Context for incoming calls from this user
+;secret=blahpoly
+;host=dynamic                  ; This peer register with us
+;dtmfmode=rfc2833              ; Choices are inband, rfc2833, or info
+;username=polly                        ; Username to use in INVITE until peer registers
+                               ; Normally you do NOT need to set this parameter
+;disallow=all
+;allow=ulaw                     ; dtmfmode=inband only works with ulaw or alaw!
+;progressinband=no             ; Polycom phones don't work properly with "never"
+
+
+;[pingtel]
+;type=friend
+;secret=blah
+;host=dynamic
+;insecure=port                 ; Allow matching of peer by IP address without matching port number
+;insecure=invite               ; Do not require authentication of incoming INVITEs
+;insecure=port,invite          ; (both)
+;qualify=1000                  ; Consider it down if it's 1 second to reply
+                               ; Helps with NAT session
+                               ; qualify=yes uses default value
+;callgroup=1,3-4               ; We are in caller groups 1,3,4
+;pickupgroup=1,3-5             ; We can do call pick-p for call group 1,3,4,5
+;defaultip=192.168.0.60                ; IP address to use if peer has not registred
+
+;[cisco1]
+;type=friend
+;secret=blah
+;qualify=200                   ; Qualify peer is no more than 200ms away
+;nat=yes                       ; This phone may be natted
+                               ; Send SIP and RTP to the IP address that packet is 
+                               ; received from instead of trusting SIP headers 
+;host=dynamic                  ; This device registers with us
+;canreinvite=no                        ; Asterisk by default tries to redirect the
+                               ; RTP media stream (audio) to go directly from
+                               ; the caller to the callee.  Some devices do not
+                               ; support this (especially if one of them is 
+                               ; behind a NAT).
+;defaultip=192.168.0.4         ; IP address to use until registration
+;username=goran                        ; Username to use when calling this device before registration
+                               ; Normally you do NOT need to set this parameter
+;setvar=CUSTID=5678            ; Channel variable to be set for all calls from this device
+
+; Pre-configured SIP extensions
+
+[6011]
+type=friend
+context=default
+host=dynamic
+user=6011
+secret=6011
+canreinvite=no
+callerid=6011
+disallow=all
+allow=ulaw,g729
+qualify=yes
+
+[6012]
+type=friend
+context=default
+host=dynamic
+user=6012
+secret=6012
+canreinvite=no
+callerid=6012
+disallow=all
+allow=ulaw,g729
+
+[6013]
+type=friend
+context=default
+host=dynamic
+user=6013
+secret=6013
+canreinvite=no
+callerid=6013
+disallow=all
+allow=ulaw,g729
+
+[6014]
+type=friend
+context=default
+host=dynamic
+user=6014
+secret=6014
+canreinvite=no
+callerid=6014
+disallow=all
+allow=ulaw,g729
+
+[6015]
+type=friend
+context=default
+host=dynamic
+user=6015
+secret=6015
+canreinvite=no
+callerid=6015
+disallow=all
+allow=ulaw,g729
+
+[6016]
+type=friend
+context=default
+host=dynamic
+user=6016
+secret=6016
+canreinvite=no
+callerid=6016
+disallow=all
+allow=ulaw,g729
+
+[6017]
+type=friend
+context=default
+host=dynamic
+user=6017
+secret=6017
+canreinvite=no
+callerid=6017
+disallow=all
+allow=ulaw,g729
+
+[6018]
+type=friend
+context=default
+host=dynamic
+user=6018
+secret=6018
+canreinvite=no
+callerid=6018
+disallow=all
+allow=ulaw,g729
+
+; Pre-configured SIP trunks
+
+[voip1]
+type=friend
+context=default
+user=user
+secret=password
+host=192.168.1.28
+canreinvite=no
+disallow=all
+allow=ulaw,g729
+qualify=yes
+
index f89cf56af28bfc9a8e7f420dbd39cd964ae208eb..9e0795d057117a93a9796c3de51daebd0b2da4f7 100644 (file)
@@ -8,3 +8,16 @@
                          Emergency backdoor IP. Useful if you get locked out of the main network connection, for 
                          example due to DHCP problems on your network or a configuration mistake.  
                          Write this number down somewhere!</div>
+
+<div id="phone_phone" class="tip">
+                         Analog Phone extension: Normal telephone plugged into a port on your phone system.
+                         </div>
+<div id="phone_ipphone" class="tip">
+                         IP Phone extension: IP Phone plugged into your network.
+                         </div>
+<div id="phone_line" class="tip">
+                         Analog Phone Line: Analog telephone line plugged into a port on your phone system.
+                         </div>
+<div id="phone_voipline" class="tip">
+                         VOIP  Phone Line: Make and receive phone calls over the Internet.
+                         </div>
diff --git a/easy-asterisk-gui/voipline.jpg b/easy-asterisk-gui/voipline.jpg
new file mode 100644 (file)
index 0000000..d84b105
Binary files /dev/null and b/easy-asterisk-gui/voipline.jpg differ