Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/transloadit/php-sdk
Transloadit's official PHP SDK
https://github.com/transloadit/php-sdk
encoding php transloadit uploading
Last synced: 4 days ago
JSON representation
Transloadit's official PHP SDK
- Host: GitHub
- URL: https://github.com/transloadit/php-sdk
- Owner: transloadit
- License: mit
- Created: 2010-12-05T23:00:39.000Z (about 14 years ago)
- Default Branch: main
- Last Pushed: 2024-12-03T11:56:27.000Z (about 1 month ago)
- Last Synced: 2024-12-29T18:09:53.581Z (12 days ago)
- Topics: encoding, php, transloadit, uploading
- Language: PHP
- Homepage: https://transloadit.com/
- Size: 481 KB
- Stars: 61
- Watchers: 7
- Forks: 23
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# Transloadit PHP SDK
[![Test Actions Status][test_badge]][test_link]
[![Code coverage][codecov_badge]][codecov_link]
![Packagist PHP Version Support][php_verison_badge]
[![License][licence_badge]][licence_link]## Introduction
The Transloadit PHP SDK provides a simple and efficient way to interact with Transloadit's file processing service in your PHP applications. With this SDK, you can easily:
- Create and manage file upload assemblies
- Use pre-defined templates for common file processing tasks
- Handle notifications and retrieve assembly statuses
- Integrate Transloadit's powerful file processing capabilities into your PHP projectsThis SDK simplifies the process of working with Transloadit's REST API, allowing you to focus on building great applications without worrying about the complexities of file processing.
## Install
```
composer require transloadit/php-sdk
```Keep your Transloadit account's Auth Key & Secret nearby. You can check
the [API credentials](https://transloadit.com/accounts/credentials) page for
these values.## Usage
### 1. Upload and resize an image from your server
This example demonstrates how you can use the SDK to create an Assembly
on your server.It takes a sample image file, uploads it to Transloadit, and starts a
resizing job on it.```php
'MY_TRANSLOADIT_KEY',
'secret' => 'MY_TRANSLOADIT_SECRET',
]);$response = $transloadit->createAssembly([
'files' => ['/PATH/TO/FILE.jpg'],
'params' => [
'steps' => [
'resize' => [
'robot' => '/image/resize',
'width' => 200,
'height' => 100,
],
],
],
]);// Show the results of the assembly we spawned
echo '';';
print_r($response);
echo '```
### 2. Create a simple end-user upload form
This example shows you how to create a simple Transloadit upload form
that redirects back to your site after the upload is done.Once the script receives the redirect request, the current status for
this Assembly is shown using `Transloadit::response()`.
Note: There is no guarantee that the Assembly has already finished
executing by the time the$response
is fetched. You should use
thenotify_url
parameter for this.```php
'MY_TRANSLOADIT_KEY',
'secret' => 'MY_TRANSLOADIT_SECRET',
]);// Check if this request is a Transloadit redirect_url notification.
// If so fetch the response and output the current assembly status:
$response = Transloadit::response();
if ($response) {
echo 'Assembly Status:
';
echo '';';
print_r($response);
echo '
exit;
}// This should work on most environments, but you might have to modify
// this for your particular setup.
$redirectUrl = sprintf('http://%s%s', $_SERVER['HTTP_HOST'], $_SERVER['REQUEST_URI']);// Setup a simple file upload form that resizes an image to 200x100px
echo $transloadit->createAssemblyForm([
'params' => [
'steps' => [
'resize' => [
'robot' => '/image/resize',
'width' => 200,
'height' => 100,
],
],
'redirect_url' => $redirectUrl,
],
]);
?>Pick an image to resize
```
### 3. Use Uppy for file uploads
We recommend using [Uppy](https://transloadit.com/docs/sdks/uppy/), our next-gen file uploader for the web, instead of the jQuery SDK. Uppy provides a more modern, flexible, and feature-rich solution for handling file uploads with Transloadit.
To integrate Uppy with your PHP backend:
1. Include Uppy in your HTML:
```html
```
2. Initialize Uppy with Transloadit plugin:
```html
const uppy = new Uppy.Core()
.use(Uppy.Dashboard, {
inline: true,
target: '#uppy'
})
.use(Uppy.Transloadit, {
params: {
auth: { key: 'MY_TRANSLOADIT_KEY' },
template_id: 'MY_TEMPLATE_ID',
notify_url: 'https://your-site.com/transloadit_notify.php'
}
})uppy.on('complete', (result) => {
console.log('Upload complete! We've uploaded these files:', result.successful)
})```
3. Handle the assembly status on your PHP backend:
Create a new file named `transloadit_notify.php` in your project:
```php
'MY_TRANSLOADIT_KEY',
'secret' => 'MY_TRANSLOADIT_SECRET',
]);$response = Transloadit::response();
if ($response) {
// Process the assembly result
$assemblyId = $response->data['assembly_id'];
$assemblyStatus = $response->data['ok'];// You can store the assembly information in your database
// or perform any other necessary actions here// Log the response for debugging
error_log('Transloadit Assembly Completed: ' . $assemblyId);
error_log('Assembly Status: ' . ($assemblyStatus ? 'Success' : 'Failed'));// Optionally, you can write the response to a file
file_put_contents('transloadit_response_' . $assemblyId . '.json', json_encode($response->data));// Send a 200 OK response to Transloadit
http_response_code(200);
echo 'OK';
} else {
// If it's not a Transloadit notification, return a 400 Bad Request
http_response_code(400);
echo 'Bad Request';
}
?>
```Make sure to replace `'https://your-site.com/transloadit_notify.php'` with the actual URL where you'll host this PHP script.
For more detailed information on using Uppy with Transloadit, please refer to our [Uppy documentation](https://transloadit.com/docs/sdks/uppy/).
### 4. Fetch the Assembly Status JSON
You can use the `getAssembly` method to get the Assembly Status.
```php
'MY_TRANSLOADIT_KEY',
'secret' => 'MY_TRANSLOADIT_SECRET',
]);$response = $transloadit->getAssembly($assemblyId);
echo '
';';
print_r($response);
echo '```
### 5. Create an Assembly with a Template.
This example demonstrates how you can use the SDK to create an Assembly
with Templates.You are expected to create a Template on your Transloadit account dashboard
and add the Template ID here.```php
'MY_TRANSLOADIT_KEY',
'secret' => 'MY_TRANSLOADIT_SECRET',
]);$response = $transloadit->createAssembly([
'files' => ['/PATH/TO/FILE.jpg'],
'params' => [
'template_id' => 'MY_TEMPLATE_ID',
],
]);// Show the results of the assembly we spawned
echo '';';
print_r($response);
echo '```
### Signature Auth (Assemblies)
Signature Authentication is done by the PHP SDK by default internally so you do not need to worry about this :)
### Signature Auth (Smart CDN)
You can use the `signedSmartCDNUrl` method to generate signed URLs for Transloadit's [Smart CDN](https://transloadit.com/services/content-delivery/):
```php
'MY_TRANSLOADIT_KEY',
'secret' => 'MY_TRANSLOADIT_SECRET',
]);// Basic usage
$url = $transloadit->signedSmartCDNUrl(
'your-workspace-slug',
'your-template-slug',
'avatars/jane.jpg'
);// Advanced usage with custom parameters and expiry
$url = $transloadit->signedSmartCDNUrl(
'your-workspace-slug',
'your-template-slug',
'avatars/jane.jpg',
['width' => 100, 'height' => 100], // Additional parameters
1732550672867, // Expiry date in milliseconds since epoch
);echo $url;
```The generated URL will be in the format:
```
https://{workspace-slug}.tlcdn.com/{template-slug}/{input-field}?{query-params}&sig=sha256:{signature}
```Note that:
- The URL will expire after the specified time (default: 1 hour)
- All parameters are properly encoded
- The signature is generated using HMAC SHA-256
- Query parameters are sorted alphabetically before signing## Example
For fully working examples take a look at [`examples/`](https://github.com/transloadit/php-sdk/tree/HEAD/examples).
## API
### $Transloadit = new Transloadit($properties = []);
Creates a new Transloadit instance and applies the given $properties.
#### $Transloadit->key = null;
The auth key of your Transloadit account.
#### $Transloadit->secret = null;
The auth secret of your Transloadit account.
#### $Transloadit->request($options = [], $execute = true);
Creates a new `TransloaditRequest` using the `$Transloadit->key` and
`$Transloadit->secret` properties.If `$execute` is set to `true`, `$TransloaditRequest->execute()` will be
called and used as the return value.Otherwise the new `TransloaditRequest` instance is being returned.
#### $Transloadit->createAssemblyForm($options = []);
Creates a new Transloadit assembly form including the hidden 'params' and
'signature' fields. A closing form tag is not included.`$options` is an array of `TransloaditRequest` properties to be used.
For example: `"params"`, `"expires"`, `"endpoint"`, etc..In addition to that, you can also pass an `"attributes"` key, which allows
you to set custom form attributes. For example:```php
$Transloadit->createAssemblyForm(array(
'attributes' => array(
'id' => 'my_great_upload_form',
'class' => 'transloadit_form',
),
));
```#### $Transloadit->createAssembly($options);
Sends a new assembly request to Transloadit. This is the preferred way of
uploading files from your server.`$options` is an array of `TransloaditRequest` properties to be used with the exception that you can
also use the `waitForCompletion` option here:`waitForCompletion` is a boolean (default is false) to indicate whether you want to wait for the
Assembly to finish with all encoding results present before the callback is called. If
waitForCompletion is true, this SDK will poll for status updates and return when all encoding work
is done.Check example #1 above for more information.
#### $Transloadit->getAssembly($assemblyId);
Retrieves the Assembly status json for a given Assembly ID.
#### $Transloadit->cancelAssembly($assemblyId);
Cancels an assembly that is currently executing and prevents any further encodings costing money.
This will result in `ASSEMBLY_NOT_FOUND` errors if invoked on assemblies that are not currently
executing (anymore).#### Transloadit::response()
This static method is used to parse the notifications Transloadit sends to
your server.There are two kinds of notifications this method handles:
- When using the `redirect_url` parameter, and Transloadit redirects
back to your site, a `$_GET['assembly_url']` query parameter gets added.
This method detects the presence of this parameter and fetches the current
assembly status from that url and returns it as a `TransloaditResponse`.
- When using the `notify_url` parameter, Transloadit sends a
`$_POST['transloadit']` parameter. This method detects this, and parses
the notification JSON into a `TransloaditResponse` object for you.If the current request does not seem to be invoked by Transloadit, this
method returns `false`.### $TransloaditRequest = new TransloaditRequest($properties = []);
Creates a new TransloaditRequest instance and applies the given $properties.
#### $TransloaditRequest->key = null;
The auth key of your Transloadit account.
#### $TransloaditRequest->secret = null;
The auth secret of your Transloadit account.
#### $TransloaditRequest->method = 'GET';
Inherited from `CurlRequest`. Can be used to set the type of request to be
made.#### $TransloaditRequest->curlOptions = [];
Inherited from `CurlRequest`. Can be used to tweak cURL behavior using [any cURL option that your PHP/cURL version supports](https://www.php.net/manual/en/function.curl-setopt.php).
Here is an [example](examples/6-assembly-with-timeout.php) that illustrates
using this option to change the timeout of a request (drastically, to `1ms`, just to prove you can make the SDK abort after a time of your choosing).The default timeouts and options depend on the cURL version on your system and can be verified by checking `phpinfo()` and the [curl_setopt](https://www.php.net/manual/en/function.curl-setopt.php) documentation.
#### $TransloaditRequest->endpoint = 'https://api2.transloadit.com';
The endpoint to send this request to.
#### $TransloaditRequest->path = null;
The url path to request.
#### $TransloaditRequest->url = null;
Inherited from `CurlRequest`. Lets you overwrite the above endpoint / path
properties with a fully custom url alltogether.#### $TransloaditRequest->fields = [];
A list of additional fields to send along with your request. Transloadit
will include those in all assembly related notifications.#### $TransloaditRequest->files = [];
An array of paths to local files you would like to upload. For example:
```php
$TransloaditRequest->files = array('/my/file.jpg');
```or
```php
$TransloaditRequest->files = array('my_upload' => '/my/file.jpg');
```The first example would automatically give your file a field name of
`'file_1'` when executing the request.#### $TransloaditRequest->params = [];
An array representing the JSON params to be send to Transloadit. You
do not have to include an `'auth'` key here, as this class handles that
for you as part of `$TransloaditRequest->prepare()`.#### $TransloaditRequest->expires = '+2 hours';
If you have configured a '`$TransloaditRequest->secret`', this class will
automatically sign your request. The expires property lets you configure
the duration for which the signature is valid.#### $TransloaditRequest->headers = [];
Lets you send additional headers along with your request. You should not
have to change this property.#### $TransloaditRequest->execute()
Sends this request to Transloadit and returns a `TransloaditResponse`
instance.### $TransloaditResponse = new TransloaditResponse($properties = []);
Creates a new TransloaditResponse instance and applies the given $properties.
#### $TransloaditResponse->data = null;
Inherited from `CurlResponse`. Contains an array of the parsed JSON
response from Transloadit.You should generally only access this property after having checked for
errors using `$TransloaditResponse->error()`.#### $TransloaditResponse->error();
Returns `false` or a string containing an explanation of what went wrong.
All of the following will cause an error string to be returned:
- Network issues of any kind
- The Transloadit response JSON contains an `{"error": "..."}` key
- A malformed response was received**_Note_**: You will need to set waitForCompletion = True in the $Transloadit->createAssembly($options) function call.
## Contributing
Feel free to fork this project. We will happily merge bug fixes or other small
improvements. For bigger changes you should probably get in touch with us
before you start to avoid not seeing them merged.### Testing
#### Basic Tests
```bash
make test
```#### System Tests
System tests require:
1. Valid Transloadit credentials in environment:
```bash
export TRANSLOADIT_KEY='your-auth-key'
export TRANSLOADIT_SECRET='your-auth-secret'
```Then run:
```bash
make test-all
```#### Node.js Reference Implementation Parity Assertions
The SDK includes assertions that compare URL signing with our reference Node.js implementation. To run these tests:
1. Requirements:
- Node.js installed
- tsx installed globally (`npm install -g tsx`)2. Install dependencies:
```bash
npm install -g tsx
```3. Run the test:
```bash
export TRANSLOADIT_KEY='your-auth-key'
export TRANSLOADIT_SECRET='your-auth-secret'
TEST_NODE_PARITY=1 make test-all
```CI opts-into `TEST_NODE_PARITY=1`, and you can optionally do this locally as well.
### Releasing a new version
To release, say `3.2.0` [Packagist](https://packagist.org/packages/transloadit/php-sdk), follow these steps:
1. Make sure `PACKAGIST_TOKEN` is set in your `.env` file
1. Make sure you are in main: `git checkout main`
1. Update `CHANGELOG.md` and `composer.json`
1. Commit: `git add CHANGELOG.md composer.json && git commit -m "Release 3.2.0"`
1. Tag, push, and release: `source env.sh && VERSION=3.2.0 ./release.sh`This project implements the [Semantic Versioning](http://semver.org/) guidelines.
## License
[MIT Licensed](LICENSE)
[test_badge]: https://github.com/transloadit/php-sdk/actions/workflows/ci.yml/badge.svg
[test_link]: https://github.com/transloadit/php-sdk/actions/workflows/ci.yml
[codecov_badge]: https://codecov.io/gh/transloadit/php-sdk/branch/main/graph/badge.svg
[codecov_link]: https://codecov.io/gh/transloadit/php-sdk
[php_verison_badge]: https://img.shields.io/packagist/php-v/transloadit/php-sdk
[licence_badge]: https://img.shields.io/badge/License-MIT-green.svg
[licence_link]: https://github.com/transloadit/php-sdk/blob/main/LICENSE