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 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 | <?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$ // if(!class_exists('owa_observer')) { require_once(OWA_BASE_DIR.'owa_observer.php'); } /** * Request Event Handler * * @author Peter Adams <peter@openwebanalytics.com> * @copyright Copyright © 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_requestHandlers extends owa_observer { /** * Notify Handler * * @access public * @param object $event */ function notify($event) { $r = owa_coreAPI::entityFactory('base.request'); $r->load( $event->get('guid') ); if ( ! $r->wasPersisted() ) { $r->setProperties($event->getProperties()); // Set Primary Key $r->set('id', $event->get('guid')); // Make ua id $r->set('ua_id', owa_lib::setStringGuid($event->get('HTTP_USER_AGENT'))); // Make OS id $r->set('os_id', owa_lib::setStringGuid($event->get('os'))); // Make document id $r->set('document_id', owa_lib::setStringGuid($event->get('page_url'))); // Make prior document id $r->set('prior_document_id', owa_lib::setStringGuid($event->get('prior_page'))); // Generate Referer id $r->set('referer_id', owa_lib::setStringGuid($event->get('HTTP_REFERER'))); // Generate Host id $r->set('host_id', owa_lib::setStringGuid($event->get('full_host'))); // Generate Host id $r->set('num_prior_sessions', $event->get('num_prior_sessions')); $r->set('language', $event->get('language')); if ( ! $event->get( 'country' ) ) { $location = owa_coreAPI::getGeolocationFromIpAddress( $event->get( 'ip_address' ) ); owa_coreAPI::debug( 'geolocation: ' .print_r( $location, true ) ); $event->set( 'country', $location->getCountry() ); $event->set( 'city', $location->getCity() ); $event->set( 'latitude', $location->getLatitude() ); $event->set( 'longitude', $location->getLongitude() ); $event->set( 'country_code', $location->getCountryCode() ); $event->set( 'state', $location->getState() ); $location_id = $location->generateId(); } else { $s = owa_coreAPI::serviceSingleton(); $location_id = $s->geolocation->generateId($event->get( 'country' ), $event->get( 'state' ), $event->get( 'city' ) ); } if ($location_id) { $event->set( 'location_id', $location_id ); $r->set( 'location_id', $event->get( 'location_id' ) ); } $result = $r->create(); if ($result == true) { $eq = owa_coreAPI::getEventDispatch(); $nevent = $eq->makeEvent($event->getEventType().'_logged'); $nevent->setProperties($event->getProperties()); $eq->asyncNotify($nevent); return OWA_EHS_EVENT_HANDLED; } else { return OWA_EHS_EVENT_FAILED; } } else { owa_coreAPI::debug('Not persisting. Request already exists.'); return OWA_EHS_EVENT_HANDLED; } } } ?> |