Blame view

protected/extensions/feed/EFeedItemRSS2.php 3 KB
a1684257   Administrator   first commit
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
  <?php
  /**
   * EFeedItemRSS2 Class file
   * @author Antonio Ramirez 
   * @link http://www.ramirezcobos.com 
   * 
   * 
   * THIS SOFTWARE IS PROVIDED BY THE CONTRIBUTORS "AS IS" AND
   * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
   * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
   * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
   * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
   * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
   * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
   * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
   * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
   * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
   */
  /**
   * EFeedItemRSS2 is an element of an RSS 2.0 Feed
   *
   * @author		Antonio Ramirez <ramirez.cobos@gmail.com>
   * @package   	rss
   * @uses 		CUrlValidator
   * @throws 		CException
   */
  class EFeedItemRSS2 extends EFeedItemAbstract{
  	/**
  	 * (non-PHPdoc)
  	 * @see EFeedItemAbstract::setDate()
  	 */
  	public function setDate( $date ){
  		if(!is_numeric( $date )) $date = strtotime( $date );
  		
  		$date = date( DATE_RSS, $date );
  		
  		$this->addTag( 'pubDate', $date );
  	}
  	/**
  	 * 
  	 * Property getter date
  	 * @return value of date | null
  	 */
  	public function getDate(){
  		return $this->tags->itemAt('pubDate');
  	}
  	/**
  	 * (non-PHPdoc)
  	 * @see EFeedItemAbstract::getNode()
  	 */
  	public function getNode(){
  	
  		
  		$node = CHtml::openTag('item').PHP_EOL;
  		
  		foreach( $this->tags as $tag ){
  			$node .= $this->getElement($tag);
  		}
  
  		$node .= CHtml::closeTag('item');
  		
  		return $node.PHP_EOL;
  	}
  	/**
  	 * 
  	 * @returns well formatted xml element
  	 * @param EFeedTag $tag
  	 */
  	private function getElement( EFeedTag $tag ){
  		
  		$element = '';
  		
  		if(in_array($tag->name,$this->CDATAEncoded))
  		{
  			$element .= CHtml::openTag($tag->name,$tag->attributes);
  			$element .= '<![CDATA[';
  			
  		}else 
  		{
  			$element .= CHtml::openTag($tag->name,$tag->attributes);
  		}
  		$element .= PHP_EOL;
  		
  		if(is_array($tag->content))
  		{ 
  			foreach ($tag->content as $tag => $content) 
  			{
  				$tmpTag = new EFeedTag($tag, $content);
  				
  				$element .= $this->getElement( $tmpTag );
  			}
  		}
  		else
  		{
  			$element .= (in_array($tag->name, $this->CDATAEncoded))? $tag->content : CHtml::encode($tag->content);
  		}           
  			
  		$element .= (in_array($tag->name, $this->CDATAEncoded))? PHP_EOL.']]>':"";
  		
  		$element .= CHtml::closeTag($tag->name).PHP_EOL;
  		
  		return $element;
  	}
  	/**
  	 * 
  	 * Set the 'encloser' element of feed item
  	 * 
  	 * @param    string  The url attribute of encloser tag
  	 * @param    string  The length attribute of encloser tag
  	 * @param    string  The type attribute of encloser tag
  	 */
  	public function setEncloser($url, $length, $type)
  	{
  		$attributes = array('url'=>$url, 'length'=>$length, 'type'=>$type);
  		
  		$this->addTag('enclosure','',$attributes);
  	}
  }