Make server configurable when sharing files. Fix react/http compatibility issues

This commit is contained in:
Marcel Pociot
2021-05-19 11:35:27 +02:00
parent 60af8bce19
commit 44dca53687
4 changed files with 11 additions and 6 deletions

View File

@@ -8,7 +8,7 @@ use GuzzleHttp\Psr7\ServerRequest;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Message\ServerRequestInterface;
use React\EventLoop\LoopInterface; use React\EventLoop\LoopInterface;
use React\Http\Response; use React\Http\Message\Response;
use React\Stream\ReadableResourceStream; use React\Stream\ReadableResourceStream;
use Symfony\Bridge\PsrHttpMessage\Factory\HttpFoundationFactory; use Symfony\Bridge\PsrHttpMessage\Factory\HttpFoundationFactory;
use Symfony\Component\Finder\Finder; use Symfony\Component\Finder\Finder;

View File

@@ -14,7 +14,7 @@ class Fileserver
public function __construct($rootFolder, $name, $port, $address, LoopInterface $loop) public function __construct($rootFolder, $name, $port, $address, LoopInterface $loop)
{ {
$server = new Server(function (ServerRequestInterface $request) use ($rootFolder, $name, $loop) { $server = new Server($loop, function (ServerRequestInterface $request) use ($rootFolder, $name, $loop) {
return (new ConnectionHandler($rootFolder, $name, $loop))->handle($request); return (new ConnectionHandler($rootFolder, $name, $loop))->handle($request);
}); });

View File

@@ -74,6 +74,7 @@ class HttpClient
protected function createConnector(): Connector protected function createConnector(): Connector
{ {
return new Connector($this->loop, [ return new Connector($this->loop, [
'dns' => config('expose.dns', '127.0.0.1'),
'tls' => [ 'tls' => [
'verify_peer' => false, 'verify_peer' => false,
'verify_peer_name' => false, 'verify_peer_name' => false,

View File

@@ -10,7 +10,7 @@ use Symfony\Component\Console\Output\ConsoleOutput;
class ShareFilesCommand extends Command class ShareFilesCommand extends Command
{ {
protected $signature = 'share-files {folder=.} {--name=} {--subdomain=} {--auth=}'; protected $signature = 'share-files {folder=.} {--name=} {--subdomain=} {--auth=} {--server-host=} {--server-port=}';
protected $description = 'Share a local folder with a remote expose server'; protected $description = 'Share a local folder with a remote expose server';
@@ -31,11 +31,15 @@ class ShareFilesCommand extends Command
$this->configureConnectionLogger(); $this->configureConnectionLogger();
$serverHost = $this->option('server-host') ?? config('expose.host', 'localhost');
$serverPort = $this->option('server-port') ?? config('expose.port', 8080);
$auth = $this->option('auth') ?? config('expose.auth_token', '');
(new Factory()) (new Factory())
->setLoop(app(LoopInterface::class)) ->setLoop(app(LoopInterface::class))
->setHost(config('expose.host', 'localhost')) ->setHost($serverHost)
->setPort(config('expose.port', 8080)) ->setPort($serverPort)
->setAuth($this->option('auth')) ->setAuth($auth)
->createClient() ->createClient()
->shareFolder( ->shareFolder(
$this->argument('folder'), $this->argument('folder'),