Add analytics
[bus.git] / busui / owa / modules / base / metrics / topReferers.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
<?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$
//
 
/**
 * Top Referers Metric
 * 
 * @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_topReferers extends owa_metric {
        
        function owa_topReferers($params = null) {
                
                return owa_topReferers::__construct($params);
                
        }
        
        function __construct($params = '') {
        
                return parent::__construct($params);
        }
        
        function calculate() {
                
                $this->db->selectColumn("count(referer.id) as count,
                                                                        sum(session.num_pageviews) as page_views,
                                                                        url,
                                                                        page_title,
                                                                        site_name,
                                                                        query_terms,
                                                                        snippet,
                                                                        refering_anchortext,
                                                                        is_searchengine");
                                                                        
                $this->db->selectFrom('owa_session', 'session');        
                $this->db->join(OWA_SQL_JOIN_LEFT_OUTER, 'owa_referer', 'referer', 'referer_id', 'referer.id');         
                $this->db->groupBy('referer.url');              
                $this->db->orderBy('count', $this->getOrder()); 
                $this->db->where('is_searchengine', 1, '!=');
                
                $ret = $this->db->getAllRows();
 
                return $ret;
 
        }
        
        function paginationCount() {
        
                $this->db->selectColumn("count(distinct referer.id) as count");
                                                                        
                $this->db->selectFrom('owa_session', 'session');        
                $this->db->join(OWA_SQL_JOIN_LEFT_OUTER, 'owa_referer', 'referer', 'referer_id', 'referer.id');                 
                $this->db->where('is_searchengine', 1, '!=');
                
                $ret = $this->db->getOneRow();
 
                return $ret['count'];
 
        
        }
        
        
}
 
 
?>