Move busui to seperate repository
[bus.git] / processRequest.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
<?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_controller.php');
require_once(OWA_BASE_MODULE_DIR.'processEvent.php');
 
/**
 * 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
 */
 
class owa_processRequestController extends owa_processEventController {
        
        function __construct($params) {
                        
                return parent::__construct($params);
        }
        
        function action() {
                
                // Control logic
                
                // Do not log if the first_hit cookie is still present.
        $fh_state_name = owa_coreAPI::getSetting('base', 'first_hit_param');
                $fh = owa_coreAPI::getStateParam($fh_state_name);
        
        if (!empty($fh)) {
                $this->e->debug('Clearing left over first first hit cookie.');
                        owa_coreAPI::clearState($fh_state_name);
                        $this->e->debug('Left over first first hit cookie found...aborting request as likely a robot.');
                        $this->event->set('do_not_log', true);
                        return;
                }
                
                // set variety of new session properties.
                if ($this->event->get('is_new_session')) {
                        
                }       
        }
        
        function post() {
                                
                if ( owa_coreAPI::getSetting('base', 'delay_first_hit') ) {     
                        
                        // If not, then make sure that there is an inbound visitor_id
                        if ( ! $this->event->get( 'visitor_id' ) ) {
                                // Log request properties to a cookie for processing by a second request and return
                                owa_coreAPI::debug('Logging this request to first hit cookie.');
                                return $this->log_first_hit();
                        }
                }
                
                owa_coreAPI::debug('Logging '.$this->event->getEventType().' to event queue...');
                
                return $this->addToEventQueue();
        }
}
 
?>