Download the PHP package amphp/socket without Composer
On this page you can find all versions of the php package amphp/socket. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Package socket
Short Description Non-blocking socket connection / server implementations based on Amp and Revolt.
License MIT
Homepage https://github.com/amphp/socket
Informations about the package socket
amphp/socket
AMPHP is a collection of event-driven libraries for PHP designed with fibers and concurrency in mind.
amphp/socket
is a library for establishing and encrypting non-blocking sockets.
It provides a socket abstraction for clients and servers.
It abstracts the really low levels of non-blocking streams in PHP.
Installation
This package can be installed as a Composer dependency.
Requirements
amphp/socket
heavily relies on amphp/byte-stream
, specifically its ReadableStream
and WritableStream
interfaces.
Connecting to a Server
amphp/socket
allows clients to connect to servers via TCP, UDP, or Unix domain sockets.
You can establish a socket connection using Amp\Socket\connect()
.
It will automatically resolve DNS names and retries other IPs if a connection fails and multiple IPs are available.
Encrypted Connections / TLS
If you want to connect via TLS, use Amp\Socket\connectTls()
instead or call $socket->setupTls()
on the returned socket.
Handling Connections
Socket
implements ReadableStream
and WritableStream
, so everything from amphp/byte-stream
applies for receiving and sending data.
Server
amphp/socket
allows listening for incoming TCP connections as well as connections via Unix domain sockets.
It defaults to secure TLS settings if you decide to enable TLS.
Listening and Accepting Connections
Use Amp\Socket\Socket\listen()
to listen on a port or unix domain socket.
It's a wrapper around stream_socket_server
that gives useful error message on failures via exceptions.
Once you're listening, accept clients using Server::accept()
.
It returns a Socket
that returns once a new client has been accepted.
It's usually called within a while
loop:
Handling Connections
Socket
implements ReadableStream
and WritableStream
, so everything from amphp/byte-stream
applies for receiving and sending data.
It's best to handle clients in their own coroutine, while letting the server accept all clients as soon as there are new clients.
Closing Connections
Once you're done with a client, close the connection using Socket::close()
.
If you want to wait for all data to be successfully written before closing the connection, use Socket::end()
.
See above for an example.
Server Address
Sometimes you don't know the address the server is listening on, e.g. because you listed to tcp://127.0.0.1:0
, which assigns a random free port. You can use Server::getAddress()
to get the address the server is bound to.
Server Shutdown
Once you're done with the server socket, close the socket.
That means, the server won't listen on the specified location anymore.
Use Server::close()
to close the server socket.
Encrypted Connections / TLS
As already mentioned in the documentation for Amp\Socket\Socket\listen()
, you need to enable TLS manually after accepting connections.
For a TLS server socket, you listen on the tcp://
protocol on a specified address.
After accepting clients, call $socket->setupTls()
where $socket
is the socket returned from SocketServer::accept()
.
Warning Any data transmitted before
Socket::setupTls()
completes will be transmitted in clear text. Don't attempt to read from the socket or write to it manually. Doing so will read the raw TLS handshake data that's supposed to be read by OpenSSL.
Self-Signed Certificates
There's no option to allow self-signed certificates in ClientTlsContext
since it is no more secure than disabling peer verification.
To safely use a self-signed certificate, disable peer verification and require fingerprint verification of the certificate using ClientTlsContext::withPeerFingerprint()
.
Security
If you discover any security related issues, please email [email protected]
instead of using the issue tracker.
License
The MIT License (MIT). Please see LICENSE
for more information.
All versions of socket with dependencies
ext-openssl Version *
amphp/amp Version ^3
amphp/dns Version ^2
amphp/byte-stream Version ^2
kelunik/certificate Version ^1.1
league/uri Version ^6.5 | ^7
league/uri-interfaces Version ^2.3 | ^7
revolt/event-loop Version ^1 || ^0.2