modify('+' . self::ENQUEUE_TIMER . ' seconds'); $queueForFunctions = new Func($this->publisherFunctions); foreach ($this->schedules as $schedule) { if (!$schedule['active']) { $dbForPlatform->deleteDocument( 'schedules', $schedule['$id'], ); unset($this->schedules[$schedule['$sequence']]); continue; } $scheduledAt = new \DateTime($schedule['schedule']); if ($scheduledAt <= $intervalEnd) { continue; } $data = $dbForPlatform->getDocument( 'schedules', $schedule['$id'], )->getAttribute('data', []); $delay = $scheduledAt->getTimestamp() - (new \DateTime())->getTimestamp(); $this->updateProjectAccess($schedule['project'], $dbForPlatform); \go(function () use ($queueForFunctions, $schedule, $scheduledAt, $delay, $data) { 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']['resourceId']) ->setExecution($schedule['resource']) ->setMethod($data['method'] ?? 'POST') ->setPath($data['path'] ?? '/') ->setHeaders($data['headers'] ?? []) ->setBody($data['body'] ?? '') ->setProject($schedule['project']) ->setUserId($data['userId'] ?? '') ->trigger(); $this->recordEnqueueDelay($scheduledAt); }); $dbForPlatform->deleteDocument( 'schedules', $schedule['$id'], ); unset($this->schedules[$schedule['$sequence']]); } } }