Add analytics
[bus.git] / busui / owa / modules / base / reportVisitorsRoster.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
<?php
 
//
// Open Web Analytics - An Open Source Web Analytics Framework
//
// Copyright 2006 Peter Adams. All rights reserved.
//
// Licensed under GPL v2.0 http://www.gnu.org/copyleft/gpl.html
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
// $Id$
//
 
require_once(OWA_BASE_DIR.'/owa_lib.php');
require_once(OWA_BASE_DIR.'/owa_view.php');
require_once(OWA_BASE_DIR.'/owa_reportController.php');
 
/**
 * Visitors Roster Report Controller
 * 
 * @author      Peter Adams <peter@openwebanalytics.com>
 * @copyright   Copyright &copy; 2006 Peter Adams <peter@openwebanalytics.com>
 * @license     http://www.gnu.org/copyleft/gpl.html GPL v2.0
 * @category    owa
 * @package     owa
 * @version             $Revision$            
 * @since               owa 1.0.0
 * @depricated
 * @todo                remove
 */
 
class owa_reportVisitorsRosterController extends owa_reportController {
                
        function __construct($params) {
        
                $this->priviledge_level = 'viewer';
                return parent::__construct($params);
        }
        
        function action() {
                
                
                $db = owa_coreAPI::dbSingleton();
                
                $db->selectColumn("distinct session.visitor_id as visitor_id, visitor.user_name, visitor.user_email");
                $db->selectFrom('owa_session', 'session');
                $db->join(OWA_SQL_JOIN_LEFT_OUTER, 'owa_visitor', 'visitor', 'visitor_id', 'visitor.id');
        
                $db->where('site_id', $this->getParam('site_id'));
                
                // make new timeperiod of a day
                $period = owa_coreAPI::makeTimePeriod('day', array('startDate' => $this->getParam('first_session')));
                $start = $period->getStartDate();
                $end = $period->getEndDate();
                //print_r($period);
                // set new period so lables show up right.
                $db->where('first_session_timestamp', 
                                   array('start' => $start->getTimestamp(), 'end' => $end->getTimestamp()), 
                                   'BETWEEN');
                
                $ret = $db->getAllRows();
        
                $this->set('visitors', $ret);   
                $this->setSubview('base.reportVisitorsRoster');
                $this->setTitle('New Visitors from', $period->getStartDate()->label);           
        }
        
}
 
/**
 * Visitors Roster Report View
 * 
 * @author      Peter Adams <peter@openwebanalytics.com>
 * @copyright   Copyright &copy; 2006 Peter Adams <peter@openwebanalytics.com>
 * @license     http://www.gnu.org/copyleft/gpl.html GPL v2.0
 * @category    owa
 * @package     owa
 * @version             $Revision$            
 * @since               owa 1.0.0
 */
 
class owa_reportVisitorsRosterView extends owa_view {
                
        function render($data) {
                
                $this->body->set_template('report_visitors_roster.tpl');        
                $this->body->set('headline', 'Visitors');
                $this->body->set('visitors', $data['visitors']);
        }
}
 
?>