This commit is contained in:
Marcel Pociot
2020-05-03 23:27:51 +02:00
parent 37aeee76e4
commit 0b120245db
9 changed files with 182 additions and 29 deletions

View File

@@ -2,7 +2,7 @@
namespace App\Server;
class Configuration
class Configuration implements \JsonSerializable
{
/** @var string */
protected $hostname;
@@ -36,4 +36,15 @@ class Configuration
{
return $this->$key ?? config('expose.admin.'.$key);
}
/**
* @inheritDoc
*/
public function jsonSerialize()
{
return array_merge([
'hostname' => $this->hostname(),
'port' => $this->port(),
], config('expose.admin'));
}
}

View File

@@ -9,6 +9,9 @@ use App\Http\Server as HttpServer;
use App\Server\Connections\ConnectionManager;
use App\Server\Http\Controllers\Admin\DeleteUsersController;
use App\Server\Http\Controllers\Admin\DisconnectSiteController;
use App\Server\Http\Controllers\Admin\GetSettingsController;
use App\Server\Http\Controllers\Admin\GetSitesController;
use App\Server\Http\Controllers\Admin\GetUsersController;
use App\Server\Http\Controllers\Admin\ListSitesController;
use App\Server\Http\Controllers\Admin\ListUsersController;
use App\Server\Http\Controllers\Admin\RedirectToUsersController;
@@ -117,11 +120,15 @@ class Factory
$this->router->get('/', RedirectToUsersController::class, $adminCondition);
$this->router->get('/users', ListUsersController::class, $adminCondition);
$this->router->get('/settings', ShowSettingsController::class, $adminCondition);
$this->router->post('/settings', SaveSettingsController::class, $adminCondition);
$this->router->post('/users', StoreUsersController::class, $adminCondition);
$this->router->delete('/users/{id}', DeleteUsersController::class, $adminCondition);
$this->router->get('/sites', ListSitesController::class, $adminCondition);
$this->router->delete('/sites/{id}', DisconnectSiteController::class, $adminCondition);
$this->router->get('/api/settings', GetSettingsController::class, $adminCondition);
$this->router->post('/api/settings', SaveSettingsController::class, $adminCondition);
$this->router->get('/api/users', GetUsersController::class, $adminCondition);
$this->router->post('/api/users', StoreUsersController::class, $adminCondition);
$this->router->delete('/api/users/{id}', DeleteUsersController::class, $adminCondition);
$this->router->get('/api/sites', GetSitesController::class, $adminCondition);
$this->router->delete('/api/sites/{id}', DisconnectSiteController::class, $adminCondition);
}
protected function bindConfiguration()

View File

@@ -0,0 +1,32 @@
<?php
namespace App\Server\Http\Controllers\Admin;
use App\Contracts\ConnectionManager;
use App\Server\Configuration;
use Illuminate\Http\Request;
use Ratchet\ConnectionInterface;
use Twig\Environment;
use Twig\Loader\ArrayLoader;
use function GuzzleHttp\Psr7\str;
use function GuzzleHttp\Psr7\stream_for;
class GetSettingsController extends AdminController
{
/** @var Configuration */
protected $configuration;
public function __construct(ConnectionManager $connectionManager, Configuration $configuration)
{
$this->configuration = $configuration;
}
public function handle(Request $request, ConnectionInterface $httpConnection)
{
$httpConnection->send(
respond_json([
'configuration' => $this->configuration,
])
);
}
}

View File

@@ -0,0 +1,35 @@
<?php
namespace App\Server\Http\Controllers\Admin;
use App\Contracts\ConnectionManager;
use App\Http\Controllers\Controller;
use App\Server\Configuration;
use Illuminate\Http\Request;
use Ratchet\ConnectionInterface;
use Twig\Environment;
use Twig\Loader\ArrayLoader;
use function GuzzleHttp\Psr7\str;
use function GuzzleHttp\Psr7\stream_for;
class GetSitesController extends AdminController
{
/** @var ConnectionManager */
protected $connectionManager;
/** @var Configuration */
protected $configuration;
public function __construct(ConnectionManager $connectionManager, Configuration $configuration)
{
$this->connectionManager = $connectionManager;
}
public function handle(Request $request, ConnectionInterface $httpConnection)
{
$httpConnection->send(
respond_json([
'sites' => $this->connectionManager->getConnections()
])
);
}
}

View File

@@ -0,0 +1,40 @@
<?php
namespace App\Server\Http\Controllers\Admin;
use App\Contracts\UserRepository;
use App\Http\Controllers\Controller;
use Clue\React\SQLite\Result;
use GuzzleHttp\Psr7\Response;
use Illuminate\Http\Request;
use Ratchet\ConnectionInterface;
use Twig\Environment;
use Twig\Loader\ArrayLoader;
use function GuzzleHttp\Psr7\str;
use function GuzzleHttp\Psr7\stream_for;
class GetUsersController extends AdminController
{
protected $keepConnectionOpen = true;
/** @var UserRepository */
protected $userRepository;
public function __construct(UserRepository $userRepository)
{
$this->userRepository = $userRepository;
}
public function handle(Request $request, ConnectionInterface $httpConnection)
{
$this->userRepository
->getUsers()
->then(function ($users) use ($httpConnection) {
$httpConnection->send(
respond_json(['users' => $users])
);
$httpConnection->close();
});
}
}

View File

@@ -8,6 +8,7 @@ use App\Server\Configuration;
use Clue\React\SQLite\Result;
use GuzzleHttp\Psr7\Response;
use Illuminate\Http\Request;
use Illuminate\Support\Arr;
use Ratchet\ConnectionInterface;
use Twig\Environment;
use Twig\Loader\ArrayLoader;
@@ -16,15 +17,11 @@ use function GuzzleHttp\Psr7\stream_for;
class SaveSettingsController extends AdminController
{
/** @var ConnectionManager */
protected $connectionManager;
/** @var Configuration */
protected $configuration;
public function __construct(ConnectionManager $connectionManager, Configuration $configuration)
public function __construct(Configuration $configuration)
{
$this->connectionManager = $connectionManager;
$this->configuration = $configuration;
}
@@ -32,14 +29,18 @@ class SaveSettingsController extends AdminController
{
config()->set('expose.admin.validate_auth_tokens', $request->has('validate_auth_tokens'));
config()->set('expose.admin.messages.invalid_auth_token', $request->get('invalid_auth_token'));
$messages = $request->get('messages');
config()->set('expose.admin.messages.subdomain_taken', $request->get('subdomain_taken'));
config()->set('expose.admin.messages.invalid_auth_token', Arr::get($messages, 'invalid_auth_token'));
config()->set('expose.admin.messages.message_of_the_day', $request->get('motd'));
config()->set('expose.admin.messages.subdomain_taken', Arr::get($messages, 'subdomain_taken'));
$httpConnection->send(str(new Response(301, [
'Location' => '/settings'
])));
config()->set('expose.admin.messages.message_of_the_day', Arr::get($messages, 'message_of_the_day'));
$httpConnection->send(
respond_json([
'configuration' => $this->configuration,
])
);
}
}