initial commit

This commit is contained in:
yggverse 2024-04-21 14:32:15 +03:00
parent dde6bc2eae
commit 4343ce9565
4 changed files with 290 additions and 1 deletions

1
.gitignore vendored Normal file
View File

@ -0,0 +1 @@
/vendor/

View File

@ -1,2 +1,69 @@
# nex-php
PHP 8 / Composer Library for Nex Protocol
PHP 8 Library for Nex Protocol
## Usage
```
composer require yggverse/nex
```
## Client
PHP interface for Nex protocol queries
### Request
``` php
$request = new \Yggverse\Nex\Client\Request(
'nex://nightfall.city/nex/'
);
```
**Resolved request (SNI)**
For direct connection provide resolved IP as the second argument
``` php
$request = new \Yggverse\Nex\Client\Request(
'nex://nightfall.city/nex/' // target URL
'46.23.92.144' // resolved IP, skip to use system-wide resolver
);
```
Alternatively, use `setResolvedHost` method of `Request` object before `getResponse`
#### Request::setResolvedHost
``` php
$request->setResolvedHost(
'46.23.92.144'
)
```
* to resolve network address with PHP, take a look on the [net-php](https://github.com/YGGverse/net-php) library!
#### Request::getResolvedHost
Get resolved host back
#### Request::setHost
#### Request::getHost
#### Request::setPort
#### Request::getPort
#### Request::setPath
#### Request::getPath
#### Request::setQuery
#### Request::getQuery
#### Request::getResponse
Execute requested URL and return raw response
``` php
var_dump(
$request->getResponse()
);
```
#### Request::getOptions
#### Request::setOptions

19
composer.json Normal file
View File

@ -0,0 +1,19 @@
{
"name": "yggverse/nex",
"description": "PHP 8 Library for Nex Protocol",
"keywords": [ "yggverse", "nex", "nex-protocol", "client" ],
"homepage": "https://github.com/yggverse/nex-php",
"type": "library",
"license": "MIT",
"autoload": {
"psr-4": {
"Yggverse\\Nex\\": "src/"
}
},
"authors": [
{
"name": "YGGverse"
}
],
"require": {}
}

202
src/Client/Request.php Normal file
View File

@ -0,0 +1,202 @@
<?php
declare(strict_types=1);
namespace Yggverse\Nex\Client;
class Request
{
private ?string $_ip = null;
private string $_host;
private int $_port;
private string $_path;
private string $_query;
private array $_options = [];
public function __construct(string $url, ?string $ip = null)
{
if ($host = parse_url($url, PHP_URL_HOST))
{
$this->setHost(
$host
);
}
else
{
throw new Exception(); // @TODO
}
if ($port = parse_url($url, PHP_URL_PORT))
{
$this->setPort(
$port
);
}
else
{
$this->setPort(
1900
);
}
if ($path = parse_url($url, PHP_URL_PATH))
{
$this->setPath(
$path
);
}
else
{
$this->setPath(
''
);
}
if ($query = parse_url($url, PHP_URL_QUERY))
{
$this->setQuery(
$query
);
}
else
{
$this->setQuery(
''
);
}
if ($ip && false !== filter_var($ip, FILTER_VALIDATE_IP))
{
$this->setResolvedHost(
$ip
);
}
}
public function setOptions(array $value): void
{
$this->_options = $value;
}
public function getOptions(): array
{
return $this->_options;
}
public function setHost(string $value): void
{
$this->_host = $value;
}
public function getHost(): string
{
return $this->_host;
}
public function setPort(int $value): void
{
$this->_port = $value;
}
public function getPort(): int
{
return $this->_port;
}
public function setPath(string $value): void
{
$this->_path = $value;
}
public function getPath(): string
{
return $this->_path;
}
public function setQuery(string $value): void
{
$this->_query = $value;
}
public function getQuery(): string
{
return $this->_query;
}
public function setResolvedHost(?string $value): void
{
$this->_ip = $value;
}
public function getResolvedHost(): ?string
{
return $this->_ip;
}
public function getResponse(
int $timeout = 30, // socket timeout, useful for offline resources
?int $limit = null, // content length, null for unlimited
?int &$length = 0, // initial response length, do not change without special needs
?int &$code = null, // error code for debug
?string &$message = null, // error message for debug
string &$response = '' // response init, also returning by this method
): ?string
{
$connection = stream_socket_client(
sprintf(
'tcp://%s:%d',
$this->_ip ? $this->_ip : $this->_host,
$this->_port
),
$code,
$message,
$timeout,
STREAM_CLIENT_CONNECT,
stream_context_create(
$this->_options
)
);
if (!is_resource($connection))
{
return null;
}
fwrite(
$connection,
sprintf(
"nex://%s:%d%s%s\r\n",
$this->_host,
$this->_port,
$this->_path,
$this->_query
)
);
while ($part = fgets($connection))
{
$length = $length + mb_strlen(
$part
);
if ($limit && $length > $limit)
{
break;
}
$response .= $part;
}
fclose(
$connection
);
return $response;
}
}