forked from GNUsocial/gnu-social
		
	
		
			
				
	
	
		
			159 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			159 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php 
 | |
| /**
 | |
|  * XMPPHP: The PHP XMPP Library
 | |
|  * Copyright (C) 2008  Nathanael C. Fritz
 | |
|  * This file is part of SleekXMPP.
 | |
|  * 
 | |
|  * XMPPHP is free software; you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU General Public License as published by
 | |
|  * the Free Software Foundation; either version 2 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  * 
 | |
|  * XMPPHP is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU General Public License for more details.
 | |
|  * 
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with XMPPHP; if not, write to the Free Software
 | |
|  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 | |
|  *
 | |
|  * @category   xmpphp 
 | |
|  * @package	XMPPHP
 | |
|  * @author	 Nathanael C. Fritz <JID: fritzy@netflint.net>
 | |
|  * @author	 Stephan Wentz <JID: stephan@jabber.wentz.it>
 | |
|  * @author	 Michael Garvin <JID: gar@netflint.net>
 | |
|  * @copyright  2008 Nathanael C. Fritz
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * XMPPHP XML Object
 | |
|  * 
 | |
|  * @category   xmpphp 
 | |
|  * @package	XMPPHP
 | |
|  * @author	 Nathanael C. Fritz <JID: fritzy@netflint.net>
 | |
|  * @author	 Stephan Wentz <JID: stephan@jabber.wentz.it>
 | |
|  * @author	 Michael Garvin <JID: gar@netflint.net>
 | |
|  * @copyright  2008 Nathanael C. Fritz
 | |
|  * @version	$Id$
 | |
|  */
 | |
| class XMPPHP_XMLObj {
 | |
| 	/**
 | |
| 	 * Tag name
 | |
| 	 *
 | |
| 	 * @var string
 | |
| 	 */
 | |
| 	public $name;
 | |
| 	
 | |
| 	/**
 | |
| 	 * Namespace
 | |
| 	 *
 | |
| 	 * @var string
 | |
| 	 */
 | |
| 	public $ns;
 | |
| 	
 | |
| 	/**
 | |
| 	 * Attributes
 | |
| 	 *
 | |
| 	 * @var array
 | |
| 	 */
 | |
| 	public $attrs = array();
 | |
| 	
 | |
| 	/**
 | |
| 	 * Subs?
 | |
| 	 *
 | |
| 	 * @var array
 | |
| 	 */
 | |
| 	public $subs = array();
 | |
| 	
 | |
| 	/**
 | |
| 	 * Node data
 | |
| 	 * 
 | |
| 	 * @var string
 | |
| 	 */
 | |
| 	public $data = '';
 | |
| 
 | |
| 	/**
 | |
| 	 * Constructor
 | |
| 	 *
 | |
| 	 * @param string $name
 | |
| 	 * @param string $ns
 | |
| 	 * @param array  $attrs
 | |
| 	 * @param string $data
 | |
| 	 */
 | |
| 	public function __construct($name, $ns = '', $attrs = array(), $data = '') {
 | |
| 		$this->name = strtolower($name);
 | |
| 		$this->ns   = $ns;
 | |
| 		if(is_array($attrs) && count($attrs)) {
 | |
| 			foreach($attrs as $key => $value) {
 | |
| 				$this->attrs[strtolower($key)] = $value;
 | |
| 			}
 | |
| 		}
 | |
| 		$this->data = $data;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Dump this XML Object to output.
 | |
| 	 *
 | |
| 	 * @param integer $depth
 | |
| 	 */
 | |
| 	public function printObj($depth = 0) {
 | |
| 		print str_repeat("\t", $depth) . $this->name . " " . $this->ns . ' ' . $this->data;
 | |
| 		print "\n";
 | |
| 		foreach($this->subs as $sub) {
 | |
| 			$sub->printObj($depth + 1);
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Return this XML Object in xml notation
 | |
| 	 *
 | |
| 	 * @param string $str
 | |
| 	 */
 | |
| 	public function toString($str = '') {
 | |
| 		$str .= "<{$this->name} xmlns='{$this->ns}' ";
 | |
| 		foreach($this->attrs as $key => $value) {
 | |
| 			if($key != 'xmlns') {
 | |
| 				$value = htmlspecialchars($value);
 | |
| 				$str .= "$key='$value' ";
 | |
| 			}
 | |
| 		}
 | |
| 		$str .= ">";
 | |
| 		foreach($this->subs as $sub) {
 | |
| 			$str .= $sub->toString();
 | |
| 		}
 | |
| 		$body = htmlspecialchars($this->data);
 | |
| 		$str .= "$body</{$this->name}>";
 | |
| 		return $str;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Has this XML Object the given sub?
 | |
| 	 * 
 | |
| 	 * @param string $name
 | |
| 	 * @return boolean
 | |
| 	 */
 | |
| 	public function hasSub($name, $ns = null) {
 | |
| 		foreach($this->subs as $sub) {
 | |
| 			if(($name == "*" or $sub->name == $name) and ($ns == null or $sub->ns == $ns)) return true;
 | |
| 		}
 | |
| 		return false;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Return a sub
 | |
| 	 *
 | |
| 	 * @param string $name
 | |
| 	 * @param string $attrs
 | |
| 	 * @param string $ns
 | |
| 	 */
 | |
| 	public function sub($name, $attrs = null, $ns = null) {
 | |
| 		#TODO attrs is ignored
 | |
| 		foreach($this->subs as $sub) {
 | |
| 			if($sub->name == $name and ($ns == null or $sub->ns == $ns)) {
 | |
| 				return $sub;
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| }
 |