You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
115 lines
3.7 KiB
115 lines
3.7 KiB
2 years ago
|
<?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_XMPP
|
||
|
*
|
||
|
* This file is unnecessary unless you need to connect to older, non-XMPP-compliant servers like Dreamhost's.
|
||
|
* In this case, use instead of XMPPHP_XMPP, otherwise feel free to delete it.
|
||
|
* The old Jabber protocol wasn't standardized, so use at your own risk.
|
||
|
*
|
||
|
*/
|
||
|
require_once "XMPP.php";
|
||
|
|
||
|
class XMPPHP_XMPPOld extends XMPPHP_XMPP {
|
||
|
/**
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
protected $session_id;
|
||
|
|
||
|
public function __construct($host, $port, $user, $password, $resource, $server = null, $printlog = false, $loglevel = null) {
|
||
|
parent::__construct($host, $port, $user, $password, $resource, $server, $printlog, $loglevel);
|
||
|
if(!$server) $server = $host;
|
||
|
$this->stream_start = '<stream:stream to="' . $server . '" xmlns:stream="http://etherx.jabber.org/streams" xmlns="jabber:client">';
|
||
|
$this->fulljid = "{$user}@{$server}/{$resource}";
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Override XMLStream's startXML
|
||
|
*
|
||
|
* @param parser $parser
|
||
|
* @param string $name
|
||
|
* @param array $attr
|
||
|
*/
|
||
|
public function startXML($parser, $name, $attr) {
|
||
|
if($this->xml_depth == 0) {
|
||
|
$this->session_id = $attr['ID'];
|
||
|
$this->authenticate();
|
||
|
}
|
||
|
parent::startXML($parser, $name, $attr);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Send Authenticate Info Request
|
||
|
*
|
||
|
*/
|
||
|
public function authenticate() {
|
||
|
$id = $this->getId();
|
||
|
$this->addidhandler($id, 'authfieldshandler');
|
||
|
$this->send("<iq type='get' id='$id'><query xmlns='jabber:iq:auth'><username>{$this->user}</username></query></iq>");
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Retrieve auth fields and send auth attempt
|
||
|
*
|
||
|
* @param XMLObj $xml
|
||
|
*/
|
||
|
public function authFieldsHandler($xml) {
|
||
|
$id = $this->getId();
|
||
|
$this->addidhandler($id, 'oldAuthResultHandler');
|
||
|
if($xml->sub('query')->hasSub('digest')) {
|
||
|
$hash = sha1($this->session_id . $this->password);
|
||
|
print "{$this->session_id} {$this->password}\n";
|
||
|
$out = "<iq type='set' id='$id'><query xmlns='jabber:iq:auth'><username>{$this->user}</username><digest>{$hash}</digest><resource>{$this->resource}</resource></query></iq>";
|
||
|
} else {
|
||
|
$out = "<iq type='set' id='$id'><query xmlns='jabber:iq:auth'><username>{$this->user}</username><password>{$this->password}</password><resource>{$this->resource}</resource></query></iq>";
|
||
|
}
|
||
|
$this->send($out);
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Determine authenticated or failure
|
||
|
*
|
||
|
* @param XMLObj $xml
|
||
|
*/
|
||
|
public function oldAuthResultHandler($xml) {
|
||
|
if($xml->attrs['type'] != 'result') {
|
||
|
$this->log->log("Auth failed!", XMPPHP_Log::LEVEL_ERROR);
|
||
|
$this->disconnect();
|
||
|
throw new XMPPHP_Exception('Auth failed!');
|
||
|
} else {
|
||
|
$this->log->log("Session started");
|
||
|
$this->event('session_start');
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
?>
|