forked from GNUsocial/gnu-social
		
	
		
			
				
	
	
		
			140 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			140 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| /**
 | |
|  * Base class for oEmbed objects
 | |
|  *
 | |
|  * PHP version 5.1.0+
 | |
|  *
 | |
|  * Copyright (c) 2008, Digg.com, Inc.
 | |
|  * 
 | |
|  * All rights reserved.
 | |
|  * 
 | |
|  * Redistribution and use in source and binary forms, with or without 
 | |
|  * modification, are permitted provided that the following conditions are met:
 | |
|  *
 | |
|  *  - Redistributions of source code must retain the above copyright notice,
 | |
|  *    this list of conditions and the following disclaimer.
 | |
|  *  - Redistributions in binary form must reproduce the above copyright notice,
 | |
|  *    this list of conditions and the following disclaimer in the documentation
 | |
|  *    and/or other materials provided with the distribution.
 | |
|  *  - Neither the name of Digg.com, Inc. nor the names of its contributors 
 | |
|  *    may be used to endorse or promote products derived from this software 
 | |
|  *    without specific prior written permission.
 | |
|  *
 | |
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND 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.
 | |
|  *
 | |
|  * @category  Services
 | |
|  * @package   Services_oEmbed
 | |
|  * @author    Joe Stump <joe@joestump.net> 
 | |
|  * @copyright 2008 Digg.com, Inc.
 | |
|  * @license   http://tinyurl.com/42zef New BSD License
 | |
|  * @version   SVN: @version@
 | |
|  * @link      http://code.google.com/p/digg
 | |
|  * @link      http://oembed.com
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * Base class for oEmbed objects
 | |
|  *
 | |
|  * @category  Services
 | |
|  * @package   Services_oEmbed
 | |
|  * @author    Joe Stump <joe@joestump.net> 
 | |
|  * @copyright 2008 Digg.com, Inc.
 | |
|  * @license   http://tinyurl.com/42zef New BSD License
 | |
|  * @version   Release: @version@
 | |
|  * @link      http://code.google.com/p/digg
 | |
|  * @link      http://oembed.com
 | |
|  */
 | |
| abstract class Services_oEmbed_Object_Common
 | |
| {
 | |
|     /**
 | |
|      * Raw object returned from API
 | |
|      *
 | |
|      * @var object $object The raw object from the API
 | |
|      */
 | |
|     protected $object = null;
 | |
| 
 | |
|     /**
 | |
|      * Required fields per the specification
 | |
|      *
 | |
|      * @var array $required Array of required fields
 | |
|      * @link http://oembed.com
 | |
|      */
 | |
|     protected $required = array();
 | |
| 
 | |
|     /**
 | |
|      * Constructor
 | |
|      *
 | |
|      * @param object $object Raw object returned from the API
 | |
|      *
 | |
|      * @throws {@link Services_oEmbed_Object_Exception} on missing fields
 | |
|      * @return void
 | |
|      */
 | |
|     public function __construct($object)
 | |
|     {
 | |
|         $this->object = $object;
 | |
| 
 | |
|         $this->required[] = 'version';
 | |
|         foreach ($this->required as $field) {
 | |
|             if (!isset($this->$field)) {
 | |
|                 throw new Services_oEmbed_Object_Exception(
 | |
|                     'Object is missing required ' . $field . ' attribute'
 | |
|                 );
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get object variable
 | |
|      *
 | |
|      * @param string $var Variable to get
 | |
|      *
 | |
|      * @see Services_oEmbed_Object_Common::$object
 | |
|      * @return mixed Attribute's value or null if it's not set/exists
 | |
|      */
 | |
|     public function __get($var)
 | |
|     {
 | |
|         if (property_exists($this->object, $var)) {
 | |
|             return $this->object->$var;
 | |
|         }
 | |
| 
 | |
|         return null;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Is variable set?
 | |
|      *
 | |
|      * @param string $var Variable name to check
 | |
|      * 
 | |
|      * @return boolean True if set, false if not
 | |
|      * @see Services_oEmbed_Object_Common::$object
 | |
|      */
 | |
|     public function __isset($var)
 | |
|     {
 | |
|         if (property_exists($this->object, $var)) {
 | |
|             return (isset($this->object->$var));
 | |
|         }
 | |
| 
 | |
|         return false;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Require a sane __toString for all objects
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     abstract public function __toString();
 | |
| }
 | |
| 
 | |
| ?>
 |