forked from openbroadcaster/mapping
-
Notifications
You must be signed in to change notification settings - Fork 0
/
module.php
94 lines (72 loc) · 3.36 KB
/
module.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
<?
/*
Copyright 2012 OpenBroadcaster, Inc.
This file is part of OpenBroadcaster Server.
OpenBroadcaster Server 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.
OpenBroadcaster Server 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 OpenBroadcaster Server. If not, see <http://www.gnu.org/licenses/>.
*/
class DeviceMapModule extends OBFModule
{
public $name = 'Device Map';
public $description = 'Provide a map displaying location of EMS Alerts and status of OpenBroadcaster devices.';
public function callbacks()
{
}
public function install()
{
$this->db->query('ALTER TABLE devices ADD COLUMN(`longitude` decimal(8,5) NOT NULL DEFAULT -134.25921)');
$this->db->query('ALTER TABLE devices ADD COLUMN(`latitude` decimal(8,5) NOT NULL DEFAULT 60.29280)');
$this->db->query('UPDATE devices SET longitude=-134.2592146, lattude=60.2928019');
/*
$this->db->query('CREATE TABLE IF NOT EXISTS `module_map_bases` (
`baselayer` varchar(255) NOT NULL,
PRIMARY KEY (`baselayer`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ;');
$this->db->query('CREATE TABLE `module_device_map` (
`device_id` int(10) unsigned NOT NULL,
`zoomlevel` tinyint(4) NOT NULL DEFAULT "3",
`baselayer` varchar(255) NOT NULL,
`latitude` float NOT NULL DEFAULT "60.246",
`longitude` float NOT NULL DEFAULT "-134.531",
PRIMARY KEY (`device_id`),
KEY `module_device_map_ibfk_1` (`baselayer`),
CONSTRAINT `module_device_map_ibfk_1` FOREIGN KEY (`baselayer`) REFERENCES `module_map_bases` (`baselayer`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;');
$this->db->query('INSERT INTO obs.module_map_bases (baselayer) VALUES ("OSMBase")');
$this->db->query('INSERT INTO obs.module_device_map (device_id,baselayer) SELECT devices.id,"OSMBase" from devices;');
*/
//View permission
$data = array();
$data['name'] = 'view_map';
$data['description'] = 'view map';
$data['category'] = 'device';
$this->db->insert('users_permissions',$data);
//Edit permission
$data = array();
$data['name'] = 'edit_map';
$data['description'] = 'edit map defaults';
$data['category'] = 'device';
$this->db->insert('users_permissions',$data);
return true;
}
public function uninstall()
{
// $this->db->query('ALTER TABLE devices DROP COLUMN `longitude`');
// $this->db->query('ALTER TABLE devices DROP COLUMN `latitude`');
// $this->db->query('DROP TABLE `module_device_map`');
// $this->db->query('DROP TABLE `module_map_bases`');
$this->db->where('name','view_map');
$this->db->delete('users_permissions');
$this->db->where('name','edit_map');
$this->db->delete('users_permissions');
return true;
}
}