mirror of
https://github.com/YGGverse/nex-php.git
synced 2026-04-01 02:05:28 +00:00
implement nex protocol server
This commit is contained in:
parent
ae8cdbeeaf
commit
dff658c1f2
2 changed files with 169 additions and 1 deletions
128
src/Server.php
Normal file
128
src/Server.php
Normal file
|
|
@ -0,0 +1,128 @@
|
|||
<?php
|
||||
|
||||
namespace Yggverse\Nex;
|
||||
|
||||
class Server
|
||||
{
|
||||
private string $_host;
|
||||
private int $_port;
|
||||
private int $_size;
|
||||
|
||||
public function __construct(
|
||||
string $host = '127.0.0.1',
|
||||
int $port = 1915,
|
||||
int $size = 1024
|
||||
) {
|
||||
$this->setHost(
|
||||
$host
|
||||
);
|
||||
|
||||
$this->setPort(
|
||||
$port
|
||||
);
|
||||
|
||||
$this->setSize(
|
||||
$size
|
||||
);
|
||||
}
|
||||
|
||||
public function getHost(): string
|
||||
{
|
||||
return $this->_host;
|
||||
}
|
||||
|
||||
public function setHost(
|
||||
string $value
|
||||
): void
|
||||
{
|
||||
if (false === filter_var($value, FILTER_VALIDATE_IP))
|
||||
{
|
||||
throw new \Exception();
|
||||
}
|
||||
|
||||
if (strpos($value, ':'))
|
||||
{
|
||||
$value = sprintf(
|
||||
'[%s]',
|
||||
$value
|
||||
);
|
||||
}
|
||||
|
||||
$this->_host = $value;
|
||||
}
|
||||
|
||||
public function getPort(): int
|
||||
{
|
||||
return $this->_port;
|
||||
}
|
||||
|
||||
public function setPort(
|
||||
int $value
|
||||
): void
|
||||
{
|
||||
$this->_port = $value;
|
||||
}
|
||||
|
||||
public function getSize(): int
|
||||
{
|
||||
return $this->_size;
|
||||
}
|
||||
|
||||
public function setSize(
|
||||
int $value
|
||||
): void
|
||||
{
|
||||
$this->_size = $value;
|
||||
}
|
||||
|
||||
public function start(
|
||||
?callable $handler = null
|
||||
): void
|
||||
{
|
||||
$socket = stream_socket_server(
|
||||
sprintf(
|
||||
'tcp://%s:%d',
|
||||
$this->_host,
|
||||
$this->_port
|
||||
),
|
||||
$error,
|
||||
$message,
|
||||
STREAM_SERVER_BIND | STREAM_SERVER_LISTEN
|
||||
);
|
||||
|
||||
while ($socket)
|
||||
{
|
||||
$incoming = stream_socket_accept(
|
||||
$socket, -1, $connect
|
||||
);
|
||||
|
||||
stream_set_blocking(
|
||||
$incoming,
|
||||
true
|
||||
);
|
||||
|
||||
$request = fread(
|
||||
$incoming,
|
||||
$this->_size
|
||||
);
|
||||
|
||||
stream_set_blocking(
|
||||
$incoming,
|
||||
false
|
||||
);
|
||||
|
||||
if ($handler)
|
||||
{
|
||||
$response = call_user_func(
|
||||
$handler,
|
||||
$request,
|
||||
$connect
|
||||
);
|
||||
}
|
||||
|
||||
fclose(
|
||||
$incoming
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue