getAwsClient()
This API exposes full access to the AWS SDK that Remotion uses under the hood. You can use it to interact with your AWS infrastructure in ways that Remotion doesn't provide a function for.
Example: Getting a buffer for a render
tsx
// Import from "@remotion/lambda" instead before Remotion v4.0.60import { getAwsClient, getRenderProgress } from "@remotion/lambda/client";import { Readable } from "stream";const bucketName = "remotionlambda-d9mafgx";const getFileAsBuffer = async () => {const progress = await getRenderProgress({renderId: "d7nlc2y",bucketName: "remotionlambda-d9mafgx",functionName: "remotion-render-la8ffw",region: "us-east-1",});if (!progress.outKey) {// Video not yet renderedreturn;}const { client, sdk } = getAwsClient({ region: "us-east-1", service: "s3" });const data = client.send(new sdk.GetObjectCommand({Bucket: bucketName,Key: progress.outKey,}),);return data.Body as Readable;};
tsx
// Import from "@remotion/lambda" instead before Remotion v4.0.60import { getAwsClient, getRenderProgress } from "@remotion/lambda/client";import { Readable } from "stream";const bucketName = "remotionlambda-d9mafgx";const getFileAsBuffer = async () => {const progress = await getRenderProgress({renderId: "d7nlc2y",bucketName: "remotionlambda-d9mafgx",functionName: "remotion-render-la8ffw",region: "us-east-1",});if (!progress.outKey) {// Video not yet renderedreturn;}const { client, sdk } = getAwsClient({ region: "us-east-1", service: "s3" });const data = client.send(new sdk.GetObjectCommand({Bucket: bucketName,Key: progress.outKey,}),);return data.Body as Readable;};
Example: Enable CORS for a bucket
tsx
// Import from "@remotion/lambda" instead before Remotion v4.0.60import { getAwsClient } from "@remotion/lambda/client";const { client, sdk } = getAwsClient({ region: "us-east-1", service: "s3" });client.send(new sdk.PutBucketCorsCommand({Bucket: "[bucket-name]",CORSConfiguration: {CORSRules: [{AllowedMethods: ["GET", "HEAD"],AllowedHeaders: ["*"],AllowedOrigins: ["*"],},],},}),);
tsx
// Import from "@remotion/lambda" instead before Remotion v4.0.60import { getAwsClient } from "@remotion/lambda/client";const { client, sdk } = getAwsClient({ region: "us-east-1", service: "s3" });client.send(new sdk.PutBucketCorsCommand({Bucket: "[bucket-name]",CORSConfiguration: {CORSRules: [{AllowedMethods: ["GET", "HEAD"],AllowedHeaders: ["*"],AllowedOrigins: ["*"],},],},}),);
Arguments
An object with two mandatory parameters:
region
One of the supported regions of Remotion Lambda, for which the client should be instantiated.
service
One of lambda
, cloudwatch
, iam
, servicequotas
, s3
or sts
.
customCredentials?
v3.2.23
Allows you to connect to another cloud provider, useful if you render your output to a different cloud. The value must satisfy the following type:
ts
type CustomCredentials = {endpoint: string;accessKeyId: string | null;secretAccessKey: string | null;};
ts
type CustomCredentials = {endpoint: string;accessKeyId: string | null;secretAccessKey: string | null;};
forcePathStyle?
v4.0.202
Passes forcePathStyle
to the AWS S3 client. If you don't know what this is, you probably don't need it.
Return value
An object with two properties:
client
An AWS SDK client instantiated with the region you passed and the credentials you had set at the time of calling the function.
- For
s3
: An instance of S3Client - For
iam
: An instance of IAMClient - For
cloudwatch
: An instance of CloudWatchLogsClient - For
servicequotas
: An instance of ServiceQuotasClient - For
lambda
: An instance of LambdaClient
sdk
The full SDK JavaScript module for the service you specified.
- For
s3
: The@aws-sdk/client-s3
package - For
iam
: The@aws-sdk/client-iam
package - For
cloudwatch
: The@aws-sdk/client-cloudwatch-logs
package - For
servicequotas
: The@aws-sdk/client-service-quotas
package - For
lambda
: The@aws-sdk/client-lambda
package
You don't need to create a new client from the SDK and should instead reuse the client
that is also returned and being used by Remotion, in order to save memory.