mirror of
https://github.com/bitinflow/expose.git
synced 2026-03-13 13:35:54 +00:00
123 lines
3.5 KiB
PHP
123 lines
3.5 KiB
PHP
<?php
|
|
|
|
namespace App\Server\Http\Controllers;
|
|
|
|
use App\Contracts\ConnectionManager;
|
|
use App\HttpServer\QueryParameters;
|
|
use Clue\React\SQLite\DatabaseInterface;
|
|
use Clue\React\SQLite\Result;
|
|
use stdClass;
|
|
use Ratchet\ConnectionInterface;
|
|
use Ratchet\MessageComponentInterface;
|
|
|
|
class ControlMessageController implements MessageComponentInterface
|
|
{
|
|
|
|
/** @var ConnectionManager */
|
|
protected $connectionManager;
|
|
|
|
/** @var DatabaseInterface */
|
|
protected $database;
|
|
|
|
public function __construct(ConnectionManager $connectionManager, DatabaseInterface $database)
|
|
{
|
|
$this->connectionManager = $connectionManager;
|
|
$this->database = $database;
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
function onOpen(ConnectionInterface $connection)
|
|
{
|
|
$this->verifyAuthToken($connection);
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
function onClose(ConnectionInterface $connection)
|
|
{
|
|
if (isset($connection->request_id)) {
|
|
$httpConnection = $this->connectionManager->getHttpConnectionForRequestId($connection->request_id);
|
|
$httpConnection->close();
|
|
}
|
|
|
|
$this->connectionManager->removeControlConnection($connection);
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
function onMessage(ConnectionInterface $connection, $msg)
|
|
{
|
|
if (isset($connection->request_id)) {
|
|
return $this->sendRequestToHttpConnection($connection->request_id, $msg);
|
|
}
|
|
|
|
try {
|
|
$payload = json_decode($msg);
|
|
$eventName = $payload->event;
|
|
|
|
if (method_exists($this, $eventName)) {
|
|
return call_user_func([$this, $eventName], $connection, $payload->data ?? new stdClass());
|
|
}
|
|
} catch (\Throwable $exception) {
|
|
//
|
|
}
|
|
}
|
|
|
|
protected function sendRequestToHttpConnection(string $requestId, $request)
|
|
{
|
|
$httpConnection = $this->connectionManager->getHttpConnectionForRequestId($requestId);
|
|
$httpConnection->send($request);
|
|
}
|
|
|
|
protected function authenticate(ConnectionInterface $connection, $data)
|
|
{
|
|
$connectionInfo = $this->connectionManager->storeConnection($data->host, $data->subdomain, $connection);
|
|
|
|
$connection->send(json_encode([
|
|
'event' => 'authenticated',
|
|
'subdomain' => $connectionInfo->subdomain,
|
|
'client_id' => $connectionInfo->client_id
|
|
]));
|
|
}
|
|
|
|
protected function registerProxy(ConnectionInterface $connection, $data)
|
|
{
|
|
$connection->request_id = $data->request_id;
|
|
|
|
$connectionInfo = $this->connectionManager->findControlConnectionForClientId($data->client_id);
|
|
|
|
$connectionInfo->emit('proxy_ready_' . $data->request_id, [
|
|
$connection,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
function onError(ConnectionInterface $conn, \Exception $e)
|
|
{
|
|
//
|
|
}
|
|
|
|
protected function verifyAuthToken(ConnectionInterface $connection)
|
|
{
|
|
$authToken = QueryParameters::create($connection->httpRequest)->get('authToken');
|
|
|
|
$this->database
|
|
->query("SELECT * FROM users WHERE auth_token = :token", ['token' => $authToken])
|
|
->then(function (Result $result) use ($connection) {
|
|
if (count($result->rows) === 0) {
|
|
$connection->send(json_encode([
|
|
'event' => 'authenticationFailed',
|
|
'data' => []
|
|
]));
|
|
$connection->close();
|
|
}
|
|
});
|
|
}
|
|
}
|