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
|
<?php
/**
* Zend Framework
*
* LICENSE
*
* This source file is subject to the new BSD license that is bundled
* with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* http://framework.zend.com/license/new-bsd
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to license@zend.com so we can send you a copy immediately.
*
* @category Zend
* @package Zend_Service_WindowsAzure
* @subpackage Storage
* @copyright Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
* @version $Id$
*/
/**
* @see Zend_Log_Formatter_Interface
*/
require_once 'Zend/Log/Formatter/Interface.php';
/**
* @see Zend_Service_WindowsAzure_Storage_DynamicTableEntity
*/
require_once 'Zend/Service/WindowsAzure/Storage/DynamicTableEntity.php';
/**
* @category Zend
* @package Zend_Service_WindowsAzure
* @subpackage Log
* @copyright Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
*/
class Zend_Service_WindowsAzure_Log_Formatter_WindowsAzure
implements Zend_Log_Formatter_Interface
{
/**
* Write a message to the table storage
*
* @param array $event
*
* @return Zend_Service_WindowsAzure_Storage_DynamicTableEntity
*/
public function format($event)
{
// partition key is the current date, represented as YYYYMMDD
// row key will always be the current timestamp. These values MUST be hardcoded.
$logEntity = new Zend_Service_WindowsAzure_Storage_DynamicTableEntity(
date('Ymd'), microtime(true)
);
// Windows Azure automatically adds the timestamp, but the timezone is most of the time
// different compared to the origin server's timezone, so add this timestamp aswell.
$event['server_timestamp'] = $event['timestamp'];
unset($event['timestamp']);
foreach ($event as $key => $value) {
if ((is_object($value) && !method_exists($value, '__toString'))
|| is_array($value)
) {
$value = gettype($value);
}
$logEntity->{$key} = $value;
}
return $logEntity;
}
}
|