self::$memoryConsumption + self::$memoryDiffMb) { \gc_collect_cycles(); self::$memoryConsumption = self::getMemoryConsumption(); $cleanedMemory = $currentMemory - self::$memoryConsumption; if (!Magic::$suspendPeriodicLogging) { Logger::log("gc_collect_cycles done. Cleaned memory: $cleanedMemory Mb", Logger::VERBOSE); } } })); if (!\defined('MADELINE_RELEASE_URL')) { return; } $client = HttpClientBuilder::buildDefault(); $request = new Request(MADELINE_RELEASE_URL); $madelinePhpContents = null; $id = null; $cb = function () use ($client, $request, &$madelinePhpContents, &$id): void { try { $madelinePhpContents ??= read(MADELINE_PHP); $contents = $client->request(new Request("https://phar.madelineproto.xyz/phar.php?v=new".\rand(0, PHP_INT_MAX))) ->getBody() ->buffer(); if ($contents !== $madelinePhpContents) { $unlock = Tools::flock(MADELINE_PHP.'.lock', LOCK_EX); write(MADELINE_PHP.'.temp.php', $contents); move(MADELINE_PHP.'.temp.php', MADELINE_PHP); $unlock(); $madelinePhpContents = $contents; } $latest = $client->request($request); Magic::$version_latest = \trim($latest->getBody()->buffer()); if (Magic::$version !== Magic::$version_latest) { Logger::log('!!!!!!!!!!!!! An update of MadelineProto is required, shutting down worker! !!!!!!!!!!!!!', Logger::FATAL_ERROR); write(MADELINE_PHAR_VERSION, ''); if (Magic::$isIpcWorker) { throw new SignalException('!!!!!!!!!!!!! An update of MadelineProto is required, shutting down worker! !!!!!!!!!!!!!'); } if ($id) { EventLoop::cancel($id); } return; } foreach (\glob(MADELINE_PHAR_GLOB) as $path) { $base = \basename($path); if ($base === 'madeline-'.Magic::$version.'.phar') { continue; } $f = \fopen("$path.lock", 'c'); if (\flock($f, LOCK_EX|LOCK_NB)) { \fclose($f); \unlink($path); \unlink("$path.lock"); } else { \fclose($f); } } } catch (Throwable $e) { Logger::log("An error occurred in the phar cleanup loop: $e", Logger::FATAL_ERROR); } }; $cb(); EventLoop::unreference($id = EventLoop::repeat(60.0, $cb)); } /** @var \WeakMap<\Fiber, true> */ public static WeakMap $map; public static function registerFiber(\Fiber $fiber): void { self::$map ??= new WeakMap; self::$map[$fiber] = true; } private static function getMemoryConsumption(): int { $memory = \round(\memory_get_usage()/1024/1024, 1); if (!Magic::$suspendPeriodicLogging) { /*$k = 0; foreach (self::$map as $fiber => $_) { if ($k++ === 0) { continue; } if ($fiber->isTerminated()) { continue; } if (!$fiber->isStarted()) { continue; } $reflection = new ReflectionFiber($fiber); $tlTrace = ''; foreach ($reflection->getTrace() as $k => $frame) { $tlTrace .= isset($frame['file']) ? \str_pad(\basename($frame['file']).'('.$frame['line'].'):', 20)."\t" : ''; $tlTrace .= isset($frame['function']) ? $frame['function'].'(' : ''; $tlTrace .= isset($frame['args']) ? \substr(\json_encode($frame['args']) ?: '', 1, -1) : ''; $tlTrace .= ')'; $tlTrace .= "\n"; } \var_dump($tlTrace); } Logger::log("Memory consumption: $memory Mb", Logger::ULTRA_VERBOSE); $fibers = self::$map->count(); $maps = '~'.\substr_count(\file_get_contents('/proc/self/maps'), "\n"); Logger::log("Running fibers: $fibers, maps: $maps", Logger::ULTRA_VERBOSE);*/ } return (int) $memory; } }