Вход Регистрация
Файл: includes/classes/swiftmailer/classes/Swift/Plugins/ThrottlerPlugin.php
Строк: 158
<?php

/*
 * This file is part of SwiftMailer.
 * (c) 2004-2009 Chris Corbyn
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

/**
 * Throttles the rate at which emails are sent.
 *
 * @author Chris Corbyn
 */
class Swift_Plugins_ThrottlerPlugin extends Swift_Plugins_BandwidthMonitorPlugin implements Swift_Plugins_SleeperSwift_Plugins_Timer
{
    
/** Flag for throttling in bytes per minute */
    
const BYTES_PER_MINUTE 0x01;

    
/** Flag for throttling in emails per second (Amazon SES) */
    
const MESSAGES_PER_SECOND 0x11;

    
/** Flag for throttling in emails per minute */
    
const MESSAGES_PER_MINUTE 0x10;

    
/**
     * The Sleeper instance for sleeping.
     *
     * @var Swift_Plugins_Sleeper
     */
    
private $_sleeper;

    
/**
     * The Timer instance which provides the timestamp.
     *
     * @var Swift_Plugins_Timer
     */
    
private $_timer;

    
/**
     * The time at which the first email was sent.
     *
     * @var int
     */
    
private $_start;

    
/**
     * The rate at which messages should be sent.
     *
     * @var int
     */
    
private $_rate;

    
/**
     * The mode for throttling.
     *
     * This is {@link BYTES_PER_MINUTE} or {@link MESSAGES_PER_MINUTE}
     *
     * @var int
     */
    
private $_mode;

    
/**
     * An internal counter of the number of messages sent.
     *
     * @var int
     */
    
private $_messages 0;

    
/**
     * Create a new ThrottlerPlugin.
     *
     * @param int                   $rate
     * @param int                   $mode,   defaults to {@link BYTES_PER_MINUTE}
     * @param Swift_Plugins_Sleeper $sleeper (only needed in testing)
     * @param Swift_Plugins_Timer   $timer   (only needed in testing)
     */
    
public function __construct($rate$mode self::BYTES_PER_MINUTESwift_Plugins_Sleeper $sleeper nullSwift_Plugins_Timer $timer null)
    {
        
$this->_rate $rate;
        
$this->_mode $mode;
        
$this->_sleeper $sleeper;
        
$this->_timer $timer;
    }

    
/**
     * Invoked immediately before the Message is sent.
     *
     * @param Swift_Events_SendEvent $evt
     */
    
public function beforeSendPerformed(Swift_Events_SendEvent $evt)
    {
        
$time $this->getTimestamp();
        if (!isset(
$this->_start)) {
            
$this->_start $time;
        }
        
$duration $time $this->_start;

        switch (
$this->_mode) {
            case 
self::BYTES_PER_MINUTE :
                
$sleep $this->_throttleBytesPerMinute($duration);
                break;
            case 
self::MESSAGES_PER_SECOND :
                
$sleep $this->_throttleMessagesPerSecond($duration);
                break;
            case 
self::MESSAGES_PER_MINUTE :
                
$sleep $this->_throttleMessagesPerMinute($duration);
                break;
            default :
                
$sleep 0;
                break;
        }

        if (
$sleep 0) {
            
$this->sleep($sleep);
        }
    }

    
/**
     * Invoked when a Message is sent.
     *
     * @param Swift_Events_SendEvent $evt
     */
    
public function sendPerformed(Swift_Events_SendEvent $evt)
    {
        
parent::sendPerformed($evt);
        ++
$this->_messages;
    }

    
/**
     * Sleep for $seconds.
     *
     * @param int $seconds
     */
    
public function sleep($seconds)
    {
        if (isset(
$this->_sleeper)) {
            
$this->_sleeper->sleep($seconds);
        } else {
            
sleep($seconds);
        }
    }

    
/**
     * Get the current UNIX timestamp.
     *
     * @return int
     */
    
public function getTimestamp()
    {
        if (isset(
$this->_timer)) {
            return 
$this->_timer->getTimestamp();
        }

        return 
time();
    }

    
/**
     * Get a number of seconds to sleep for.
     *
     * @param int $timePassed
     *
     * @return int
     */
    
private function _throttleBytesPerMinute($timePassed)
    {
        
$expectedDuration $this->getBytesOut() / ($this->_rate 60);

        return (int) 
ceil($expectedDuration $timePassed);
    }

    
/**
     * Get a number of seconds to sleep for.
     *
     * @param int $timePassed
     *
     * @return int
     */
    
private function _throttleMessagesPerSecond($timePassed)
    {
        
$expectedDuration $this->_messages / ($this->_rate);

        return (int) 
ceil($expectedDuration $timePassed);
    }

    
/**
     * Get a number of seconds to sleep for.
     *
     * @param int $timePassed
     *
     * @return int
     */
    
private function _throttleMessagesPerMinute($timePassed)
    {
        
$expectedDuration $this->_messages / ($this->_rate 60);

        return (int) 
ceil($expectedDuration $timePassed);
    }
}
Онлайн: 2
Реклама