forked from FreePBX/sipsettings
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinstall.php
104 lines (92 loc) · 3.4 KB
/
install.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
<?php
/* $Id:$ */
if (!defined('FREEPBX_IS_AUTH')) { die('No direct script access allowed'); }
// Original Release by Philippe Lindheimer
// Copyright Philippe Lindheimer (2009)
// Copyright Bandwidth.com (2009)
/*
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as
published by the Free Software Foundation, either version 3 of the
License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
global $db;
global $amp_conf;
$sql = <<< END
CREATE TABLE IF NOT EXISTS `sipsettings` (
`keyword` VARCHAR (50) NOT NULL default '',
`data` VARCHAR (255) NOT NULL default '',
`seq` TINYINT (1),
`type` TINYINT (1) NOT NULL default '0',
PRIMARY KEY (`keyword`,`seq`,`type`)
)
END;
outn(_("checking for sipsettings table.."));
$tsql = "SELECT * FROM `sipsettings` limit 1";
$check = $db->getRow($tsql, DB_FETCHMODE_ASSOC);
if(DB::IsError($check)) {
out(_("none, creating table"));
// table does not exist, create it
sql($sql);
outn(_("populating default codecs.."));
$sip_settings = array(
array('ulaw' ,'1', '0'),
array('alaw' ,'2', '1'),
array('slin' ,'' , '2'),
array('g726' ,'' , '3'),
array('gsm' ,'3', '4'),
array('g729' ,'' , '5'),
array('ilbc' ,'' , '6'),
array('g723' ,'' , '7'),
array('g726aal2','' , '8'),
array('adpcm' ,'' , '9'),
array('lpc10' ,'' ,'10'),
array('speex' ,'' ,'11'),
array('g722' ,'' ,'12'),
);
// Now insert minimal codec rows
$compiled = $db->prepare("INSERT INTO sipsettings (keyword, data, seq, type) values (?,?,?,'1')");
$result = $db->executeMultiple($compiled,$sip_settings);
if(DB::IsError($result)) {
out(_("fatal error occurred populating defaults, check module"));
} else {
out(_("ulaw, alaw, gsm added"));
}
} else {
out(_("already exists"));
}
out(_("Migrate rtp.conf values if needed and initialize"));
$sql = "SELECT data FROM sipsettings WHERE keyword = 'rtpstart'";
$rtpstart = sql($sql,'getOne');
if (!$rtpstart) {
$sql = "SELECT value FROM admin WHERE variable = 'RTPSTART'";
$rtpstart = sql($sql,'getOne');
if ($rtpstart) {
out(sprintf(_("saving previous value of %s"), $rtpstart));
} else {
$rtpstart = '10000';
out(sprintf(_("setting default value of %s"), $rtpstart));
}
sql("REPLACE INTO sipsettings (keyword, data, seq, type) VALUES ('rtpstart','$rtpstart','0','0')");
}
$sql = "SELECT data FROM sipsettings WHERE keyword = 'rtpend'";
$rtpend = sql($sql,'getOne');
if (!$rtpend) {
$sql = "SELECT value FROM admin WHERE variable = 'RTPEND'";
$rtpend = sql($sql,'getOne');
if ($rtpend) {
out(sprintf(_("saving previous value of %s"), $rtpend));
} else {
$rtpend = '20000';
out(sprintf(_("setting default value of %s"), $rtpend));
}
sql("REPLACE INTO sipsettings (keyword, data, seq, type) values ('rtpend','$rtpend','1','0')");
}
// One way or another we've converted so we remove the interim variable from admin
sql("DELETE FROM admin WHERE variable IN ('RTPSTART', 'RTPEND')");