Triggering renders from PHP
To trigger a Lambda render using PHP, you need to use the AWS SDK directly. Below you find a snippet showing the sample call to the AWS SDK. Note the following:
- You first need to complete the Lambda setup.
- Unstable API: The format that Remotion Lambda accepts can change in every version. You need to consult the history of this page to see the changes over time. This page always shows the latest version of the payload.
- Sending large input props (>200KB) is not supported with PHP at the moment.
remotion.phpphp
remotion.phpphp
Reference applications
2 reference projects are available:
- php-remotion. This is an application that invokes the Remotion Lambda function containing the minimum parameters to render a video.
- remotion-laravel is an application that serves a REST endpoint using Laravel PHP framework. This endpoint invokes the Remotion lambda function with the necessary parameters to render a video.
Both use remotion-app, which includes a Remotion composition and utility scripts for deploying and deleting Remotion Lambda infrastructure in AWS.
Bare PHP
Ensure that remotion-app is already deployed on your AWS Account.
The php-remotion application will call Remotion Lambda to render a video and contains the bare minimum parameters for Remotion's Lambda arguments. Once the parameters are constructed, they will be passed on to the AWS Lambda Client using the AWS PHP SDK. This project imitates the operation of rendermediaonlambda and uses composer.
Clone the project using:
bash
bash
remotion-serverless/php-remotion 
bash
bash
bash
bash
The application has a .env file that needs to be populated for the video render to work properly. An .env.example has been included in the project containing example values.
.envbash
.envbash
- REMOTION_APP_REGIONIs the AWS region you are using, e.g- us-east-1.
- REMOTION_APP_IS_ASSUME_ROLEaccepts either- trueor- false. When set to- truethe application the application calls the AWS STS- AssumeRolecommand, retrieve the- key,- secretand- tokenand pass those credentials in- LambdaClient::factory. Ensure that- REMOTION_APP_ROLE_ARNand- REMOTION_APP_ROLE_SESSION_NAMEare provided when using this flag. This approach is appropriate if you want to deploy this application in AWS EC2. Roles are required to be set up for the application. Please refer to the Authenticating Lambda with EC2 guide and follow steps 1 to 4.Assume rolebash$credentials = NULL;if ($_ENV["REMOTION_APP_IS_ASSUME_ROLE"] === true) {$credentials = assumeRole($_ENV["REMOTION_APP_REGION"],$_ENV["REMOTION_APP_ROLE_ARN"], $_ENV["REMOTION_APP_ROLE_SESSION_NAME"]);}$client = LambdaClient::factory(['version' => 'latest','region' => $region,'credentials' => $credentials,]);Assume rolebash$credentials = NULL;if ($_ENV["REMOTION_APP_IS_ASSUME_ROLE"] === true) {$credentials = assumeRole($_ENV["REMOTION_APP_REGION"],$_ENV["REMOTION_APP_ROLE_ARN"], $_ENV["REMOTION_APP_ROLE_SESSION_NAME"]);}$client = LambdaClient::factory(['version' => 'latest','region' => $region,'credentials' => $credentials,]);
The following variables can be retrieved by completing the Lambda setup:
- REMOTION_APP_BUCKET- Your bucket name
- REMOTION_APP_FUNCTION_NAME- The name of your deployed function. Note that it changes on every Remotion version.
- REMOTION_APP_SERVE_URLis where your Webpack bundle is hosted.
When you use Remotion on an AWS EC2 instance, set the following env variables. To set up the required roles, please refer to the Authenticating Lambda with EC2 guide and follow steps 1 to 4.
- REMOTION_APP_ROLE_ARNrepresents the ARN of the role which the application assume to render the video, for this instance it is- remotion-ec2-executionroleARN from- step 2on this guide.
- REMOTION_APP_ROLE_SESSION_NAMEa name to uniquely identify the role session when the same role is assumed by different principals.
Run the application by executing the command below:
Run applicationbash
Run applicationbash
Sample application responsebash
Sample application responsebash
Once the execution is successful, the API will responsd with the bucketName and renderId. These are metadata required to get the status the video render or retrieving video.
Laravel
This application can be executed on a local machine or computing instance, such as AWS EC2, to call Remotion Lambda and render a video. It includes the minimum parameters required for Remotion's Lambda arguments from a REST endpoint.
After constructing the parameters, they will be passed on to the AWS Lambda Client using the AWS PHP SDK. It also contains Laravel boilerplate code for setting up a REST endpoint that calls the Remotion Lambda. This project imitates the operation of renderMediaOnLambda() and uses Composer.
bash
bash
remotion-serverless/remotion-laravel 
bash
bash
bash
bash
Refer to the bare PHP example for setting up the environment variables.
The application requires a database, and for this application, SQLLite is used. Therefore, the configuration details from the .env file need to be provided.
.env (continued)bash
.env (continued)bash
- DB_CONNECTIONis the connection type that represents which database to use ie,- MYSQL
- DB_DATABASEis the database name, for this instance this represents the absolute URL path of the SQLite database.
Create the database and table in SQLite defined in DB_DATABASE by executing the command below:
Create a database and tablebash
Create a database and tablebash
Run the application by executing the command below:
Run applicationbash
Run applicationbash
Send register requestbash
Send register requestbash
Log into the applicationbash
Log into the applicationbash
Sample responsejson
Sample responsejson
Render video requestbash
Render video requestbash
Example responsejson
Example responsejson
Checking progress
For retrieving the progress of a Lambda render, you need to send another request to the Lambda function. Currently we do not have instructions for it, as a reference you may see here for the payload that is being sent by the TypeScript SDK.