Skip to content

Commit

Permalink
Merge pull request #540: Update readme
Browse files Browse the repository at this point in the history
  • Loading branch information
roxblnfk authored Dec 19, 2024
2 parents 5cf33ab + 340d39e commit fb4d5ec
Show file tree
Hide file tree
Showing 41 changed files with 189 additions and 131 deletions.
159 changes: 141 additions & 18 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,42 +1,165 @@
# Temporal PHP SDK

[![CI Status](https://github.com/temporalio/sdk-php/actions/workflows/testing.yml/badge.svg)](https://github.com/temporalio/php-sdk/actions)
[![Stable Release](https://poser.pugx.org/temporal/sdk/version)](https://packagist.org/packages/temporal/sdk)
[![FOSSA Status](https://app.fossa.com/api/projects/git%2Bgithub.com%2Ftemporalio%2Fsdk-php.svg?type=shield)](https://app.fossa.com/projects/git%2Bgithub.com%2Ftemporalio%2Fsdk-php?ref=badge_shield)

## Introduction

Temporal is a distributed, scalable, durable, and highly available orchestration
engine used to execute asynchronous long-running business logic in a scalable
and resilient way.

"Temporal PHP SDK" is the framework for authoring workflows and activities using
PHP language.
Temporal PHP SDK is the framework for authoring [Workflows](https://docs.temporal.io/workflows) and [Activities](https://docs.temporal.io/activities) using PHP language.

**Table of contents:**
- [Get starting](#get-starting)
- [Installation](#installation)
- [Usage](#usage)
- [Testing](#testing)
- [Dev environment](#dev-environment)
- [Temporal CLI](#temporal-cli)
- [Buggregator](#buggregator)
- [Resources](#resources)
- [License](#license)

## Installation
## Get starting

SDK is available as composer package and can be installed using the
following command in a root of your project:
### Installation

Install the SDK using Composer:

```bash
composer require temporal/sdk
```

Make sure to install [RoadRunner](https://github.com/spiral/roadrunner) to enable workflow and activity consumption in your PHP workers.
[![PHP](https://img.shields.io/packagist/php-v/temporal/sdk.svg?style=flat-square&logo=php)](https://packagist.org/packages/temporal/sdk)
[![Stable Release](https://poser.pugx.org/temporal/sdk/version?style=flat-square)](https://packagist.org/packages/temporal/sdk)
[![Total DLoads](https://img.shields.io/packagist/dt/temporal/sdk.svg?style=flat-square)](https://packagist.org/packages/temporal/sdk/stats)
[![License](https://img.shields.io/packagist/l/temporal/sdk.svg?style=flat-square)](LICENSE.md)

The SDK includes two main components: [Clients](https://docs.temporal.io/develop/php/temporal-clients) and Workers.
The Clients component is used to start, schedule, and manage Workflows;
the Workers component is used to execute Workflows and Activities.

The Clients component requires the [`grpc`](https://pecl.php.net/package/grpc) extension,
and the Workers component requires [RoadRunner](https://roadrunner.dev).
It's recommended to use both components with the [`protobuf`](https://pecl.php.net/package/protobuf) extension
in production to improve performance.

| | Client | Worker |
|--------------|-------------|-------------|
| RoadRunner || required |
| ext-grpc | required ||
| ext-protobuf | recommended | recommended |

To download RoadRunner, you can use the following command:

```bash
./vendor/bin/rr get
```

## Usage
### Usage

See [examples](https://github.com/temporalio/samples-php) to get started.
If you are using [Spiral](https://github.com/spiral/framework),
follow the [instructions in the documentation](https://spiral.dev/docs/temporal-configuration/).

If you are using the SDK without integrations, the following sections of the documentation may be helpful:
- [How to run Worker Processes](https://docs.temporal.io/develop/php/core-application#run-a-dev-worker)
- [How to develop a basic Workflow](https://docs.temporal.io/develop/php/core-application#develop-workflows)
- [How to connect a Temporal Client to a Temporal Service](https://docs.temporal.io/develop/php/temporal-clients#connect-to-a-dev-cluster)
- [How to start a Workflow Execution](https://docs.temporal.io/develop/php/temporal-clients#start-workflow-execution)

> [!NOTE]
> Check out [the repository with examples](https://github.com/temporalio/samples-php) of using the PHP SDK.
> [!WARNING]
> Since version [`2.11.0`](https://github.com/temporalio/sdk-php/releases/tag/v2.11.0),
> [feature flags](https://github.com/temporalio/sdk-php/blob/master/src/Worker/FeatureFlags.php) were introduced
> that change the behavior of the entire PHP worker.
> It's recommended to disable deprecated behavior.
## Testing

See [testing manual](testing/Readme.md) to get started.
The PHP SDK includes a toolkit for testing Workflows.
There is [documentation](https://docs.temporal.io/develop/php/testing-suite) and [dev guide](testing/Readme.md) on how to test a Workflow using Activity mocking.

To ensure the determinism of a Workflow,
you can also use the [Replay API in tests](https://docs.temporal.io/develop/php/testing-suite#replay).

## Dev environment

Some recommendations for setting up a development environment:

### Temporal CLI

The [Temporal CLI](https://docs.temporal.io/cli) provides direct access to a Temporal Service via the terminal.
You can use it to start, stop, inspect and operate on Workflows and Activities,
and perform administrative tasks such as Namespace, Schedule, and Task Queue management.
The Temporal CLI also includes an embedded Temporal Service suitable for use in development and CI/CD.
It includes the Temporal Server, SQLite persistence, and the Temporal Web UI.

Run the following command to start the Temporal Service in development mode:

```bash
temporal server start-dev --log-level error
```

Experimental features:
- Add flags `--dynamic-config-value frontend.enableUpdateWorkflowExecution=true --dynamic-config-value frontend.enableUpdateWorkflowExecutionAsyncAccepted=true`
to enable the [Workflow Update feature](https://docs.temporal.io/encyclopedia/workflow-message-passing#sending-updates).
- Add flag `--dynamic-config-value frontend.enableExecuteMultiOperation=true` to enable [`updateWithStart()` feature](https://php.temporal.io/classes/Temporal-Client-WorkflowClient.html#method_updateWithStart).
- Add flag `--dynamic-config-value system.enableEagerWorkflowStart=true` to enable the [Eager Workflow Start feature](https://docs.temporal.io/develop/advanced-start-options#eager-start).

### Buggregator

During development, you might need to dump a variable, throw an error trace, or simply look at the call stack.
Since Workflows and Activities run in RoadRunner workers, you cannot use `var_dump`,
`print_r`, `echo`, and other functions that output data to STDOUT.

Instead, use [Buggregator](https://buggregator.dev) along with [Trap](https://github.com/buggregator/trap).
In this case, dumps, traces, and logs will be sent via socket to your local Buggregator server,
where you can view them in a convenient web interface.

> [!TIP]
> Trap is a wrapper around `symfony/var-dumper`, providing additional debugging capabilities.
> Moreover, Trap patches var-dumper for outputting protobuf structures, which is very handy when working with Temporal.
To run Buggregator in Docker, execute the command below
and follow the [instructions](https://docs.buggregator.dev/config/var-dumper.html#configuration):

```bash
docker run --rm -p 8000:8000 -p 1025:1025 -p 9912:9912 -p 9913:9913 ghcr.io/buggregator/server:latest
```

If you are not using Docker or running PHP code outside a container, you can use Trap as a compact server:

```bash
./vendor/bin/trap --ui=8000
```

Now use the `trap()`, `tr()`, or `dump()` functions to output data to Buggregator.
Web UI will be available at `http://localhost:8000`.

## Resources

Read the docs
[![Temporal Documentation](https://img.shields.io/static/v1?style=flat-square&label=&message=Dcumentation&logo=Temporal&color=7744ee)](https://docs.temporal.io/)
[![PHP SDK Documentation](https://img.shields.io/static/v1?style=flat-square&label=PHP+SDK&message=Dev+guide&logo=Temporal&color=7766ee)](https://docs.temporal.io/develop/php)
[![PHP SDK API](https://img.shields.io/static/v1?style=flat-square&label=PHP+SDK&message=API&logo=PHP&color=447723&logoColor=aa88ff)](https://php.temporal.io/)

Ask a question
[![Github issues](https://img.shields.io/static/v1?style=flat-square&label=&message=Issues&logo=Github&color=202020)](https://github.com/temporalio/sdk-php/issues)
[![Slack](https://img.shields.io/static/v1?style=flat-square&label=&message=Slack&logo=Slack&color=cc4444)](https://t.mp/slack)
[![Forum](https://img.shields.io/static/v1?style=flat-square&label=&message=Forum&logo=Discourse&color=4477ee)](https://community.temporal.io/tag/php-sdk)
[![Discord](https://img.shields.io/static/v1?style=flat-square&label=&message=Discord&logo=Discord&color=333333)](https://discord.gg/FwmDtGQe55)

Stay tuned
[![Read Blog](https://img.shields.io/static/v1?style=flat-square&label=&message=Read+the+Blog&logo=Temporal&color=312f2b)](https://temporal.io/blog)
[![Temporal YT Channel](https://img.shields.io/static/v1?style=flat-square&label=&message=Watch+on+Youtube&logo=youtube&color=b9002a)](https://www.youtube.com/temporalio)
[![X](https://img.shields.io/badge/-Follow-black?style=flat-square&logo=X)](https://x.com/temporalio)

Additionally
[![Temporal community](https://img.shields.io/static/v1?style=flat-square&label=&message=Community&color=ff6644&logo=)](https://temporal.io/community)
[![Awesome Temporal](https://img.shields.io/static/v1?style=flat-square&label=&message=Awesome+Temporal&logo=Awesome-Lists&color=4b4567)](https://github.com/temporalio/awesome-temporal)

## Documentation
The documentation on how to use the Temporal PHP SDK and client is [here](https://docs.temporal.io/).

## License
MIT License, please see [LICENSE](LICENSE.md) for details.

Temporal PHP SDK is open-sourced software licensed under the [MIT license](https://opensource.org/licenses/MIT).

[![FOSSA Status](https://app.fossa.com/api/projects/git%2Bgithub.com%2Ftemporalio%2Fsdk-php.svg?type=large)](https://app.fossa.com/projects/git%2Bgithub.com%2Ftemporalio%2Fsdk-php?ref=badge_large)
4 changes: 0 additions & 4 deletions src/Activity/ActivityContextInterface.php
Original file line number Diff line number Diff line change
Expand Up @@ -21,23 +21,20 @@ interface ActivityContextInterface
* Returns information about current activity execution.
*
* @see Activity::getInfo()
*
*/
public function getInfo(): ActivityInfo;

/**
* Returns activity execution input arguments.
*
* @see Activity::getInput()
*
*/
public function getInput(): ValuesInterface;

/**
* Check if the heartbeat's first argument has been passed.
*
* @see Activity::hasHeartbeatDetails()
*
*/
public function hasHeartbeatDetails(): bool;

Expand All @@ -55,7 +52,6 @@ public function getHeartbeatDetails($type = null);
* Marks the activity as incomplete for asynchronous completion.
*
* @see Activity::doNotCompleteOnReturn()
*
*/
public function doNotCompleteOnReturn(): void;

Expand Down
8 changes: 0 additions & 8 deletions src/Activity/ActivityInfo.php
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,6 @@ final class ActivityInfo
* A correlation token that can be used to complete the activity through `complete` method.
*
* @see ActivityCompletionClientInterface::complete()
*
*/
#[Marshal(name: 'TaskToken')]
public string $taskToken;
Expand All @@ -56,14 +55,12 @@ final class ActivityInfo
* activity through `complete` method.
*
* @see ActivityCompletionClientInterface::complete()
*
*/
#[Marshal(name: 'ActivityID')]
public string $id;

/**
* Type (name) of the activity.
*
*/
#[Marshal(name: 'ActivityType', type: ObjectType::class, of: ActivityType::class)]
public ActivityType $type;
Expand All @@ -73,36 +70,31 @@ final class ActivityInfo

/**
* Maximum time between heartbeats. 0 means no heartbeat needed.
*
*/
#[Marshal(name: 'HeartbeatTimeout', type: DateIntervalType::class)]
public \DateInterval $heartbeatTimeout;

/**
* Time of activity scheduled by a workflow
*
*/
#[Marshal(name: 'ScheduledTime', type: DateTimeType::class)]
public \DateTimeInterface $scheduledTime;

/**
* Time of activity start
*
*/
#[Marshal(name: 'StartedTime', type: DateTimeType::class)]
public \DateTimeInterface $startedTime;

/**
* Time of activity timeout
*
*/
#[Marshal(name: 'Deadline', type: DateTimeType::class)]
public \DateTimeInterface $deadline;

/**
* Attempt starts from 1, and increased by 1 for every retry if
* retry policy is specified.
*
*/
#[Marshal(name: 'Attempt')]
public int $attempt = 1;
Expand Down
1 change: 0 additions & 1 deletion src/Client/Common/RpcRetryOptions.php
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,6 @@ public function withCongestionInitialInterval($interval): self
*
* @param null|float $coefficient Maximum amount of jitter.
* Default will be used if set to {@see null}.
*
*/
#[Pure]
public function withMaximumJitterCoefficient(?float $coefficient): self
Expand Down
1 change: 0 additions & 1 deletion src/Client/GRPC/BaseClient.php
Original file line number Diff line number Diff line change
Expand Up @@ -165,7 +165,6 @@ public function close(): void

/**
* @param null|Pipeline<GrpcClientInterceptor, object> $pipeline
*
*/
final public function withInterceptorPipeline(?Pipeline $pipeline): static
{
Expand Down
1 change: 0 additions & 1 deletion src/Client/Update/UpdateHandle.php
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,6 @@ public function getId(): string

/**
* Check there is a cached accepted result or failure for this update request.
*
*/
public function hasResult(): bool
{
Expand Down
Loading

0 comments on commit fb4d5ec

Please sign in to comment.