1
0
Fork 0
mirror of synced 2024-07-03 21:50:34 +12:00
appwrite/app/cli.php

121 lines
3.8 KiB
PHP
Raw Normal View History

2020-07-29 07:48:51 +12:00
<?php
2022-05-24 02:54:50 +12:00
require_once __DIR__ . '/init.php';
require_once __DIR__ . '/controllers/general.php';
2020-07-29 07:48:51 +12:00
2022-08-02 13:32:46 +12:00
use Appwrite\CLI\Tasks;
2022-10-28 16:36:20 +13:00
use Utopia\CLI\CLI;
2022-04-10 21:38:22 +12:00
use Utopia\Database\Validator\Authorization;
2022-08-02 13:32:46 +12:00
use Utopia\Platform\Service;
2022-10-28 16:36:20 +13:00
use Utopia\App;
use Utopia\CLI\Console;
use Utopia\Cache\Adapter\Redis as RedisCache;
use Utopia\Cache\Cache;
use Utopia\Database\Adapter\MariaDB;
use Utopia\Database\Database;
2022-10-28 21:56:45 +13:00
use Utopia\Logger\Log;
2022-10-28 21:49:05 +13:00
use Utopia\Registry\Registry;
2022-04-10 21:38:22 +12:00
Authorization::disable();
2020-07-29 07:48:51 +12:00
2022-10-28 16:36:20 +13:00
CLI::setResource('register', fn()=>$register);
2022-10-28 22:00:59 +13:00
CLI::setResource('db', function (Registry $register) {
2022-10-28 21:49:05 +13:00
$attempts = 0;
$max = 10;
$sleep = 1;
do {
try {
$attempts++;
$db = $register->get('db');
break; // leave the do-while if successful
} catch (\Exception $e) {
Console::warning("Database not ready. Retrying connection ({$attempts})...");
if ($attempts >= $max) {
throw new \Exception('Failed to connect to database: ' . $e->getMessage());
}
sleep($sleep);
2022-10-28 16:36:20 +13:00
}
2022-10-28 21:49:05 +13:00
} while ($attempts < $max);
return $db;
}, ['register']);
2022-10-28 16:36:20 +13:00
2022-10-30 18:36:31 +13:00
CLI::setResource('cache', fn ($register) => $register->get('cache'), ['register']);
2022-10-28 16:36:20 +13:00
CLI::setResource('dbForConsole', function ($db, $cache) {
$cache = new Cache(new RedisCache($cache));
$database = new Database(new MariaDB($db), $cache);
$database->setDefaultDatabase(App::getEnv('_APP_DB_SCHEMA', 'appwrite'));
$database->setNamespace('_console');
return $database;
}, ['db', 'cache']);
2022-10-28 22:00:59 +13:00
CLI::setResource('influxdb', function (Registry $register) {
2022-10-28 21:49:05 +13:00
/** @var InfluxDB\Client $client */
$client = $register->get('influxdb');
$attempts = 0;
$max = 10;
$sleep = 1;
2022-10-28 22:00:59 +13:00
2022-10-28 21:49:05 +13:00
do { // check if telegraf database is ready
try {
$attempts++;
$database = $client->selectDB('telegraf');
if (in_array('telegraf', $client->listDatabases())) {
break; // leave the do-while if successful
}
} catch (\Throwable$th) {
Console::warning("InfluxDB not ready. Retrying connection ({$attempts})...");
if ($attempts >= $max) {
throw new \Exception('InfluxDB database not ready yet');
}
sleep($sleep);
2022-10-28 17:09:34 +13:00
}
2022-10-28 21:49:05 +13:00
} while ($attempts < $max);
return $database;
}, ['register']);
2022-10-28 17:09:34 +13:00
2022-10-28 22:00:59 +13:00
CLI::setResource('logError', function (Registry $register) {
return function (Throwable $error, string $namespace, string $action) use ($register) {
2022-10-28 21:56:45 +13:00
$logger = $register->get('logger');
if ($logger) {
$version = App::getEnv('_APP_VERSION', 'UNKNOWN');
$log = new Log();
$log->setNamespace($namespace);
$log->setServer(\gethostname());
$log->setVersion($version);
$log->setType(Log::TYPE_ERROR);
$log->setMessage($error->getMessage());
$log->addTag('code', $error->getCode());
$log->addTag('verboseType', get_class($error));
$log->addExtra('file', $error->getFile());
$log->addExtra('line', $error->getLine());
$log->addExtra('trace', $error->getTraceAsString());
$log->addExtra('detailedTrace', $error->getTrace());
$log->setAction($action);
$isProduction = App::getEnv('_APP_ENV', 'development') === 'production';
$log->setEnvironment($isProduction ? Log::ENVIRONMENT_PRODUCTION : Log::ENVIRONMENT_STAGING);
$responseCode = $logger->addLog($log);
Console::info('Usage stats log pushed with status code: ' . $responseCode);
}
Console::warning("Failed: {$error->getMessage()}");
Console::warning($error->getTraceAsString());
};
});
2022-08-02 13:32:46 +12:00
$cliPlatform = new Tasks();
$cliPlatform->init(Service::TYPE_CLI);
2022-07-13 18:26:22 +12:00
$cli = $cliPlatform->getCli();
$cli->run();