Skip to content

v2.7.0

Compare
Choose a tag to compare
@roxblnfk roxblnfk released this 23 Dec 16:39
· 436 commits to master since this release
v2.7.0
403baf4

Schedule API

Temporal Schedules are a replacement for traditional cron jobs for task scheduling because the Schedules provide a more durable way to execute tasks, allow insight into their progress, enable observability of schedules and workflow runs, and let you start, stop, and pause them.

Starting with this release, the Temporal PHP SDK begins to provide new primitives for Schedule CRUD operations.

use Temporal\Client\Schedule;

// Start from creating the Schedule Client
// If you use a Temporal integration package with your framework, you can
// get the client from the container using the `ScheduleClientInterface` interface.
$client = \Temporal\Client\ScheduleClient::create(
    \Temporal\Client\GRPC\ServiceClient::create('localhost:7233'),
);

// Create a Schedule
$handle = $client->createSchedule(
    Schedule\Schedule::new()->withAction(
        Schedule\Action\StartWorkflowAction::new('testWorkflow')
            ->withTaskQueue('testTaskQueue')
            ->withRetryPolicy(\Temporal\Common\RetryOptions::new()->withMaximumAttempts(3))
            ->withHeader(['foo' => 'bar'])
            ->withWorkflowExecutionTimeout('40m')
    )->withSpec(
        Schedule\Spec\ScheduleSpec::new()
            ->withIntervalList(5 * 60) // every 5 minutes
            ->withJitter(60) // with jitter of 1 minute
    ),
    scheduleId: 'my-schedule-id',
);

// Pause the Schedule
$handle->pause();

// Trigger the Action to be taken immediately
$handle->trigger(Schedule\Policy\ScheduleOverlapPolicy::CancelOther);

// Delete the Schedule
$handle->delete();

To get a handle to an existing Schedule, use the ScheduleClient::getHandle() method.

$client = \Temporal\Client\ScheduleClient::create(
    \Temporal\Client\GRPC\ServiceClient::create('localhost:7233'),
);

// Get a handle to an existing Schedule
$handle = $client->getHandle(scheduleID: 'my-schedule-id');

// Describe the Schedule
$description = $handle->describe();

// Update the Schedule
$handle->update(
    $description->schedule->withSpec(
        \Temporal\Client\Schedule\Spec\ScheduleSpec::new()
            ->withCronStringList('0 12 * * 5', '0 12 * * 1')
    ),
    conflictToken: $description->conflictToken, // To avoid race condition
);

Workflow Start Delay

Use the Workflow Start Delay functionality if you need to delay the execution of the Workflow without the need for regular launches.
Here you simply specify the time to wait before dispatching the first Workflow task.
If the Workflow gets a Signal before the delay, a Workflow task will be dispatched and the rest of the delay will be ignored. A Signal from WorkflowClientInterface::startWithSignal() won't trigger a workflow task.
Cannot be set the same time as a WorkflowOptions::withCronSchedule().

/** @var \Temporal\Client\WorkflowClientInterface $client */

$workflow = $client->newWorkflowStub(
    GreeterWorkflowInterface::class,
    \Temporal\Client\WorkflowOptions::new()
        ->withWorkflowStartDelay(\DateInterval::createFromDateString('1 minute'))
);
$client->start($workflow, 'Hello world!');

Interceptors

Temporal Interceptors are a mechanism for modifying inbound and outbound SDK calls. They are commonly used to add tracing and authorization to the scheduling and execution of Workflows and Activities. You can compare these to "middleware" in other frameworks.

The following types of Interceptors have been implemented:

Please note that some interceptor interfaces will be expanded in the future. To avoid compatibility issues, always use the corresponding traits in your implementations. The traits will prevent implementations from breaking when new methods are added to the interfaces.
A reminder of this and a link to the corresponding trait are placed in the comments of the interceptor interfaces.

In this release, we have also added support for headers, which are an integral part of interceptors. Headers, being metadata, are intended for sharing context and auxiliary information. Headers sent at the start of a workflow will be propagated to all subsequent calls from the Workflow and can only be modified in interceptors.

You can find examples of how to use interceptors in the samples repository (PR)

Full Changelog: v2.6.2...v2.7.0