PHP code example of finller / laravel-aws-mediaconvert
1. Go to this page and download the library: Download finller/laravel-aws-mediaconvert library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
finller / laravel-aws-mediaconvert example snippets
return [
/**
* IAM Credentials from AWS.
*
* Please note, if you are intending to use Laravel Vapor, rename
* From: AWS_ACCESS_KEY_ID - To: e.g. VAPOR_ACCESS_KEY_ID
* From: AWS_SECRET_ACCESS_KEY - To: e.g. VAPOR_SECRET_ACCESS_KEY
* and ensure that your Vapor environment has these values defined.
*/
'credentials' => [
'key' => env('AWS_ACCESS_KEY_ID'),
'secret' => env('AWS_SECRET_ACCESS_KEY'),
],
'region' => env('AWS_DEFAULT_REGION', 'us-east-1'),
'version' => 'latest',
'url' => env('AWS_MEDIACONVERT_ACCOUNT_URL'),
/**
* Specify the IAM Role ARN.
*
* You can find the Role ARN visiting the following URL:
* https://console.aws.amazon.com/iam/home?region=us-east-1#/roles
* Please note to adjust the "region" in the URL above.
* Tip: in case you need to create a new Role, you may name it `MediaConvert_Default_Role`
* by making use of this name, AWS MediaConvert will default to using this IAM Role.
*/
'iam_arn' => env('AWS_IAM_ARN'),
/**
* Specify the queue you would like use.
*
* It can be found by visiting the following URL:
* https://us-east-1.console.aws.amazon.com/mediaconvert/home?region=us-east-1#/queues/details/Default
* Please note to adjust the "region" in the URL above.
*/
'queue_arn' => env('AWS_QUEUE_ARN'),
/**
* Specify how often MediaConvert sends STATUS_UPDATE events to Amazon CloudWatch Events.
* Set the interval, in seconds, between status updates.
*
* MediaConvert sends an update at this interval from the time the service begins processing
* your job to the time it completes the transcode or encounters an error.
*
* Accepted values: 10, 12, 15, 20, 30, 60, 120, 180, 240, 300, 360, 420, 480, 540, 600
*/
'webhook_interval' => 60,
];
$input = AwsMediaConvert::getUri($path); // you can use getUri to build the S3 uri quickly
AwsMediaConvert::createJob(
settings: DefaultMediaConvertSettings::make($input)
->addOutputGroup(
DefaultOptimizedVideoMediaConvertGroup::make(
Destination: $destination,
Height: min(1080, $originalHeight) // optional but you can set a Height or Width to resize the video
)
)
->toArray(),
metaData: [ // feel free to add metadata so you can do the right action when receiving the webhook
'env' => config('app.env'),
get_class($this->media) => $this->media->id,
'job' => get_class($this),
]
);
$input = AwsMediaConvert::getUri($path); // you can use getUri to build the S3 uri easily
AwsMediaConvert::createJob(
settings: DefaultMediaConvertSettings::make($input)
->addOutputGroup(
DefaultHlsMediaConvertGroup::make($destination)
->addOutputWhen($maxHeight >= 1080, DefaultHls1080pMediaConvertOutput::make())
->addOutputWhen($maxHeight >= 720, DefaultHls720pMediaConvertOutput::make())
->addOutputWhen($maxHeight >= 540, DefaultHls540pMediaConvertOutput::make())
->addOutputWhen($maxHeight >= 540, DefaultHls480pMediaConvertOutput::make())
)
->toArray(),
metaData: []
);
$input = AwsMediaConvert::getUri($path); // you can use getUri to build the S3 uri easily
AwsMediaConvert::createJob(
settings: DefaultMediaConvertSettings::make($input)
->addOutputGroup(
DefaultOptimizedVideoMediaConvertGroup::make(
Destination: $destination,
Height: min(1080, $originalHeight) // optional but you can set a Height or Width to resize the video
)
)
->addOutputGroup(
DefaultHlsMediaConvertGroup::make($destination)
->addOutputWhen($originalHeight >= 1080, DefaultHls1080pMediaConvertOutput::make())
->addOutputWhen($originalHeight >= 720, DefaultHls720pMediaConvertOutput::make())
->addOutputWhen($originalHeight >= 540, DefaultHls540pMediaConvertOutput::make())
->addOutputWhen($originalHeight >= 540, DefaultHls480pMediaConvertOutput::make())
)
->toArray(),
metaData: []
);
class VerifyCsrfToken extends Middleware
{
/**
* The URIs that should be excluded from CSRF verification.
*
* @var array<int, string>
*/
protected $except = [
'aws/*', // Put the route you have chosen here
];
}