HEX
Server: Apache/2.4.6 (CentOS) OpenSSL/1.0.2k-fips PHP/7.2.34
System: Linux atalantini.com 3.10.0-1127.13.1.el7.x86_64 #1 SMP Tue Jun 23 15:46:38 UTC 2020 x86_64
User: root (0)
PHP: 7.2.34
Disabled: NONE
Upload Files
File: //usr/share/php/React/Socket/ServerInterface.php
<?php

namespace React\Socket;

use Evenement\EventEmitterInterface;

/**
 * The `ServerInterface` is responsible for providing an interface for accepting
 * incoming streaming connections, such as a normal TCP/IP connection.
 *
 * Most higher-level components (such as a HTTP server) accept an instance
 * implementing this interface to accept incoming streaming connections.
 * This is usually done via dependency injection, so it's fairly simple to actually
 * swap this implementation against any other implementation of this interface.
 * This means that you SHOULD typehint against this interface instead of a concrete
 * implementation of this interface.
 *
 * Besides defining a few methods, this interface also implements the
 * `EventEmitterInterface` which allows you to react to certain events:
 *
 * connection event:
 *     The `connection` event will be emitted whenever a new connection has been
 *     established, i.e. a new client connects to this server socket:
 *
 *     ```php
 *     $server->on('connection', function (ConnectionInterface $connection) {
 *         echo 'new connection' . PHP_EOL;
 *     });
 *     ```
 *
 *     See also the `ConnectionInterface` for more details about handling the
 *     incoming connection.
 *
 * error event:
 *     The `error` event will be emitted whenever there's an error accepting a new
 *     connection from a client.
 *
 *     ```php
 *     $server->on('error', function (Exception $e) {
 *         echo 'error: ' . $e->getMessage() . PHP_EOL;
 *     });
 *     ```
 *
 *     Note that this is not a fatal error event, i.e. the server keeps listening for
 *     new connections even after this event.
 *
 * @see ConnectionInterface
 */
interface ServerInterface extends EventEmitterInterface
{
    /**
     * Starts listening on the given address
     *
     * This starts accepting new incoming connections on the given address.
     * See also the `connection event` above for more details.
     *
     * By default, the server will listen on the localhost address and will not be
     * reachable from the outside.
     * You can change the host the socket is listening on through a second parameter
     * provided to the listen method.
     *
     * This method MUST NOT be called more than once on the same instance.
     *
     * @param int    $port port to listen on
     * @param string $host optional host to listen on, defaults to localhost IP
     * @return void
     * @throws Exception if listening on this address fails (invalid or already in use etc.)
     */
    public function listen($port, $host = '127.0.0.1');

    /**
     * Returns the port this server is currently listening on
     *
     * This method MUST NOT be called before calling listen().
     * This method MUST NOT be called after calling shutdown().
     *
     * @return int the port number
     */
    public function getPort();

    /**
     * Shuts down this listening socket
     *
     * This will stop listening for new incoming connections on this socket.
     *
     * This method MUST NOT be called before calling listen().
     * This method MUST NOT be called after calling shutdown().
     *
     * @return void
     */
    public function shutdown();
}