connections->add($connection, $pool); $queuePool = $pools['pools-queue-queue']['pool']; $queueConnection = $queuePool->get(); $this->connections->add($queueConnection, $queuePool); $queueForFunctions = new Func(new Redis($queueConnection)); $intervalEnd = (new \DateTime())->modify('+' . self::ENQUEUE_TIMER . ' seconds'); foreach ($this->schedules as $schedule) { if (!$schedule['active']) { $dbForConsole->deleteDocument( 'schedules', $schedule['$id'], ); unset($this->schedules[$schedule['$internalId']]); continue; } $scheduledAt = new \DateTime($schedule['schedule']); if ($scheduledAt <= $intervalEnd) { continue; } $data = $dbForConsole->getDocument( 'schedules', $schedule['$id'], )->getAttribute('data', []); $delay = $scheduledAt->getTimestamp() - (new \DateTime())->getTimestamp(); \go(function () use ($queueForFunctions, $schedule, $delay, $data, $dbForConsole) { Co::sleep($delay); $queueForFunctions->setType('schedule') // Set functionId instead of function as we don't have $dbForProject // TODO: Refactor to use function instead of functionId ->setFunctionId($schedule['resource']['functionId']) ->setExecution($schedule['resource']) ->setMethod($data['method'] ?? 'POST') ->setPath($data['path'] ?? '/') ->setHeaders($data['headers'] ?? []) ->setBody($data['body'] ?? '') ->setProject($schedule['project']) ->setUserId($data['userId'] ?? '') ->trigger(); $dbForConsole->deleteDocument( 'schedules', $schedule['$id'], ); }); unset($this->schedules[$schedule['$internalId']]); } $this->connections->reclaim(); } }