@@ -12,161 +12,147 @@
This package allows Google Cloud Tasks to be used as the queue driver.
-
+
-
-
- Requirements
-
+### Requirements
-
- This package requires Laravel 6 or higher and supports MySQL 8 and PostgreSQL 14. Might support older database versions too, but package hasn't been tested for it.
+This package requires Laravel 10 or 11.
-Please check the [Laravel support policy](https://laravel.com/docs/master/releases#support-policy) table for supported Laravel and PHP versions.
-
-
- Installation
-
-
- Require the package using Composer
-
- ```console
- composer require stackkit/laravel-google-cloud-tasks-queue
- ```
-
- Add a new queue connection to `config/queue.php`
-
- ```php
- 'cloudtasks' => [
- 'driver' => 'cloudtasks',
- 'project' => env('STACKKIT_CLOUD_TASKS_PROJECT', ''),
- 'location' => env('STACKKIT_CLOUD_TASKS_LOCATION', ''),
- 'queue' => env('STACKKIT_CLOUD_TASKS_QUEUE', 'default'),
-
- // Required when using AppEngine
- 'app_engine' => env('STACKKIT_APP_ENGINE_TASK', false),
- 'app_engine_service' => env('STACKKIT_APP_ENGINE_SERVICE', ''),
-
- // Required when not using AppEngine
- 'handler' => env('STACKKIT_CLOUD_TASKS_HANDLER', ''),
- 'service_account_email' => env('STACKKIT_CLOUD_TASKS_SERVICE_EMAIL', ''),
- 'signed_audience' => env('STACKKIT_CLOUD_TASKS_SIGNED_AUDIENCE', true),
-
- // Optional: The deadline in seconds for requests sent to the worker. If the worker
- // does not respond by this deadline then the request is cancelled and the attempt
- // is marked as a DEADLINE_EXCEEDED failure.
- 'dispatch_deadline' => null,
- 'backoff' => 0,
- ],
- ```
-
-Update the `QUEUE_CONNECTION` environment variable
-
- ```dotenv
- QUEUE_CONNECTION=cloudtasks
- ```
+### Installation
+
+Require the package using Composer
+
+```console
+composer require stackkit/laravel-google-cloud-tasks-queue
+```
+
+Publish the service provider:
+
+```console
+php artisan vendor:publish --provider=cloud-tasks
+```
+
+Add a new queue connection to `config/queue.php`
+
+```php
+'cloudtasks' => [
+ 'driver' => 'cloudtasks',
+ 'project' => env('CLOUD_TASKS_PROJECT', ''),
+ 'location' => env('CLOUD_TASKS_LOCATION', ''),
+ 'queue' => env('CLOUD_TASKS_QUEUE', 'default'),
+
+ // Required when using AppEngine
+ 'app_engine' => env('APP_ENGINE_TASK', false),
+ 'app_engine_service' => env('APP_ENGINE_SERVICE', ''),
+
+ // Required when not using AppEngine
+ 'handler' => env('CLOUD_TASKS_HANDLER', ''),
+ 'service_account_email' => env('CLOUD_TASKS_SERVICE_EMAIL', ''),
+
+ 'backoff' => 0,
+],
+```
+
+If you are using separate services for dispatching and handling tasks, and your application only dispatches jobs and should not be able to handle jobs, you may disable the task handler from `config/cloud-tasks.php`:
+
+```php
+'disable_task_handler' => env('CLOUD_TASKS_DISABLE_TASK_HANDLER', false),
+```
+
+Finally, change the `QUEUE_CONNECTION` to the newly defined connection.
+
+```dotenv
+QUEUE_CONNECTION=cloudtasks
+```
Now that the package is installed, the final step is to set the correct environment variables.
Please check the table below on what the values mean and what their value should be.
-| Environment variable | Description |Example
----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|---
-| `STACKKIT_CLOUD_TASKS_PROJECT` | The project your queue belongs to. |`my-project`
-| `STACKKIT_CLOUD_TASKS_LOCATION` | The region where the project is hosted. |`europe-west6`
-| `STACKKIT_CLOUD_TASKS_QUEUE` | The default queue a job will be added to. |`emails`
-| **App Engine**
-| `STACKKIT_APP_ENGINE_TASK` (optional) | Set to true to use App Engine task (else a Http task will be used). Defaults to false. |`true`
-| `STACKKIT_APP_ENGINE_SERVICE` (optional) | The App Engine service to handle the task (only if using App Engine task). |`api`
-| **Non- App Engine apps**
-| `STACKKIT_CLOUD_TASKS_SERVICE_EMAIL` (optional) | The email address of the service account. Important, it should have the correct roles. See the section below which roles. |`my-service-account@appspot.gserviceaccount.com`
-| `STACKKIT_CLOUD_TASKS_HANDLER` (optional) | The URL that Cloud Tasks will call to process a job. This should be the URL to your Laravel app. By default we will use the URL that dispatched the job. |`https://.com`
-| `STACKKIT_CLOUD_TASKS_SIGNED_AUDIENCE` (optional) | True or false depending if you want extra security by signing the audience of your tasks. May misbehave in certain Cloud Run setups. Defaults to true. | `true`
+| Environment variable | Description | Example
+---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------
+| `CLOUD_TASKS_PROJECT` | The project your queue belongs to. | `my-project`
+| `CLOUD_TASKS_LOCATION` | The region where the project is hosted. | `europe-west6`
+| `CLOUD_TASKS_QUEUE` | The default queue a job will be added to. | `emails`
+| **App Engine**
+| `APP_ENGINE_TASK` (optional) | Set to true to use App Engine task (else a Http task will be used). Defaults to false. | `true`
+| `APP_ENGINE_SERVICE` (optional) | The App Engine service to handle the task (only if using App Engine task). | `api`
+| **Non- App Engine apps**
+| `CLOUD_TASKS_SERVICE_EMAIL` (optional) | The email address of the service account. Important, it should have the correct roles. See the section below which roles. | `my-service-account@appspot.gserviceaccount.com`
+| `CLOUD_TASKS_HANDLER` (optional) | The URL that Cloud Tasks will call to process a job. This should be the URL to your Laravel app. By default we will use the URL that dispatched the job. | `https://.com`
+
-
-
- How it works & Differences
-
-
- Using Cloud Tasks as a Laravel queue driver is fundamentally different than other Laravel queue drivers, like Redis.
-Typically a Laravel queue has a worker that listens to incoming jobs using the `queue:work` / `queue:listen` command.
-With Cloud Tasks, this is not the case. Instead, Cloud Tasks will schedule the job for you and make an HTTP request to your application with the job payload. There is no need to run a `queue:work/listen` command.
+### How to
-#### Good to know
+#### Passing headers to a task
-- The "Min backoff" and "Max backoff" options in Cloud Tasks are ignored. This is intentional: Laravel has its own backoff feature (which is more powerful than what Cloud Tasks offers) and therefore I have chosen that over the Cloud Tasks one.
-- Similarly to the backoff feature, I have also chosen to let the package do job retries the 'Laravel way'. In Cloud Tasks, when a task throws an exception, Cloud Tasks will decide for itself when to retry the task (based on the backoff values). It will also manage its own state and knows how many times a task has been retried. This is different from Laravel. In typical Laravel queues, when a job throws an exception, the job is deleted and released back onto the queue. In order to support Laravel's backoff feature, this package must behave the same way about job retries.
+You can pass headers to a task by using the `setTaskHeadersUsing` method on the `CloudTasksQueue` class.
-
-
- Dashboard (beta)
-
- The package comes with a beautiful dashboard that can be used to monitor all queued jobs.
+```php
+use Stackkit\LaravelGoogleCloudTasksQueue\CloudTasksQueue;
+CloudTasksQueue::setTaskHeadersUsing(static fn() => [
+ 'X-My-Header' => 'My-Value',
+]);
+```
-
+If necessary, the current payload being dispatched is also available:
- ---
+```php
+use Stackkit\LaravelGoogleCloudTasksQueue\CloudTasksQueue;
-_Experimental_
+CloudTasksQueue::setTaskHeadersUsing(static fn(array $payload) => [
+ 'X-My-Header' => $payload['displayName'],
+]);
+```
-The dashboard works by storing all outgoing tasks in a database table. When Cloud Tasks calls the application and this
-package handles the task, we will automatically update the tasks' status, attempts
-and possible errors.
+#### Configure task handler url
-There is probably a (small) performance penalty because each task dispatch and handling does extra database read and writes.
-Also, the dashboard has not been tested with high throughput queues.
+You can set the handler url for a task by using the `configureHandlerUrlUsing` method on the `CloudTasksQueue` class.
- ---
+```php
+use Stackkit\LaravelGoogleCloudTasksQueue\CloudTasksQueue;
+CloudTasksQueue::configureHandlerUrlUsing(static fn() => 'https://example.com/my-url');
+```
-To make use of it, enable it through the `.env` file:
+If necessary, the current job being dispatched is also available:
- ```dotenv
- STACKKIT_CLOUD_TASKS_DASHBOARD_ENABLED=true
- STACKKIT_CLOUD_TASKS_DASHBOARD_PASSWORD=MySecretLoginPasswordPleaseChangeThis
- ```
+```php
+use Stackkit\LaravelGoogleCloudTasksQueue\CloudTasksQueue;
-Then publish its assets and migrations:
+CloudTasksQueue::configureHandlerUrlUsing(static fn(MyJob $job) => 'https://example.com/my-url/' . $job->something());
+```
- ```console
- php artisan vendor:publish --tag=cloud-tasks
- php artisan migrate
- ```
+### How it works and differences
-The dashboard is accessible at the URI: /cloud-tasks
+Using Cloud Tasks as a Laravel queue driver is fundamentally different than other Laravel queue drivers, like Redis.
-
-
- Authentication
-
+Typically a Laravel queue has a worker that listens to incoming jobs using the `queue:work` / `queue:listen` command.
+With Cloud Tasks, this is not the case. Instead, Cloud Tasks will schedule the job for you and make an HTTP request to
+your application with the job payload. There is no need to run a `queue:work/listen` command.
+
+#### Good to know
+
+Cloud Tasks has it's own retry configuration options: maximum number of attempts, retry duration, min/max backoff and max doublings. All of these options are ignored by this package. Instead, you may configure max attempts, retry duration and backoff strategy right from Laravel.
+
+### Authentication
Set the `GOOGLE_APPLICATION_CREDENTIALS` environment variable with a path to the credentials file.
More info: https://cloud.google.com/docs/authentication/production
-If you're not using your master service account (which has all abilities), you must add the following roles to make it works:
+If you're not using your master service account (which has all abilities), you must add the following roles to make it
+works:
+
1. App Engine Viewer
2. Cloud Tasks Enqueuer
3. Cloud Tasks Viewer
4. Cloud Tasks Task Deleter
5. Service Account User
-
-
- Security
-
- The job handler requires each request to have an OpenID token. In the installation step we set the service account email, and with that service account, Cloud Tasks will generate an OpenID token and send it along with the job payload to the handler.
-This package verifies that the token is digitally signed by Google. Only Google Tasks will be able to call your handler.
+### Upgrading
-More information about OpenID Connect:
-
-https://developers.google.com/identity/protocols/oauth2/openid-connect
-
-
- Upgrading
-
- Read [UPGRADING.MD](UPGRADING.md) on how to update versions.
-
+Read [UPGRADING.MD](UPGRADING.md) on how to update versions.
diff --git a/UPGRADING.md b/UPGRADING.md
index 93d0a71..f68380c 100644
--- a/UPGRADING.md
+++ b/UPGRADING.md
@@ -1,3 +1,41 @@
+# From 3.x to 4.x
+
+## Renamed environment names (Impact: high)
+
+The following environment variables have been shortened:
+- `STACKKIT_CLOUD_TASKS_PROJECT` → `CLOUD_TASKS_PROJECT`
+- `STACKKIT_CLOUD_TASKS_LOCATION` → `CLOUD_TASKS_LOCATION`
+- `STACKKIT_CLOUD_TASKS_QUEUE` → `CLOUD_TASKS_QUEUE`
+- `STACKKIT_CLOUD_TASKS_HANDLER` → `CLOUD_TASKS_HANDLER`
+- `STACKKIT_CLOUD_TASKS_SERVICE_EMAIL` → `CLOUD_TASKS_SERVICE_EMAIL`
+
+The following environment variables have been renamed to be more consistent:
+
+- `STACKKIT_APP_ENGINE_TASK` → `CLOUD_TASKS_APP_ENGINE_TASK`
+- `STACKKIT_APP_ENGINE_SERVICE` → `CLOUD_TASKS_APP_ENGINE_SERVICE`
+
+The following environment variable has been removed:
+- `STACKKIT_CLOUD_TASKS_SIGNED_AUDIENCE`
+
+## Removed dashboard (Impact: high)
+
+The dashboard has been removed to keep the package minimal. A separate composer package might be created with an updated version of the dashboard.
+
+## New configuration file (Impact: medium)
+
+The configuration file has been updated to reflect the removed dashboard and to add new configurable options.
+
+Please publish the new configuration file:
+
+```shell
+php artisan vendor:publish --tag=cloud-tasks --force
+```
+
+## Dispatch deadline (Impact: medium)
+
+The `dispatch_deadline` has been removed from the task configuration. You may now use Laravel's timeout configuration to control the maximum execution time of a task.
+
+
# From 2.x to 3.x
PHP 7.2 and 7.3, and Laravel 5.x are no longer supported.
diff --git a/assets/dashboard.png b/assets/dashboard.png
deleted file mode 100644
index 0051f17..0000000
Binary files a/assets/dashboard.png and /dev/null differ
diff --git a/composer.json b/composer.json
index cf4f0ba..1b5ea29 100644
--- a/composer.json
+++ b/composer.json
@@ -8,17 +8,18 @@
}
],
"require": {
+ "php": "^8.1",
"ext-json": "*",
"phpseclib/phpseclib": "^3.0",
- "google/auth": "^v1.29.1",
"google/cloud-tasks": "^1.10",
"thecodingmachine/safe": "^1.0|^2.0"
},
"require-dev": {
- "orchestra/testbench": "^4.0 || ^5.0 || ^6.0 || ^7.0 || ^8.0",
- "nunomaduro/larastan": "^1.0 || ^2.0",
+ "orchestra/testbench": "^8.0",
"thecodingmachine/phpstan-safe-rule": "^1.2",
- "laravel/legacy-factories": "^1.3"
+ "laravel/legacy-factories": "^1.3",
+ "laravel/pint": "^1.13",
+ "larastan/larastan": "^2.9"
},
"autoload": {
"psr-4": {
@@ -45,21 +46,11 @@
"composer require laravel/framework:10.* orchestra/testbench:8.* --no-interaction --no-update",
"composer update --prefer-stable --prefer-dist --no-interaction"
],
- "l9": [
- "composer require laravel/framework:9.* orchestra/testbench:7.* --no-interaction --no-update",
- "composer update --prefer-stable --prefer-dist --no-interaction"
- ],
- "l8": [
- "composer require laravel/framework:8.* orchestra/testbench:6.* --no-interaction --no-update",
- "composer update --prefer-stable --prefer-dist --no-interaction"
+ "pint": [
+ "pint"
],
- "l7": [
- "composer require laravel/framework:7.* orchestra/testbench:5.* --no-interaction --no-update",
- "composer update --prefer-stable --prefer-dist --no-interaction"
- ],
- "l6": [
- "composer require laravel/framework:6.* orchestra/testbench:4.* --no-interaction --no-update",
- "composer update --prefer-stable --prefer-dist --no-interaction"
+ "larastan": [
+ "@php -d memory_limit=-1 vendor/bin/phpstan"
]
}
}
diff --git a/config/cloud-tasks.php b/config/cloud-tasks.php
index c8cbdca..4a77375 100644
--- a/config/cloud-tasks.php
+++ b/config/cloud-tasks.php
@@ -3,8 +3,9 @@
declare(strict_types=1);
return [
- 'dashboard' => [
- 'enabled' => env('STACKKIT_CLOUD_TASKS_DASHBOARD_ENABLED', false),
- 'password' => env('STACKKIT_CLOUD_TASKS_DASHBOARD_PASSWORD', 'MyPassword1!')
- ],
+ // The URI of the endpoint that will handle the task
+ 'uri' => env('CLOUD_TASKS_URI', 'handle-task'),
+
+ // If the application only dispatches jobs
+ 'disable_task_handler' => env('CLOUD_TASKS_DISABLE_TASK_HANDLER', false),
];
diff --git a/dashboard/.env.production b/dashboard/.env.production
deleted file mode 100644
index 292a14c..0000000
--- a/dashboard/.env.production
+++ /dev/null
@@ -1 +0,0 @@
-VITE_API_URL=
diff --git a/dashboard/.gitignore b/dashboard/.gitignore
deleted file mode 100644
index a84704d..0000000
--- a/dashboard/.gitignore
+++ /dev/null
@@ -1,4 +0,0 @@
-node_modules
-.DS_Store
-dist-ssr
-*.local
\ No newline at end of file
diff --git a/dashboard/.prettierignore b/dashboard/.prettierignore
deleted file mode 100644
index 85dd8c4..0000000
--- a/dashboard/.prettierignore
+++ /dev/null
@@ -1,6 +0,0 @@
-# Ignore artifacts:
-build
-coverage
-.vscode
-node_modules
-.idea
diff --git a/dashboard/.prettierrc.js b/dashboard/.prettierrc.js
deleted file mode 100644
index 0614ee7..0000000
--- a/dashboard/.prettierrc.js
+++ /dev/null
@@ -1,6 +0,0 @@
-module.exports = {
- trailingComma: 'es5',
- tabWidth: 2,
- semi: false,
- singleQuote: true,
-}
diff --git a/dashboard/.prettierrc.json b/dashboard/.prettierrc.json
deleted file mode 100644
index b2095be..0000000
--- a/dashboard/.prettierrc.json
+++ /dev/null
@@ -1,4 +0,0 @@
-{
- "semi": false,
- "singleQuote": true
-}
diff --git a/dashboard/README.md b/dashboard/README.md
deleted file mode 100644
index c0793a8..0000000
--- a/dashboard/README.md
+++ /dev/null
@@ -1,7 +0,0 @@
-# Vue 3 + Vite
-
-This template should help get you started developing with Vue 3 in Vite. The template uses Vue 3 `
-
-
-
-
-
-
-
-