1
0
Fork 0
mirror of synced 2024-06-15 09:14:50 +12:00
appwrite/app/server.php

82 lines
2 KiB
PHP
Raw Normal View History

2020-06-26 21:54:37 +12:00
<?php
require_once __DIR__.'/../vendor/autoload.php';
2020-06-27 00:27:58 +12:00
use Appwrite\Utopia\Request;
use Appwrite\Utopia\Response;
use Swoole\Process;
use Swoole\Http\Server;
2020-06-26 21:54:37 +12:00
use Swoole\Http\Request as SwooleRequest;
use Swoole\Http\Response as SwooleResponse;
2020-06-27 00:27:58 +12:00
use Utopia\App;
use Utopia\CLI\Console;
2020-07-05 10:24:09 +12:00
// xdebug_start_trace('/tmp/trace');
2020-06-27 00:27:58 +12:00
ini_set('display_errors', 1);
ini_set('display_startup_errors', 1);
error_reporting(E_ALL);
2020-06-26 21:54:37 +12:00
2020-07-04 03:14:06 +12:00
sleep(5);
2020-07-03 18:08:46 +12:00
$http = new Server("0.0.0.0", 80);
2020-07-01 20:55:14 +12:00
2020-06-27 00:27:58 +12:00
$http
2020-06-26 21:54:37 +12:00
->set([
'open_http2_protocol' => true,
'document_root' => __DIR__ . '/../public',
'enable_static_handler' => true,
2020-07-05 00:32:27 +12:00
'timeout' => 7,
2020-07-02 18:44:16 +12:00
'http_compression' => true,
'http_compression_level' => 6,
2020-06-26 21:54:37 +12:00
])
;
2020-06-27 00:27:58 +12:00
$http->on('WorkerStart', function($serv, $workerId) {
Console::success('Worker '.$workerId.' started succefully');
2020-06-26 21:54:37 +12:00
});
2020-06-27 00:27:58 +12:00
$http->on('BeforeReload', function($serv, $workerId) {
2020-06-26 21:54:37 +12:00
Console::success('Starting reload...');
});
2020-06-27 00:27:58 +12:00
$http->on('AfterReload', function($serv, $workerId) {
2020-06-26 21:54:37 +12:00
Console::success('Reload completed...');
});
2020-06-27 00:27:58 +12:00
$http->on('start', function (Server $http) {
Console::success('Server started succefully');
printf("x master pid %d, manager pid %d\n", $http->master_pid, $http->manager_pid);
2020-06-27 00:27:58 +12:00
// listen ctrl + c
Process::signal(2, function () use ($http) {
echo "Stop by Ctrl+C\n";
$http->shutdown();
});
2020-06-26 21:54:37 +12:00
});
2020-07-01 20:55:14 +12:00
include __DIR__ . '/app.php';
2020-07-02 10:34:05 +12:00
$http->on('request', function (SwooleRequest $swooleRequest, SwooleResponse $swooleResponse) {
2020-07-01 20:55:14 +12:00
$request = new Request($swooleRequest);
$response = new Response($swooleResponse);
$app = new App('Asia/Tel_Aviv');
2020-06-27 00:27:58 +12:00
try {
2020-07-01 20:55:14 +12:00
$app->run($request, $response);
2020-06-27 00:27:58 +12:00
} catch (\Throwable $th) {
2020-07-02 10:34:05 +12:00
if(App::isDevelopment()) {
2020-07-03 00:24:39 +12:00
var_dump(get_class($th));
2020-07-02 10:34:05 +12:00
var_dump($th->getMessage());
var_dump($th->getFile());
var_dump($th->getLine());
$swooleResponse->end('error: '.$th->getMessage());
}
$swooleResponse->end('500: Server Error');
2020-06-27 00:27:58 +12:00
}
2020-06-26 21:54:37 +12:00
});
2020-06-27 00:27:58 +12:00
$http->start();