125 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			125 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
/**
 | 
						|
 * FeedDate is an internal class that stores a date for a feed or feed item.
 | 
						|
 * Usually, you won't need to use this.
 | 
						|
 */
 | 
						|
class FeedDate
 | 
						|
{
 | 
						|
    protected $unix;
 | 
						|
 | 
						|
    /**
 | 
						|
     * Creates a new instance of FeedDate representing a given date.
 | 
						|
     * Accepts RFC 822, ISO 8601 date formats as well as unix time stamps.
 | 
						|
     *
 | 
						|
     * @param mixed $dateString optional the date this FeedDate will represent. If not specified, the current date and
 | 
						|
     *                          time is used.
 | 
						|
     */
 | 
						|
    public function __construct($dateString = "")
 | 
						|
    {
 | 
						|
        if ($dateString == "") {
 | 
						|
            $dateString = date("r");
 | 
						|
        }
 | 
						|
 | 
						|
        if (is_integer($dateString)) {
 | 
						|
            $this->unix = $dateString;
 | 
						|
 | 
						|
            return;
 | 
						|
        }
 | 
						|
        $tzOffset = 0;
 | 
						|
        if (preg_match(
 | 
						|
            "~(?:(?:Mon|Tue|Wed|Thu|Fri|Sat|Sun),\\s+)?(\\d{1,2})\\s+([a-zA-Z]{3})\\s+(\\d{4})\\s+(\\d{2}):(\\d{2}):(\\d{2})\\s+(.*)~",
 | 
						|
            $dateString,
 | 
						|
            $matches
 | 
						|
        )) {
 | 
						|
            $months = Array(
 | 
						|
                "Jan" => 1,
 | 
						|
                "Feb" => 2,
 | 
						|
                "Mar" => 3,
 | 
						|
                "Apr" => 4,
 | 
						|
                "May" => 5,
 | 
						|
                "Jun" => 6,
 | 
						|
                "Jul" => 7,
 | 
						|
                "Aug" => 8,
 | 
						|
                "Sep" => 9,
 | 
						|
                "Oct" => 10,
 | 
						|
                "Nov" => 11,
 | 
						|
                "Dec" => 12,
 | 
						|
            );
 | 
						|
            $this->unix = mktime($matches[4], $matches[5], $matches[6], $months[$matches[2]], $matches[1], $matches[3]);
 | 
						|
            if (substr($matches[7], 0, 1) == '+' OR substr($matches[7], 0, 1) == '-') {
 | 
						|
                $tzOffset = (((int)substr($matches[7], 0, 3) * 60) + (int)substr($matches[7], -2)) * 60;
 | 
						|
            } else {
 | 
						|
                if (strlen($matches[7]) == 1) {
 | 
						|
                    $oneHour = 3600;
 | 
						|
                    $ord = ord($matches[7]);
 | 
						|
                    if ($ord < ord("M")) {
 | 
						|
                        $tzOffset = (ord("A") - $ord - 1) * $oneHour;
 | 
						|
                    } elseif ($ord >= ord("M") AND $matches[7] != "Z") {
 | 
						|
                        $tzOffset = ($ord - ord("M")) * $oneHour;
 | 
						|
                    } elseif ($matches[7] == "Z") {
 | 
						|
                        $tzOffset = 0;
 | 
						|
                    }
 | 
						|
                }
 | 
						|
                switch ($matches[7]) {
 | 
						|
                    case "UT":
 | 
						|
                    case "GMT":
 | 
						|
                        $tzOffset = 0;
 | 
						|
                }
 | 
						|
            }
 | 
						|
            $this->unix += $tzOffset;
 | 
						|
 | 
						|
            return;
 | 
						|
        }
 | 
						|
        if (preg_match("~(\\d{4})-(\\d{2})-(\\d{2})T(\\d{2}):(\\d{2}):(\\d{2})(.*)~", $dateString, $matches)) {
 | 
						|
            $this->unix = mktime($matches[4], $matches[5], $matches[6], $matches[2], $matches[3], $matches[1]);
 | 
						|
            if (substr($matches[7], 0, 1) == '+' OR substr($matches[7], 0, 1) == '-') {
 | 
						|
                $tzOffset = (((int)substr($matches[7], 0, 3) * 60) + (int)substr($matches[7], -2)) * 60;
 | 
						|
            } else {
 | 
						|
                if ($matches[7] == "Z") {
 | 
						|
                    $tzOffset = 0;
 | 
						|
                }
 | 
						|
            }
 | 
						|
            $this->unix += $tzOffset;
 | 
						|
 | 
						|
            return;
 | 
						|
        }
 | 
						|
        $this->unix = 0;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Gets the date stored in this FeedDate as an RFC 822 date.
 | 
						|
     *
 | 
						|
     * @return string a date in RFC 822 format
 | 
						|
     */
 | 
						|
    public function rfc822()
 | 
						|
    {
 | 
						|
        //return gmdate("r",$this->unix);
 | 
						|
        $date = gmdate("D, d M Y H:i:s O", $this->unix);
 | 
						|
 | 
						|
        return $date;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Gets the date stored in this FeedDate as an ISO 8601 date.
 | 
						|
     *
 | 
						|
     * @return string a date in ISO 8601 format
 | 
						|
     */
 | 
						|
    public function iso8601()
 | 
						|
    {
 | 
						|
        $date = gmdate("Y-m-d\TH:i:sP", $this->unix);
 | 
						|
 | 
						|
        return $date;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Gets the date stored in this FeedDate as unix time stamp.
 | 
						|
     *
 | 
						|
     * @return int a date as a unix time stamp
 | 
						|
     */
 | 
						|
    public function unix()
 | 
						|
    {
 | 
						|
        return $this->unix;
 | 
						|
    }
 | 
						|
}
 |