web/lib/Zend/Gdata/App/LoggingHttpClientAdapterSocket.php
author Yves-Marie Haussonne <1218002+ymph@users.noreply.github.com>
Fri, 10 Jun 2011 10:13:07 +0200
changeset 172 cff6483d697a
parent 68 ecaf28ffe26e
child 207 621fa6caec0c
permissions -rw-r--r--
Added tag V00.55 for changeset 7db7d491d589

<?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_Gdata
 * @subpackage App
 * @version    $Id: LoggingHttpClientAdapterSocket.php 20096 2010-01-06 02:05:09Z bkarwin $
 * @copyright  Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
 * @license    http://framework.zend.com/license/new-bsd     New BSD License
 */

/**
 * @see Zend_Http_Client_Adapter_Socket
 */
require_once 'Zend/Http/Client/Adapter/Socket.php';

/**
 * Overrides the traditional socket-based adapter class for Zend_Http_Client to
 * enable logging of requests.  All requests are logged to a location specified
 * in the config as $config['logfile'].  Requests and responses are logged after
 * they are sent and received/processed, thus an error could prevent logging.
 *
 * @category   Zend
 * @package    Zend_Gdata
 * @subpackage App
 * @copyright  Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
 * @license    http://framework.zend.com/license/new-bsd     New BSD License
 */
class Zend_Gdata_App_LoggingHttpClientAdapterSocket extends Zend_Http_Client_Adapter_Socket
{

    /**
     * The file handle for writing logs
     *
     * @var resource|null
     */
    protected $log_handle = null;

    /**
     * Log the given message to the log file.  The log file is configured
     * as the config param 'logfile'.  This method opens the file for
     * writing if necessary.
     *
     * @param string $message The message to log
     */
    protected function log($message)
    {
        if ($this->log_handle == null) {
            $this->log_handle = fopen($this->config['logfile'], 'a');
        }
        fwrite($this->log_handle, $message);
    }

    /**
     * Connect to the remote server
     *
     * @param string  $host
     * @param int     $port
     * @param boolean $secure
     * @param int     $timeout
     */
    public function connect($host, $port = 80, $secure = false)
    {
        $this->log("Connecting to: ${host}:${port}");
        return parent::connect($host, $port, $secure);
    }

    /**
     * Send request to the remote server
     *
     * @param string        $method
     * @param Zend_Uri_Http $uri
     * @param string        $http_ver
     * @param array         $headers
     * @param string        $body
     * @return string Request as string
     */
    public function write($method, $uri, $http_ver = '1.1', $headers = array(), $body = '')
    {
        $request = parent::write($method, $uri, $http_ver, $headers, $body);
        $this->log("\n\n" . $request);
        return $request;
    }

    /**
     * Read response from server
     *
     * @return string
     */
    public function read()
    {
        $response = parent::read();
        $this->log("${response}\n\n");
        return $response;
    }

    /**
     * Close the connection to the server
     *
     */
    public function close()
    {
        $this->log("Closing socket\n\n");
        parent::close();
    }

}
PK}H$ iconolab-5012f57b6737/design/.keepmeUTbWPK}H.qԾKQ+ ]iconolab-5012f57b6737/design/components.odtUTbWPK}H#&&D }Liconolab-5012f57b6737/design/iconolab/demo/Resources/SampleStyle.cssUTbWPK}H*b~85 Miconolab-5012f57b6737/design/iconolab/demo/index.htmlUTbWPK}HG% n < dUiconolab-5012f57b6737/design/iconolab/demo/pages/addatag.pngUTbWPK}HgC [{ iconolab-5012f57b6737/design/iconolab/demo/pages/addtagwithlist.pngUTbWPK}HIYI? /? Oiconolab-5012f57b6737/design/iconolab/demo/pages/admin_tags.pngUTbWPK}H^5QC>fF iconolab-5012f57b6737/design/iconolab/demo/pages/choisir_une_image.pngUTbWPK}HFIF? iconolab-5012f57b6737/design/iconolab/demo/pages/components.pngUTbWPK}H Ficonolab-5012f57b6737/design/iconolab/demo/pages/image_tab.pngUTbWPK}H 7%VA< ~Giconolab-5012f57b6737/design/iconolab/demo/pages/landing.pngUTbWPK}H( qMҾF@ (Giconolab-5012f57b6737/design/iconolab/demo/pages/links_pages.pngUTbWPK}HC(: qHiconolab-5012f57b6737/design/iconolab/demo/pages/login.pngUTbWPK}Hw&fx B Hiconolab-5012f57b6737/design/iconolab/demo/pages/qualification.pngUTbWPK}H[(I ƽHiconolab-5012f57b6737/design/iconolab/demo/pages/save_detail_fragment.pngUTbWPK}HYjdʚ}? 9Kiconolab-5012f57b6737/design/iconolab/demo/pages/suggestion.pngUTbWPK}Hk~VG y(Liconolab-5012f57b6737/design/iconolab/demo/pages/suggestions_images.pngUTbWPK}H wBE GMiconolab-5012f57b6737/design/iconolab/demo/pages/suggestions_tags.pngUTbWPK}Hyi F Miconolab-5012f57b6737/design/iconolab/demo/pages/user_notification.pngUTbWPK}HŪQH zNiconolab-5012f57b6737/design/iconolab/demo/pages/user_notofication_2.pngUTbWPK}Hqƞ&A> Niconolab-5012f57b6737/design/iconolab/demo/pages/user_page.pngUTbWPK}H{Zs? Oiconolab-5012f57b6737/design/iconolab/demo/pages/user_pages.pngUTbWPK}H= )D NPiconolab-5012f57b6737/design/iconolab/demo/pages/user_suggestion.pngUTbWPK}H09g)M0 6Siconolab-5012f57b6737/design/iconolab/dossier.epUTbWPK}HFwPM 6 o`Siconolab-5012f57b6737/design/iconolab/ex_merge_form.epUTbWPK##SW