mirror of
https://github.com/bitinflow/expose.git
synced 2026-03-16 06:55:56 +00:00
Make server configurable when sharing files. Fix react/http compatibility issues
This commit is contained in:
@@ -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;
|
||||||
|
|||||||
@@ -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);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -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,
|
||||||
|
|||||||
@@ -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'),
|
||||||
|
|||||||
Reference in New Issue
Block a user