123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185 |
- <?php
- /**
- * Copyright 2014 Fabian Grutschus. All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without modification,
- * are permitted provided that the following conditions are met:
- *
- * 1. Redistributions of source code must retain the above copyright notice, this
- * list of conditions and the following disclaimer.
- *
- * 2. 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.
- *
- * 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.
- *
- * The views and conclusions contained in the software and documentation are those
- * of the authors and should not be interpreted as representing official policies,
- * either expressed or implied, of the copyright holders.
- *
- * @author Fabian Grutschus <f.grutschus@lubyte.de>
- * @copyright 2014 Fabian Grutschus. All rights reserved.
- * @license BSD
- * @link http://github.com/fabiang/xmpp
- */
- namespace Fabiang\Xmpp;
- use Fabiang\Xmpp\Options;
- use Fabiang\Xmpp\Connection\ConnectionInterface;
- use Fabiang\Xmpp\Connection\Socket;
- use Fabiang\Xmpp\Protocol\ProtocolImplementationInterface;
- use Fabiang\Xmpp\Event\EventManagerAwareInterface;
- use Fabiang\Xmpp\Event\EventManagerInterface;
- use Fabiang\Xmpp\Event\EventManager;
- use Fabiang\Xmpp\EventListener\Logger;
- /**
- * Xmpp connection client.
- *
- * @package Xmpp
- */
- class Client implements EventManagerAwareInterface
- {
- /**
- * Eventmanager.
- *
- * @var EventManagerInterface
- */
- protected $eventManager;
- /**
- * Options.
- *
- * @var Options
- */
- protected $options;
- /**
- * @var ConnectionInterface
- */
- protected $connection;
- /**
- * Constructor.
- *
- * @param Options $options Client options
- * @param EventManagerInterface $eventManager Event manager
- */
- public function __construct(Options $options, EventManagerInterface $eventManager = null)
- {
- // create default connection
- if (null !== $options->getConnection()) {
- $connection = $options->getConnection();
- } else {
- $connection = Socket::factory($options);
- $options->setConnection($connection);
- }
- $this->options = $options;
- $this->connection = $connection;
- if (null === $eventManager) {
- $eventManager = new EventManager();
- }
- $this->eventManager = $eventManager;
- $this->setupImplementation();
- }
- /**
- * Setup implementation.
- *
- * @return void
- */
- protected function setupImplementation()
- {
- $this->connection->setEventManager($this->eventManager);
- $this->connection->setOptions($this->options);
- $implementation = $this->options->getImplementation();
- $implementation->setEventManager($this->eventManager);
- $implementation->setOptions($this->options);
- $implementation->register();
- $implementation->registerListener(new Logger());
- }
- /**
- * Connect to server.
- *
- * @return void
- */
- public function connect()
- {
- $this->connection->connect();
- }
- /**
- * Disconnect from server.
- *
- * @return void
- */
- public function disconnect()
- {
- $this->connection->disconnect();
- }
- /**
- * Send data to server.
- *
- * @param ProtocolImplementationInterface $interface Interface
- * @return void
- */
- public function send(ProtocolImplementationInterface $interface)
- {
- $data = $interface->toString();
- $this->connection->send($data);
- }
- /**
- * {@inheritDoc}
- */
- public function getEventManager()
- {
- return $this->eventManager;
- }
- /**
- * {@inheritDoc}
- */
- public function setEventManager(EventManagerInterface $eventManager)
- {
- $this->eventManager = $eventManager;
- return $this;
- }
- /**
- * Get options.
- *
- * @return Options
- */
- public function getOptions()
- {
- return $this->options;
- }
- /**
- * @return ConnectionInterface
- */
- public function getConnection()
- {
- return $this->connection;
- }
- }
|