mirror of
https://github.com/appwrite/appwrite
synced 2026-05-06 14:58:33 +00:00
82 lines
2.6 KiB
PHP
82 lines
2.6 KiB
PHP
<?php
|
|
|
|
namespace Appwrite\Platform\Tasks;
|
|
|
|
use Appwrite\Event\Func;
|
|
use Swoole\Coroutine as Co;
|
|
use Utopia\Database\Database;
|
|
use Utopia\Pools\Group;
|
|
|
|
class ScheduleExecutions extends ScheduleBase
|
|
{
|
|
public const UPDATE_TIMER = 3; // seconds
|
|
public const ENQUEUE_TIMER = 4; // seconds
|
|
|
|
public static function getName(): string
|
|
{
|
|
return 'schedule-executions';
|
|
}
|
|
|
|
public static function getSupportedResource(): string
|
|
{
|
|
return 'execution';
|
|
}
|
|
|
|
protected function enqueueResources(Group $pools, Database $dbForConsole): void
|
|
{
|
|
$queue = $pools->get('queue')->pop();
|
|
$connection = $queue->getResource();
|
|
$queueForFunctions = new Func($connection);
|
|
$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) {
|
|
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']]);
|
|
}
|
|
|
|
$queue->reclaim();
|
|
}
|
|
}
|